记录原因:在开发中查看了一些优秀的图片下载框架,经常用到Synchronized同步,由于自己对同步有点模糊了,特此记录,方便下次查阅!
synchronized分为同步方法和同步代码块。
synchronized锁定的内容可以是具体的对象也可以是当前类的所有对象
synchronized可以有static变量锁和非static变量锁
1.同步方法
/**
* 对象锁<同步方法> 锁定的对象是具体的类对象 多个线程可以访问不同该对象的方法 但是对于同一个对象一次只能访问一次
*/
public synchronized void m1() throws InterruptedException {
Thread.sleep(2000);
System.out.println("---person.m1---");
}
当我们开启两个线程测试的时候,分别new出了Person p1,p2。当Thread1访问p1.m1()时,Thread2无法访问p1.m1(),但是Thread2可以访问p2.m1()。用法跟
synchronized(this)是一样的效果。
2.用非static来当锁的时候
/**
* 变量锁<同步块> 这种锁跟上方的对象锁是一个性质 不同线程可以访问不同变量 但是同一个对象一次只能访问一次
*/
Object a = new Object();// 变量锁
public void m2() {
synchronized (a) {
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("---线程访问了变量锁---");
}
}
当我们开启两个线程测试的时候,分别new出了Person p1,p2。当Thread1访问p1.m2()时,Thread2无法访问p1.m1(),但是Thread2可以访问p2.m2()。
3.用static变量 或者 xxx.class 作为锁的时候
<span style="white-space:pre"> </span>static Object b = new Object();// 静态变量锁
public void m3() {
synchronized (b) {
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("---线程访问了静态变量锁---");
}
}
这些情况下不乱你开了多少个线程同时访问多少类对象的对象m3只能一次一次的被调用,起到了全局锁的效果。
同步对代码整体的性能是有害无利的,当然我们有时候不得不这么做,当我们用到synchronized的时候切记用对方法才能起到对应的效果。<over!!>