看面试题,遇到这个问题,文章中的解释是:
看了之后,还是很懵,在csdn 上找了很久,基本都是这个解释,另外有一个说子类无法调用父类的静态方法,这样做可以避免线程互相调用,让对方释放cpu 使用权或直接让对方沉睡,我觉得这是错误,因为java没有规定子类无法调用父类静态类,所以自己做了个测试,以下是测试代码:
线程一的定义:
线程二的定义:
为了方便,测试方法直接写在线程二中,单说下逻辑,线程二运行后会在控制台打印文字,这时候线程一启动,启动后,睡上一秒,开始调用线程二的sleep方法,试图让线程二阻塞,随后开始自己打印,以便观察,运行结果如下:
从结果可以看到,线程二启动后正常打印文字,线程一启动一秒后,调用线程二的sleep 方法,但是,线程二未停止,反而线程一本身停止了 10秒,从这里可以看出不是不能调用其他线程的sleep 方法,而是谁调用,谁生效。
我没有看源码,但我推测原因如下:sleep作为Thread 父类的静态方法,在jvm 加载时只加载一次,也就是说,jvm 里面只存在一个sleep 方法,开开启新线程是,根据jvm 动态加载规则,jvm 对当前线程子类是有标记的,所以,sleep 方法调用时,必然是通过jvm 识别了调用的线程,结果就是谁调用,谁有效。
所以我认为最先贴出的那张图上的话,其实可以这样理解:之所以写成静态方法,是告诉程序员,你在哪里调用,调用的都是同一个方法,并非某个线程独有的实例方法,它只对当前运行的线程有效。