刚刚看了一下java 虚拟机的工作原理,终于知道为什么提倡用包装类了。
在jvm规范中,每个类型都有自己的常量池。常量池是某类型所用常量的一个有序集合,包括直接常量(基本类型,String)和对其他类型、字段、方法的符号引用。之所以是符号引用而不是像c语言那样,编译时直接指定其他类型,是因为java是动态绑定的,只有在运行时根据某些规则才能确定具体依赖的类型实例,这正是java实现多态的基础。
demo
//jvm 对象常量池
//包装类 Byte,Short,Integer,CHaracter,Long,Boolbean.这5种整型的包装类也只是在对应值小于等于 127时才可使用对象池,也即对象不负责创建和管理大于127的这些类的对象。
Byte b='c';
Byte bb='c';
System.out.println(b==bb);//true;
Short c= 1;
Short v= 1;
System.out.println(c==v);//true;
Integer m=1;
Integer mm=1;
Integer vv=new Integer(1);//新建一个对象则在堆内存中分配内存。
System.out.println("--------");
System.out.println(vv==m);
System.out.println("--------");
System.out.println(m==mm);//true;
Integer mk=128;//Integer的常量池的范围不能超过127
Integer mmk=128;
System.out.println(mk==mmk);//true;
Boolean f=true;
Boolean ff =true;
System.out.println(f==ff);//true;
Double d=1.2;
Double dd=1.2;
System.out.println(d==dd);//false; //浮点数的包装类没有实现常量池。
String s="hello";
String ss="hello";
System.out.println(s==ss);//true;String 也实现了常量池 的技术。
String sss = new String("hello");
String vvv = new String("hello");
System.out.println(sss==vvv);//false 可见new 对象就会在堆内存中分配内存
用常量池的Stzharing 数据高于new String,String 常量池在 栈中 ,不占用运行时的堆内存所有说String常量池的效率高于new String.