我们知道得到String对象有两种办法:String str1="hello";String str2=new String("hello");
这两种创建String对象的方法有什么差异吗?当然有差异,差异就在于第一种方法在对象池中拿对象,第二种方法直接生成新的对象。在JDK5.0里面,Java虚拟机在启动的时候会实例化9个对象池,这9个对象池分别用来存储8种基本类型的包装类对象和String对象。当我们在程序中直接用双引号括起来一个字符串时,JVM就到String的对象池里面去找看是否有一个值相同的对象,如果有,就拿现成的对象,如果没有就在对象池里面创建一个对象,并返回。所以我们发现下面的代码输出true:
String
str1="hello";
String
str2="hello";System.out.println(str1==str2);
这说明str1和str2指向同一个对象,因为它们都是在对象池中拿到的,而下面的代码输出为false:
String
str3="hello"
String
str4=new String("hello");System.out.println(str3==str4);因为在任何情况下,只要你去new一个String对象那都是在堆里创建了一个新的对象。与此类似的,在JDK5.0里面8种基本类型的包装类也有这样的差异:
Integer
i1=5;//在对象池中拿
Integer
i2 =5;//所以i1==i2
Integer
i3=new Integer(5);//重新创建新对象,所以i2!=i3对象池的存在是为了避免频繁的创建和销毁对象而影响系统性能,那我们自己写的类是否也可以使用对象池呢?当然可以,请看以下代码:
import java.util.HashSet;//
使用对象池来得到对象的方法public static Student newInstance(String name, int age)
{//
循环遍历对象池for (Student stu : pool) {if (stu.name.equals(name) &&
stu.age == age) {return stu;}}//
如果找不到值相同的Student对象,则创建一个Student对象//
并把它加到对象池中然后返回该对象。Student stu = new Student(name, age);
pool.add(stu);return stu;}
} }在这顺便说一句:不要滥用哈希表,有一定开发经验的开发人员经常会使用hash表(hash表在JDK中的一个实现就是HashMap)来缓存一些数据,从而提高系统的运行速度。比如使用HashMap缓存一些物料信息、人员信息等基础资料,这在提高系统速度的同时也加大了系统的内存占用,特别是当缓存的资料比较多的时候。其实我们可以使用操作系统中的缓存的概念来解决这个问题,也就是给被缓存的分配一个一定大小的缓存容器,按照一定的算法淘汰不需要继续缓存的对象,这样一方面会因为进行了对象缓存而提高了系统的运行效率,同时由于缓存容器不是无限制扩大,从而也减少了系统的内存占用。现在有很多开源的缓存实现项目,比如ehcache、oscache等,这些项目都实现了FIFO、MRU等常见的缓存算法
String对象池的作用
时间: 2024-10-12 07:56:59
String对象池的作用的相关文章
Unity对象池试水
其实接触对象池这个概念已经很久了,网上也有很多现成的插件,比较有名的是PoolManager,功能听说很完善,我并没有细看.现在我想根据网上的一些案例和教程写一个应用于现在这个项目的小ObjectPool,这里有一篇文章对ObjectPool有一定的解释,有兴趣的可以看看.我项目里面有几十个反复要使用的模型,就在这一块下手吧,主要来实现存取两块代码,为了便于检索采用List<T>来实现存取. using UnityEngine; using System.Collections; using
java5核心基础之泛型(3)-泛型作用于编译阶段-怎样将String对象传入Integer类型的泛型对象中?
泛型作用于编译阶段: 泛型是作用于编译阶段,在编译阶段控制类型,以确保在编写代码的时候仅仅能传入指定类型数据到泛型集合对象中去. 怎样验证呢,贴代码例如以下: package highBasic.generic; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.util.ArrayList; public class StringAddToGeneri
java5核心基础之泛型(3)-泛型作用于编译阶段-如何将String对象传入Integer类型的泛型对象中?
泛型作用于编译阶段: 泛型是作用于编译阶段,在编译阶段控制类型,以确保在编写代码的时候只能传入指定类型数据到泛型集合对象中去.如何验证呢,贴代码如下: package highBasic.generic; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.util.ArrayList; public class StringAddToGenericInt
分析Java的String对象
对于Java中的String对象,个人觉得每个程序员都会思考过.学习过.研究过这个对象,因为他是面试官们的最爱.如:String s = new String("abc");,创建了几个对象.这种问题反复出现在程序员面试的过程中.下面我们对应着一些代码片段以及其的执行结果,来深入分析Java的String对象. 首先我们要注意的是String对象的处理在JDK6和JDK7中的处理是不同的.下面通过代码来分析String的三个主要方面知识. 1.常量池的存在 先看看下面代码以及执行结果:
JVM内存模型及String对象内存分配
昨天看了一篇关于<Java后端程序员1年工作经验总结>的文章,其中有一段关于String和StringBuffer的描述,对于执行结果仍然把握不准,趁此机会也总结了下JVM内存模型. 1.JVM运行时数据区域 关于JVM内存模型之前也了解过一些,也是看过就忘,好记性比如烂笔头,记下来吧.参考此文章http://chenzhou123520.iteye.com/blog/1585224 图1 JVM运行时数据区域 (1).程序计数器(Program Counter Register): 程序计数
java基础知识回顾之---java String final类 容易混淆的java String常量池内存分析
/** * 栈(Stack) :存放基本类型的变量数据和对象的引用,但对象本身不存放在栈中,而是存放在堆(new 出来的对象)或者常量池中(字符串常量对象存放 在常量池中). 堆(heap):存放所有new出来的对象. * 静态存储:存放静态成员(static定义的). 常量池(constant pool):在堆中分配出来的一块存储区域,存放储显式的String常量和基本类型常量(float.int等).另外,可以存储不经常改变的东西 * p
MySQL---数据库从入门走向大神系列(十)-Connection对象池、装饰模式与动态代理模式
问题概述: 之前本系列博客写的,全部都是一个connection对象,不知道大家发现没有,我们既然做了一个Connection工具类,那么大家肯定都是从那里面拿Connection对象的,之前的如果是多线程运行,很容易出问题的,你想想事务处理就知道了,同时用事务处理操作同一个Connection,肯定会出问题的. 例如: 一方的事务在提交的时候,你正好运行了一个事务中的一个操作,那么你这个操作也会被提交,而且你后面的提交或回滚失效的,如果对方把Connection关闭了,你的程序还会挂. 等等问
连接池的作用及讲解
连接池的作用就是为了提高性能. 连接池的作用:连接池是将已经创建好的连接保存在池中,当有请求来时,直接使用已经创建好的连接对数据库进行访问.这样省略了创建连接和销毁连接的过程.这样性能上得到了提高. 基本原理是这样的: (1)建立数据库连接池对象(服务器启动).(2)按照事先指定的参数创建初始数量的数据库连接(即:空闲连接数).(3)对于一个数据库访问请求,直接从连接池中得到一个连接.如果数据库连接池对象中没有空闲的连接,且连接数没有达到最大(即:最大活跃连接数),创建一个新的数据库连接.(4)
cocos2dx3.0 对象池
class CC_DLL AutoreleasePool { public: //创建一个存放ref的对象池.而且放入PoolManager对象池管理器中 AutoreleasePool(); //创建一个存放ref的对象池,而且放入PoolManager对象池管理器中,并取个名字 AutoreleasePool(const std::string &name); ~AutoreleasePool(); //加入一个ref对象到对象池中 void addObject(Ref *object);