并发编程:线程安全
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了并发编程:线程安全相关的知识,希望对你有一定的参考价值。
概念
当多个线程访问某一个类(对象或方法)时,这个类始终都能表现出正确的行为,那么这个类(对象或方法)就是线程安全的。
synchronized
可以在任意对象及方法上加锁,而加锁的这段代码称为“互斥区”或“临界区”。
代码
public class Demo1 extends Thread { private int count = 5; public void run () { count--; System.out.println(this.currentThread().getName() + ", count = " + count); } public static void main(String[] args) { Demo1 demo1 = new Demo1(); Thread t1 = new Thread(demo1, "t1"); Thread t2 = new Thread(demo1, "t2"); Thread t3 = new Thread(demo1, "t3"); Thread t4 = new Thread(demo1, "t4"); Thread t5 = new Thread(demo1, "t5"); t1.start(); t2.start(); t3.start(); t4.start(); t5.start(); } }
效果:图1
给run方法加锁public synchronized void run () {...},效果:图2
分析图2
当多个线程访问Demo1的run方法时,以排队的方式进行处理(这里排队是按照CPU分配的先后顺序而定的),一个线程想要执行synchronized修饰的方法里的代码:首先尝试获得锁
如果拿到锁:
执行synchronized修饰的方法里的代码
如果拿不到锁:
这个线程就会不断的尝试获得这把锁,直到拿到为止。
注意:如果是多个线程同时去竞争这把锁,就会有锁竞争的问题
本文出自 “我爱大金子” 博客,请务必保留此出处http://1754966750.blog.51cto.com/7455444/1902772
以上是关于并发编程:线程安全的主要内容,如果未能解决你的问题,请参考以下文章
JUC并发编程 共享模式之工具 JUC CountdownLatch(倒计时锁) -- CountdownLatch应用(等待多个线程准备完毕( 可以覆盖上次的打印内)等待多个远程调用结束)(代码片段