一个线程加一运算,一个线程做减一运算,多个线程同时交替运行--synchronized
使用synchronized
package com.pb.thread.demo5; /**使用synchronized
* 一个线程加一运算,一个线程做减法运算,多个线程同时交替运行
*
* @author Denny
*
*/
public class Count {
private int num = 0;
private boolean flag = false; // 标识
//加法
public synchronized void add() {
while (flag) {
try {
wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
this.num++; //加
System.out.println(Thread.currentThread().getName() + "........" + this.num);
this.flag=true; //设置标识为true
notifyAll(); //唤醒所有在线程池中冻结的线程,会把所有都唤醒 }
//减法
public synchronized void sub() {
while (!flag) {
try {
wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
this.num--; //减
System.out.println(Thread.currentThread().getName() + "........" + this.num);
this.flag=false; //设置标识为true
notifyAll(); //唤醒所有在线程池中冻结的线程,会把所有都唤醒
}
}
package com.pb.thread.demo5;
public class Add implements Runnable {
private Count count;
public Add(Count count){
this.count=count;
}
@Override
public void run() {
while(true){
count.add();
}
}
}
//================
package com.pb.thread.demo5;
public class Sub implements Runnable {
private Count count;
public Sub(Count count){
this.count=count;
}
@Override
public void run() {
while(true){
count.sub();
}
}
}
测试类
package com.pb.thread.demo5;
public class CountTest {
public static void main(String[] args) {
Count c=new Count();
Add add=new Add(c);
Sub sub=new Sub(c);
Thread t1=new Thread(add);
Thread t2=new Thread(add);
Thread t3=new Thread(sub);
Thread t4=new Thread(sub);
t1.start();
t2.start();
t3.start();
t4.start();
}
}
结果:
Thread-2........0
Thread-1........1
Thread-3........0
Thread-0........1
Thread-2........0
Thread-1........1
Thread-3........0
Thread-0........1
Thread-2........0
不使用synchronized
package com.pb.thread.demo4; import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
/**
* 一个线程加一运算,一个线程做减法运算,多个线程同时交替运行
* @author Denny
*
*/
public class Count {
private int num = 0;
private boolean flag=false; // 标识
Lock lock = new ReentrantLock(); // 锁
Condition add = lock.newCondition(); // 加法锁
Condition sub = lock.newCondition();// 减法锁 public void add() {
lock.lock();// 锁上
try {
while (flag) { //循环判断 add.await();
}
this.num++;
System.out.println(Thread.currentThread().getName() + "........" + this.num);
this.flag = true; // 设置标识
sub.signal(); // 唤醒指定线程
} catch (InterruptedException e) {
e.printStackTrace();
}finally{
lock.unlock();
} } public void sub() {
lock.lock();// 锁上
try {
while (!flag) {//循环判断 sub.await();
}
this.num--;
System.out.println(Thread.currentThread().getName() + "........" + this.num);
this.flag = false; // 设置标识
add.signal(); // 唤醒指定线程
} catch (InterruptedException e) {
e.printStackTrace();
}finally{
lock.unlock();
} } }
package com.pb.thread.demo4;
public class Add implements Runnable {
private Count count;
public Add(Count count){
this.count=count;
}
@Override
public void run() {
while(true){
count.add();
}
}
}
package com.pb.thread.demo4;
public class Sub implements Runnable {
private Count count;
public Sub(Count count){
this.count=count;
}
@Override
public void run() {
while(true){
count.sub();
}
}
}
package com.pb.thread.demo4;
public class CountTest {
public static void main(String[] args) {
Count c=new Count();
Add add=new Add(c);
Sub sub=new Sub(c);
Thread t1=new Thread(add);
Thread t2=new Thread(add);
Thread t3=new Thread(sub);
Thread t4=new Thread(sub);
t1.start();
t2.start();
t3.start();
t4.start();
}
}
结果:
Thread-1........1
Thread-3........0
Thread-0........1
Thread-2........0
Thread-1........1
Thread-3........0
Thread-0........1
Thread-2........0
一个线程加一运算,一个线程做减一运算,多个线程同时交替运行--synchronized的更多相关文章
- 用JAVA写一个多线程程序,写四个线程,其中二个对一个变量加1,另外二个对一个变量减1
package com.ljn.base; /** * @author lijinnan * @date:2013-9-12 上午9:55:32 */ public class IncDecThrea ...
- java线程间通信:一个小Demo完全搞懂
版权声明:本文出自汪磊的博客,转载请务必注明出处. Java线程系列文章只是自己知识的总结梳理,都是最基础的玩意,已经掌握熟练的可以绕过. 一.从一个小Demo说起 上篇我们聊到了Java多线程的同步 ...
- Android Handler机制 (一个Thead中可以建立多个Hander,通过msg.target保证MessageQueue中的每个msg交由发送message的handler进行处理 ,但是 每个线程中最多只有一个Looper,肯定也就一个MessageQuque)
转载自http://blog.csdn.net/stonecao/article/details/6417364 在android中提供了一种异步回调机制Handler,使用它,我们可以在完成一个很长 ...
- 重新想象 Windows 8 Store Apps (42) - 多线程之线程池: 延迟执行, 周期执行, 在线程池中找一个线程去执行指定的方法
[源码下载] 重新想象 Windows 8 Store Apps (42) - 多线程之线程池: 延迟执行, 周期执行, 在线程池中找一个线程去执行指定的方法 作者:webabcd 介绍重新想象 Wi ...
- threadlocal精髓是为每一个线程保证一个共享对象,保证一个,保证是同一个
threadlocal精髓是为每一个线程保证一个共享对象,保证一个,保证同一个线程中是同一个共享对象. 如果是静态变量是共享的话,那必须同步,否则尽管有副本,还是会出错,故C错
- Java线程学习笔记(一个)
一个.正在创建的线程: 老掉牙的话题了.继承 java.lang.Thread父类或者实现Runnalbe接口.这里就提一句: class Thread implements Runnable Thr ...
- 当一个线程进入一个对象的一个synchronized方法后,其它线程是否可进入此对象的其它方法(转)
对象的synchronized方法不能进入了,但它的其他非synchronized方法还是可以访问的 对每一个class只有一个thread可以执行synchronized static method ...
- 线程池如何复用一个线程-- ThreadPoolExecutor的实现(未完)
任务是一组逻辑工作单元,而线程则是使任务异步执行的机制.在Java中,Runnable对象代表一个任务,Thread对象负责创建一个线程执行这个任务. 前提:1. 程序需要处理大量任务 2. 任务的执 ...
- java main()线程是不是最后一个退出的(相比较main中创建的其他多个线程)
JVM会在所有的非守护线程(用户线程)执行完毕后退出: main线程是用户线程: 仅有main线程一个用户线程执行完毕,不能决定JVM是否退出,也即是说main线程并不一定是最后一个退出的线程. pu ...
随机推荐
- 在win2008中安装vs2005
原文引用:http://www.cnblogs.com/ljzforever/archive/2009/04/13/1434799.html win2008下安装Visual Studio 2005, ...
- iOS 7.1 安装 企业应用 提示 无法下载应用程序
首先这种情况排除https影响,这个就不提了.请自行查询iOS https 部署. 其次系统版本是iOS 7.1,之后的版本安装都没问题. 说下我是怎么发现问题的,我找了个真机,发现直接调试提示bun ...
- 爬虫技术 -- 进阶学习(七)简单爬虫抓取示例(附c#代码)
这是我的第一个爬虫代码...算是一份测试版的代码.大牛大神别喷... 通过给定一个初始的地址startPiont然后对网页进行捕捉,然后通过正则表达式对网址进行匹配. List<string&g ...
- ionic 添加地图定位功能
由于项目需求,需要一个定位功能,通过google或百度,搜到一个cordova-plugin-geolocation的插件,在ios上可以用,但是在android就呵呵了,原因就不说了,大家都知道.所 ...
- get新技能: 如何设置元素高度与宽度成特定比例。宽度改变,高度自动按比例改变。 例如设置宽高比16:9。
设置宽高比在很多时候是有用的. 下面的栗子,我们设置一个容器的宽高比为16:9 //HTML代码片段 <div class="container"> <div c ...
- Python开源框架Scrapy安装及使用
一.安装问题 环境: CentOS + Python 2.7 + Pip 1) 安装时遇到 ”UnicodeDecodeError: 'ascii' codec can't decode byte ...
- 快速清除文件夹svn版本控制信息
将下面内容另存为clear.bat文件,在有版本控制的目录执行即可 @echo On @Rem 清除SVN版本控制信息 @for /r . %%a in (.) do @if exist " ...
- thread_Semaphore信号量
Semaphore也是一个线程同步的辅助类,可以维护当前访问自身的线程个数,并提供了同步机制. 使用Semaphore可以控制同时访问资源的线程个数,例如,实现一个文件允许的并发访问数. 一个计数信 ...
- Enterprise Library - Data Access Application Block 6.0.1304
Enterprise Library - Data Access Application Block 6.0.1304 企业库,数据访问应用程序块 6.0.1304 企业库的数据访问应用程序块的任务简 ...
- Linq专题之Lambda表达式
这一节我们讲的Lambda表达式跟匿名函数有关.Lambda表达式就是一个匿名函数,它可以包含表达式和语句,并且可以创建委托和表达式树. Lambda表达式的组成: 输入参数.Lambda运算符(=& ...