------- android培训、java培训、期待与您交流! ---------
多线程(二)
多线程的安全问题:当多个线程操作同一个共享数据时,一个线程对共享数据的多条代码只执行了一部分,还没执行完,而其他线程参与进来,导致共享数据错误。
多线程同步:对多条操作共享数据的语句,只能让一个线程都执行完,并且在执行过程中其他线程不能参与执行。
同步的方式两种:同步代码块,同步函数
Synchronized(对象)
{
需要被同步的代码块,主要是操作共享数据的代码
}
同步函数: public synchronized void add(int n)//加在函数前面修饰函数
同步的前提:1.必须要有两个或两个以上的线程
2.必须是多线程使用同一个锁
被Synchronized修饰后,被共享数据的代码被某一线程执行完后,才能被其他线程执行,相当于一个现实中的锁,锁上后其他线程就无法进入,要想进入必须等待锁释放,也就是上锁的代码被执行完。
死锁:两个线程中存在嵌套同步,且同步的锁一样代码如下
分析死锁的原因:当t1、t2两个线程同时运行时,t1执行到代码到lockb时,t2抢夺了CPU的执行权,t1执行过程暂停,而t2在执行到locka时又被t1抢夺了执行权,但当t1执行到lockb时因为锁在t2手里没有释放,t1无法继续执行,同理t2,这样造成了程序死锁。
t1:
while(true)
{
synchronized(MyLock.locka)
{
System.out.println(Thread.currentThread().getName()+"...if locka ");
synchronized(MyLock.lockb)
{
System.out.println(Thread.currentThread().getName()+"..if lockb");
}
}
}
t2:
while(true)
{
synchronized(MyLock.lockb)
{
System.out.println(Thread.currentThread().getName()+"..else lockb");
synchronized(MyLock.locka)
{
System.out.println(Thread.currentThread().getName()+".....else locka");
}
}
}