- 浏览: 23000 次
- 性别:
- 来自: 江苏泰州
-
最近访客 更多访客>>
最新评论
-
minijack:
有不合理的地方,希望大家指点!
我的移动之旅001 -
minijack:
<div class="quote_title ...
从一道诡异的程序说起-----对象池技术 -
minijack:
<div class="quote_title ...
从一道诡异的程序说起-----对象池技术 -
minijack:
可读性有点差了! 呵呵
Data management and persistence in J2EE applications -
minijack:
不知道怎么弄图片到博客中,这个比较悲剧!没有图,这个效果差的太 ...
servlet学习笔记
这几天一直在看java面试题,其中有一个基本上一面都会问的问题。就是==与equal()的异同问题。这个问题本文不谈,本文谈谈在实验这==中遇到了一个问题。
程序如下:
因为127等于127,128等于128。 呵呵 很菜
然而现在的我会得出:false false
因为我懂了==比较的是对象引用,而不是内容的相等。
然而,经过当我把这些代码敲进运行时,发生了意想不到的事。true false
这个就比较诡异了。 同等情况下不可能会出现这种情况的。可是结果就是这样,没有办法肯定是有问题的。经过百度了一阵子终于解决了心中的诱惑,虽然具体细节不是很了解,但是能够明白点了。 其实这些都是一个叫: 对象池 的技术在搞鬼。
具体的讲解请看下文: java中的对象池技术
java中的对象池技术,是为了方便快捷地创建某些对象而出现的,当需要一个对象时,就可以从池中取一个出来(如果池中没有则创建一个),则在需要重复重复创建相等变量时节省了很多时间。对象池其实也就是一个内存空间,不同于使用new关键字创建的对象所在的堆空间。本文只从java使用者的角度来探讨java对象池技术,并不涉及对象池的原理及实现方法。个人认为,如果是真的专注java,就必须对这些细节方面有一定的了解。但知道它的原理和具体的实现方法则不是必须的。
1,对象池中对象和堆中的对象Java代码
2,8种基本类型的包装类和对象池java中基本类型的包装类的大部分都实现了对象池技术,这些类是Byte,Short,Integer,Long,Character,Boolean,另外两种浮点数类型的包装类则没有实现。另外Byte,Short,Integer,Long,Character这5种整型的包装类也只是在对应值小于等于127时才可使用对象池,也即对象不负责创建和管理大于127的这些类的对象。
以下是一些对应的测试代码:
Java代码
3,String也实现了对象池技术String类也是java中用得多的类,同样为了创建String对象的方便,也实现了对象池的技术,测试代码如下:
Java代码
估计看完了这篇文章,大家就很明白了。
这是本来学java不到一个月以来收获最最大的一天,并不是因为我学到了多么牛逼的技术,而是因为我学会发现问题,解决问题的思路。 正所谓 :实践是检验真理的唯一标准。学习技术什么问题拿不定,来出来跑跑就明白了。
上面这段代码如何解释???
恩恩 不错
程序如下:
public class Test { public static void main(String[] args) { Integer i1 = 127; Integer i2 = 127; System.out.println(i1 == i2); Integer i3 = 128; Integer i4 = 128; System.out.println(i3 == i4); } }一个月前的我毫无疑问,会得出这样一个答案: true true
因为127等于127,128等于128。 呵呵 很菜
然而现在的我会得出:false false
因为我懂了==比较的是对象引用,而不是内容的相等。
然而,经过当我把这些代码敲进运行时,发生了意想不到的事。true false
这个就比较诡异了。 同等情况下不可能会出现这种情况的。可是结果就是这样,没有办法肯定是有问题的。经过百度了一阵子终于解决了心中的诱惑,虽然具体细节不是很了解,但是能够明白点了。 其实这些都是一个叫: 对象池 的技术在搞鬼。
具体的讲解请看下文: java中的对象池技术
java中的对象池技术,是为了方便快捷地创建某些对象而出现的,当需要一个对象时,就可以从池中取一个出来(如果池中没有则创建一个),则在需要重复重复创建相等变量时节省了很多时间。对象池其实也就是一个内存空间,不同于使用new关键字创建的对象所在的堆空间。本文只从java使用者的角度来探讨java对象池技术,并不涉及对象池的原理及实现方法。个人认为,如果是真的专注java,就必须对这些细节方面有一定的了解。但知道它的原理和具体的实现方法则不是必须的。
1,对象池中对象和堆中的对象Java代码
public class Test{Integer i1=new Integer(1); Integer i2=new Integer(1); //i1,i2分别位于堆中不同的内存空间 System.out.println(i1==i2);//输出false Integer i3=1; Integer i4=1; //i3,i4指向对象池中同一个内存空间 System.out.println(i3==i4);//输出true//很显然, i1,i3位于不同的内存空间 System.out.println(i1==i3); //输出false} public class Test{Integer i1=new Integer(1); Integer i2=new Integer(1); //i1,i2分别位于堆中不同的内存空间 System.out.println(i1==i2);//输出false Integer i3=1; Integer i4=1; //i3,i4指向对象池中同一个内存空间 System.out.println(i3==i4);//输出true//很显然, i1,i3位于不同的内存空间 System.out.println(i1==i3); //输出false}
2,8种基本类型的包装类和对象池java中基本类型的包装类的大部分都实现了对象池技术,这些类是Byte,Short,Integer,Long,Character,Boolean,另外两种浮点数类型的包装类则没有实现。另外Byte,Short,Integer,Long,Character这5种整型的包装类也只是在对应值小于等于127时才可使用对象池,也即对象不负责创建和管理大于127的这些类的对象。
以下是一些对应的测试代码:
Java代码
public class Test{ public static void main(String[] args){ //5种整形的包装类Byte,Short,Integer,Long,Character的对象, //在值小于127时可以使用对象池 Integer i1=127; Integer i2=127; System.out.println(i1==i2)//输出true //值大于127时,不会从对象池中取对象 Integer i3=128; Integer i4=128; System.out.println(i3==i4)//输出false //Boolean类也实现了对象池技术 Boolean bool1=true; Boolean bool2=true; System.out.println(bool1==bool2);//输出true //浮点类型的包装类没有实现对象池技术 Double d1=1.0; Double d2=1.0; System.out.println(d1==d2)//输出false } }
public class Test{ public static void main(String[] args){ //5种整形的包装类Byte,Short,Integer,Long,Character的对象, //在值小于127时可以使用对象池 Integer i1=127; Integer i2=127; System.out.println(i1==i2)//输出true //值大于127时,不会从对象池中取对象 Integer i3=128; Integer i4=128; System.out.println(i3==i4)//输出false //Boolean类也实现了对象池技术 Boolean bool1=true; Boolean bool2=true; System.out.println(bool1==bool2);//输出true //浮点类型的包装类没有实现对象池技术 Double d1=1.0; Double d2=1.0; System.out.println(d1==d2)//输出false } }
3,String也实现了对象池技术String类也是java中用得多的类,同样为了创建String对象的方便,也实现了对象池的技术,测试代码如下:
Java代码
public class Test{ public static void main(String[] args){ //s1,s2分别位于堆中不同空间 String s1=new String("hello"); String s2=new String("hello"); System.out.println(s1==s2)//输出false//s3,s4位于池中同一空间 String s3="hello"; String s4="hello"; System.out.println(s3==s4);//输出true } }
估计看完了这篇文章,大家就很明白了。
这是本来学java不到一个月以来收获最最大的一天,并不是因为我学到了多么牛逼的技术,而是因为我学会发现问题,解决问题的思路。 正所谓 :实践是检验真理的唯一标准。学习技术什么问题拿不定,来出来跑跑就明白了。
评论
4 楼
minijack
2011-05-11
kaka-pan 写道
富哥啊 有点问题!!!!
Integer i1=127;
Integer i2=127;
这其实在jdk1.5以前版本是编译都不能通过的,1.5之后自动装箱机制变成了
Integer i1 = new Integer(127);
Integer是int封装类,编译的时候其实变成了Integer i1 = Integer.valueOf(127),你可以看看jdk里面Integer源代码中的valueOf()方法:
结论:
当这个值在-128和127之间时,会用缓存保存起来,供多次使用,以节约内存。
如果不在这个范围内,则创建一个新的Integer对象。即另外开辟一块内存,这个时候i1和i2将不再指向同一个对象。
Integer i1=127;
Integer i2=127;
这其实在jdk1.5以前版本是编译都不能通过的,1.5之后自动装箱机制变成了
Integer i1 = new Integer(127);
Integer是int封装类,编译的时候其实变成了Integer i1 = Integer.valueOf(127),你可以看看jdk里面Integer源代码中的valueOf()方法:
public static Integer valueOf(int i) { final int offset = 128; if (i >= -128 && i <= 127) { return IntegerCache.cache[i + offset]; } return new Integer(i); }
结论:
当这个值在-128和127之间时,会用缓存保存起来,供多次使用,以节约内存。
如果不在这个范围内,则创建一个新的Integer对象。即另外开辟一块内存,这个时候i1和i2将不再指向同一个对象。
public class Test{ public static void main(String[] args){ //s1,s2分别位于堆中不同空间 String s1=new String("hello"); String s2=new String("hello"); System.out.println(s1==s2)//输出false//s3,s4位于池中同一空间 String s3="hello"; String s4="hello"; System.out.println(s3==s4);//输出true } }
上面这段代码如何解释???
3 楼
minijack
2011-05-11
kaka-pan 写道
富哥啊 有点问题!!!!
Integer i1=127;
Integer i2=127;
这其实在jdk1.5以前版本是编译都不能通过的,1.5之后自动装箱机制变成了
Integer i1 = new Integer(127);
Integer是int封装类,编译的时候其实变成了Integer i1 = Integer.valueOf(127),你可以看看jdk里面Integer源代码中的valueOf()方法:
结论:
当这个值在-128和127之间时,会用缓存保存起来,供多次使用,以节约内存。
如果不在这个范围内,则创建一个新的Integer对象。即另外开辟一块内存,这个时候i1和i2将不再指向同一个对象。
Integer i1=127;
Integer i2=127;
这其实在jdk1.5以前版本是编译都不能通过的,1.5之后自动装箱机制变成了
Integer i1 = new Integer(127);
Integer是int封装类,编译的时候其实变成了Integer i1 = Integer.valueOf(127),你可以看看jdk里面Integer源代码中的valueOf()方法:
public static Integer valueOf(int i) { final int offset = 128; if (i >= -128 && i <= 127) { return IntegerCache.cache[i + offset]; } return new Integer(i); }
结论:
当这个值在-128和127之间时,会用缓存保存起来,供多次使用,以节约内存。
如果不在这个范围内,则创建一个新的Integer对象。即另外开辟一块内存,这个时候i1和i2将不再指向同一个对象。
恩恩 不错
2 楼
wupuyuan
2011-03-28
这个平时还真没注意过,呵呵,又学习到了新东西!
1 楼
kaka-pan
2011-03-27
富哥啊 有点问题!!!!
Integer i1=127;
Integer i2=127;
这其实在jdk1.5以前版本是编译都不能通过的,1.5之后自动装箱机制变成了
Integer i1 = new Integer(127);
Integer是int封装类,编译的时候其实变成了Integer i1 = Integer.valueOf(127),你可以看看jdk里面Integer源代码中的valueOf()方法:
结论:
当这个值在-128和127之间时,会用缓存保存起来,供多次使用,以节约内存。
如果不在这个范围内,则创建一个新的Integer对象。即另外开辟一块内存,这个时候i1和i2将不再指向同一个对象。
Integer i1=127;
Integer i2=127;
这其实在jdk1.5以前版本是编译都不能通过的,1.5之后自动装箱机制变成了
Integer i1 = new Integer(127);
Integer是int封装类,编译的时候其实变成了Integer i1 = Integer.valueOf(127),你可以看看jdk里面Integer源代码中的valueOf()方法:
public static Integer valueOf(int i) { final int offset = 128; if (i >= -128 && i <= 127) { return IntegerCache.cache[i + offset]; } return new Integer(i); }
结论:
当这个值在-128和127之间时,会用缓存保存起来,供多次使用,以节约内存。
如果不在这个范围内,则创建一个新的Integer对象。即另外开辟一块内存,这个时候i1和i2将不再指向同一个对象。
发表评论
-
浏览器工作原理
2011-06-12 22:56 1275首先对上篇blog进行一个补充: 以我做的“基于线程池和数据 ... -
HTTP小结
2011-06-12 18:01 736最近一直学习网络方面的内容,想写一个基于线程池和数据库连接池的 ... -
java为什么会这么火?
2011-06-09 22:51 1157java是sun公司发布的,起初是sun公司为了 ... -
序列化
2011-06-09 07:03 716序列化: 1. 永久化保存对象,保存对象的字节到本地文件中 2 ... -
Java面试之hibernate
2011-05-04 22:20 904Java面试之hibernate Hiber ... -
Java面试之struts
2011-05-03 21:53 756Java面试之struts Struts之我见: 在我看来 ... -
Java面试之数据类型
2011-05-03 12:44 838Java中类型大体分为两类,一类是原始类型,一类是引用类型。另 ... -
java对象实例初始化顺序
2011-05-02 23:59 746今天我在Dzone阅读了一篇关于java对象实例初始化顺序的有 ... -
java技术之GC
2011-04-27 17:11 834GC之我见: 在java中 ... -
Data management and persistence in J2EE applications
2011-04-26 17:35 959这几天学习了一下关于JDBC的内容,查了一些资料,其中还有一篇 ... -
java面试之JDBC
2011-04-25 23:17 7371. 简介 JDBC(Java Data Base Conne ... -
java面试之MVC
2011-04-22 23:58 951MVC是一个架构,或者说是一个设计模式,它就是强制性使应用程序 ... -
servlet学习笔记
2011-04-10 00:43 848首先从应用层面上谈谈,Servlet是运行在服务器端 ... -
接口VS抽象类
2011-03-25 23:52 853大致浏览了一下网上关于接口和抽象类的文章,文章稂莠不齐,水平有 ...
相关推荐
1.引言C++语言的创建初衷是“a better C”,但是这并不意味着C++...2.从标准头文件说起某企业曾经给出如下的一道面试题:为什么标准头文件都有类似以下的结构? #ifndef __INCvxWorksh#define __INCvxWorksh #ifdef __
技术运维-机房巡检表及巡检说明
第四次算法分析与设计整理
图像处理项目实战
该资源为jaxlib-0.4.18-cp311-cp311-macosx_11_0_arm64.whl,欢迎下载使用哦!
搭建说明. 运行环境 php5.6 mysql5.6 扩展sg11 前置条件: 前后端分离,需要准备两个域名,一个后台域名,一个前端域名 后端源码修改(cs2.ijiuwu.com批量替换改为你的后端域名)数据库修改(cs3.ijiuwu.com批量替换为你的前端域名)1、创建后台站点,上传后台源码并解压到根目录2、创建前端站点,上传前端源码并解压到根目录 3、创建数据库上传并导入数据库文件 4、修改数据库信息: 后台:app/database.php 前端:application/database.php 前端站点设置 伪静态thinkphp 运行目录public 关闭防跨站 访问后台域名/admin.php进入后台管理 admin 123456 系统-》系统设置-》附件设置-》Web服务器URL 改为你的前端域名 系统-》清前台缓存 改为你的前端域名 点击刷新缓存
【毕业答辩】爆款黑板风教育文艺毕业论文答辩通用模板.pptx
1、文件内容:systemd-devel-219-78.el7_9.9.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/systemd-devel-219-78.el7_9.9.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、更多资源/技术支持:公众号禅静编程坊
win32汇编环境,对 WM-MOUSEMOVE 消息的理解
车牌识别项目
UE项目开发过程中的一些快捷脚本
lab1的words.txt文件
python、yolo、pytorch
人工智能、大语言模型相关学习资料
图像处理项目实战
python、yolo、pytorch
车牌识别项目
该资源为jaxlib-0.4.18-cp312-cp312-macosx_10_14_x86_64.whl,欢迎下载使用哦!
python、yolo、pytorch
Swift-IOS TODO_List应用开发