java多线程之Synchronized
2017-04-2715:21:53
使用Synchronized的背景:
线程安全问题.因为线程的随机性,有可能会导致多线程在操作数据时发生数据错误的情况产生。
线程安全问题产生的原因:
当线程中多条代码在操作同一个共享数据时,一个线程将部分代码执行完,还没有继续其他代码时,
被另一个线程获取cpu执行权,这时,共享数据操作就有可能出现数据错误。
简单说:多条操作功能数据的代码被多个线程分开执行造成的。
安全问题涉及的内容:
共享数据。
是否被多条语句操作。
Synchronized原理以及机制:
让多条操作共享数据的代码在某一时间段,被一个线程执行完,在执行过程中,其他线程不可以参与运算。
通过一个对象锁,将多条操作共享数据的代码进行了封装并加锁。
只有持有这个锁的线程才有机会进入同步中的去执行,在执行期间,即使其他线程获取到执行权,
因为没有获取到锁,所以只能在外面等。只有同步中的线程执行完同步代码块中的代码。
出同步代码时,才会释放这个锁,那么其他程序线程才有机会去获取这个锁,并只能有一个获取到而且进入到同步中
使用方式:
synchronized(对象)//该对象可以是任意对象
{
需要被同步的代码;
}
ps:
以后写同步你会发现这样一个问题,如果出现了安全问题后:加入了同步,安全问题依然存在。
因为同步是有前提的:
同步前提:
1,必须是两个或者两个以上的线程才需要同步。
2,必须要保证多个线程使用的是同一个锁,才可以实现多个线程被同步。
如果出现加上同步安全问题依然存在,就按照两个前提来排查问题。
1 package Synchronezied; 2 3 public class TicketWin implements Runnable{ 4 5 6 private int tickets=16; 7 Object obj=new Object(); 8 public void run(){ 9 while(1>0){ 10 11 synchronized (obj) { 12 if (tickets>0) { 13 try { 14 Thread.sleep(360); 15 } catch (Exception e) { 16 17 } 18 System.out.println(Thread.currentThread().getName()+"........"+tickets--); 19 } 20 } 21 } 22 } 23 } 24
package Synchronezied; public class TicketSynDemo { public static void main(String[] args) { TicketWin t=new TicketWin(); Thread t1=new Thread(t); Thread t2=new Thread(t); Thread t3=new Thread(t); t1.start(); t2.start(); t3.start(); } }
运行结果:

浙公网安备 33010602011771号