1.为什么要分值传递和引用传递:
基本类型存在在栈中,复合类型(对象)存在堆中。操作栈的速度要快于堆,且对象的复制相比基本类型不仅浪费内存而且速度比较慢。
从这里就可以看出来:对象是按照引用传递(数据库事务封装Connection对象传递的时候最能体现这点);基本类型是按照值传递。
2.那为什么String类型传递后会表现的值传递的特性:这并不是由于值传递而导致的,而是由于String类的不可变性(只读特性)导致的。String类型按照引用传递,但是一旦改变了,就变成新的对象了,原来引用指向的对象还是不变的。String的不可变性可以通过源码看出来,value由final修饰,同样的基本类型的封装类型Integer,Double等同样是不可变的。
3.字符串直接赋值和用new出的对象赋值的区别仅仅在于存储方式不同。传递的方式都是按照引用传递(java 编程思想也是这么解释的)
4.重载(一个操作符,在应用于特定的类时,会被赋予特殊的含义)的操作符+会用StringBuilder优化,比如:String s = "a"+"ab"+"cc";其实就一个StringBuilder调用append方法,将结果赋值给s。但是这并不意味这可以滥用+号来连接字符串。从上面的例子可以看出一次拼接(;号结束,把结果赋值给一个变量)就创建一个StringBuilder对象。所以+号连接只能用在简单的连接时,如果连接发生在循环中,就意味着随着循环的进行会创建大量StringBuilder对象,来完成最后的结果,而创建对象是一个十分耗时的操作,这样就会花长时间执行拼接,降低程序效率,所以这种时候,我们就要通过在循坏前显示的创建StringBuilder对象在循环中显示调用append对象来拼接字符串,不再依赖编译器的优化
5.String s1 = "aa" , String s2 = "aa" 这个时候s1==s2是正确的,“aa”存放在常量池中,是同一个。但是String s1 = new String(“aa”),String s2 = new String(“aa”)此时s1==s2 是false的 ,是在堆中的不同对象。也就是这俩种获得字符串的方式是不一样的。