线程安全问题.因为线程的随机性,有可能会导致多线程在操作数据时发生数据错误的情况产生。
线程安全问题产生的原因:
当线程中多条代码在操作同一个共享数据时,一个线程将部分代码执行完,还没有继续其他代码时,
被另一个线程获取cpu执行权,这时,共享数据操作就有可能出现数据错误。
简单说:多条操作功能数据的代码被多个线程分开执行造成的。
安全问题涉及的内容:
1,共享数据。
2,是否被多条语句操作。 这也是判断多线程程序是否存在安全隐患的依据。
同步格式:
同步代码块:
synchronized(对象)//该对象可以是任意对象
{
需要被同步的代码;
}
同步的原理,通过一个对象锁,将多条操作共享数据的代码进行了封装并加锁。
只有持有这个锁的线程才有机会进入同步中的去执行,在执行期间,即使其他线程获取到执行权,
因为没有获取到锁,所以只能在外面等。只有同步中的线程执行完同步代码块中的代码。
出同步代码时,才会释放这个锁,那么其他程序线程才有机会去获取这个锁,并只能有一个获取到而且进入到同步中。
举例:火车上的卫生间。锁机制最好的体现。
同步好处:
同步的出现解决了多线程的安全问题。
同步弊端:
因为多个线程每次都要判断这个锁,所以效率会降低。
以后写同步你会发现这样一个问题,如果出现了安全问题后:加入了同步,安全问题依然存在。
因为同步是有前提的:
同步前提:
1,必须是两个或者两个以上的线程才需要同步。
2,必须要保证多个线程使用的是同一个锁,才可以实现多个线程被同步。
如果出现加上同步安全问题依然存在,就按照两个前提来排查问题。
*/
class TicketWin implements Runnable
{
private int tickets = 100;
Object obj = new Object();
public void run()
{
while(true)
{
synchronized(obj)
{
if(tickets>0)
{
try{Thread.sleep(10);}catch(InterruptedException e){}
System.out.println(Thread.currentThread().getName()+"........"+tickets--);
}
}
}
}
}
class TicketDemo_syn
{
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);
Thread t4 = new Thread(t);
t1.start();
t2.start();
t3.start();
t4.start();
}
}
线程安全问题产生的原因:
当线程中多条代码在操作同一个共享数据时,一个线程将部分代码执行完,还没有继续其他代码时,
被另一个线程获取cpu执行权,这时,共享数据操作就有可能出现数据错误。
简单说:多条操作功能数据的代码被多个线程分开执行造成的。
安全问题涉及的内容:
1,共享数据。
2,是否被多条语句操作。 这也是判断多线程程序是否存在安全隐患的依据。
解决安全问题的方式:
java中提供了一个同步机制。
解决原理;让多条操作共享数据的代码在某一时间段,被一个线程执行完,在执行过程中,其他线程不可以参与运算。同步格式:
同步代码块:
synchronized(对象)//该对象可以是任意对象
{
需要被同步的代码;
}
同步的原理,通过一个对象锁,将多条操作共享数据的代码进行了封装并加锁。
只有持有这个锁的线程才有机会进入同步中的去执行,在执行期间,即使其他线程获取到执行权,
因为没有获取到锁,所以只能在外面等。只有同步中的线程执行完同步代码块中的代码。
出同步代码时,才会释放这个锁,那么其他程序线程才有机会去获取这个锁,并只能有一个获取到而且进入到同步中。
举例:火车上的卫生间。锁机制最好的体现。
同步好处:
同步的出现解决了多线程的安全问题。
同步弊端:
因为多个线程每次都要判断这个锁,所以效率会降低。
以后写同步你会发现这样一个问题,如果出现了安全问题后:加入了同步,安全问题依然存在。
因为同步是有前提的:
同步前提:
1,必须是两个或者两个以上的线程才需要同步。
2,必须要保证多个线程使用的是同一个锁,才可以实现多个线程被同步。
如果出现加上同步安全问题依然存在,就按照两个前提来排查问题。
*/
class TicketWin implements Runnable
{
private int tickets = 100;
Object obj = new Object();
public void run()
{
while(true)
{
synchronized(obj)
{
if(tickets>0)
{
try{Thread.sleep(10);}catch(InterruptedException e){}
System.out.println(Thread.currentThread().getName()+"........"+tickets--);
}
}
}
}
}
class TicketDemo_syn
{
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);
Thread t4 = new Thread(t);
t1.start();
t2.start();
t3.start();
t4.start();
}
}