一个方法传递基本类型参数 String都是值传递
传递对象 数组都是引用传递
参数为引用对象(重要):
public class StackTest {
public static void main(String[] args) {
StringBuilder sb1 = new StringBuilder("Jack Ma");
StringBuilder sb2 = new StringBuilder("Architect Gong");
changeStr(sb1, sb2);
System.out.println("sb1:" + sb1);
System.out.println("sb2:" + sb2);
}
// 参数sb1, sb2 为引用数据类型
private static void changeStr(StringBuilder sb1, StringBuilder sb2) {
sb1.append(" - 风~");
sb2 = sb1;
sb2.append(" 没有方向的吹来~");
}
}
运行得到结果
sb1:Jack Ma - 风~ 没有方向的吹来~
sb2:Architect Gong
SyslogUtils.ii(syslogOriginalNetwork);
public static void ii(SyslogOriginalNetwork syslogOriginalNetwork) {
syslogOriginalNetwork.setMethod("ss");
}
没报错,是因为静态方法没有直接去操作静态域!!syslogOriginalNetwork是一个新对象,最后实例中传入的是引用!!
内存分配:new()出来的对象,内存分配与堆中,方法存在于栈中 引用存在栈中!!!!!!!
静态方法static(类方法)和 非静态方法(实例方法)
如果把threadLocal声明为非静态,则在类A的每个实例中都会产生一个新对象,这是毫无意义的,只是增加了内存消耗!!
此时区分数据类型:基本类型和引用类型
基本类型:值存放在局部变量表中,无论如何修改只会修改当前栈帧的值,方法执行结束对方法外不会做任何改变;此时需要改变外层的变量,必须返回主动赋值。
引用数据类型:指针存放在局部变量表中,调用方法的时候,副本引用压栈,赋值仅改变副本的引用。但是如果直接改变副本引用的值,修改了引用地址的对象,此时方法以外的引用此地址对象当然被修改。(两个引用,同一个地址,任何修改行为2个引用同时生效)