直接上code
package cn.itcast.heima2;
public class TraditionalThreadSynchronized {
public static void main(String[] args) {
new TraditionalThreadSynchronized().init();
}
private void init(){
final Outputer outputer = new Outputer();
//线程1
new Thread(new Runnable(){
@Override
public void run() {
while(true){
try {
Thread.sleep(10);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
outputer.output("zhangxiaoxiang");
}
}
}).start();
//线程2
new Thread(new Runnable(){
@Override
public void run() {
while(true){
try {
Thread.sleep(10);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
outputer.output3("lihuoming");
}
}
}).start();
}
//内部类
static class Outputer{
public void output(String name){
int len = name.length();
synchronized (Outputer.class)
{
for(int i=0;i<len;i++){
System.out.print(name.charAt(i));
}
System.out.println();
}
}
//public synchronized void output2(String name){
// int len = name.length();
// for(int i=0;i<len;i++){
// System.out.print(name.charAt(i));
// }
// System.out.println();
//}
public static synchronized void output3(String name){
int len = name.length();
for(int i=0;i<len;i++){
System.out.print(name.charAt(i));
}
System.out.println();
}
}
}
sysnchronized方法适用了类Java的内置锁,即锁住的方法所属对象本身。但这里有一个static修饰的方法,这里上面的红色字体修改为“this”的话,会发生以下情况:
还没完全打印完成就被切了,,,未达到互斥的效果。
原因是:output方法所属实例对象,然而static修饰的output3方法所属于字节码对象。两个方法不是所属同一个对象所以发生上述情况。
有兴趣可以看下这篇文章:点击打开链接