最近看FutureTask代码,里面有一个方法时遍历等待FutureTask任务执行完毕的链表,链表节点中保持等待任务完成的被阻塞的线程。这个遍历一下又让我懵了一下,再次记录一下java值传递、函数传参的问题。
我理解 WaitNode p = waiters 相当于把 p 指向waiters引用的对象,不管 p=null 还是 waiters=null ,都只是把这个引用指向null,jvm进行垃圾回收时判断是否有引用指向这个对象,没有就回收这个对象占用的内存空间。p=null 语句的执行不会对 waiters有任何影响,waiters=null 语句的执行当然也不会对 p 有任何影响。
说到这里再记录一下java函数传参数的问题,java函数传参究竟是传值还是传引用呢。我理解可以记为java函数传参只是传值,不管参数是基本类型还是对象(当然这里指的是对象的其中一个引用)。基本类型就毫无争议了,传对象也是传一个引用的值,如果在函数中用这个引用操作对象当然会改变对象本身,但是在函数中对这个引用赋值一个新的对象引用,即为它new一个新的对象赋值给它,这个引用就指向另一个对象了。那么此时会改变参数中引用指向的对象吗?答案是不会的,因为函数会把这个引用值存于栈空间,只是拷贝了一个临时的引用,你使用 new object() 赋值给的只是这个临时引用。
这个很像C++中函数参数传递传“指针”还是“引用”的区别,上述传参类似C++中传入的指针变量,不过注意C++中的引用可不是上面说的“java引用”。