package function.thread;
import java.util.concurrent.Semaphore;
public class TestSemaphore {
public static void main(String args[]){
//这里的信号量大于等待执行线程个数时,线程就会并发执行而不是同步
//因为线程release后,剩余的信号量还是大于0,其余的线程在调用acquire方法时不会被阻塞
Semaphore s = new Semaphore(1);
new IncreThread(s,"A");
new DecThread(s,"B");
}
}
class SharedData{
static int count =10;
}
class IncreThread implements Runnable{
String name;
Semaphore sem;
IncreThread(Semaphore s , String name){
this.name = name;
this.sem = s;
new Thread(this).start();
}
public void run(){
try{
System.out.println(name+" is enter and waitting for permit ........");
sem.acquire();//信号量大于0时会被放行,否则就被阻塞
System.out.println(name+" get a permit ........");
for(int i=0;i<6 ; i++){
Thread.sleep(1000);
SharedData.count++;
System.out.println(name+":"+SharedData.count);
}
}catch(Exception e){
e.printStackTrace();
}
System.out.println(name+" is releaseing a permit ........");
sem.release();
}
}
class DecThread implements Runnable{
String name;
Semaphore sem;
DecThread(Semaphore s , String name){
this.name = name;
this.sem = s;
new Thread(this).start();
}
public void run(){
try{
System.out.println(name+" is enter and waitting for permit ........");
sem.acquire();
System.out.println(name+" get a permit ........");
for(int i=0;i<6 ; i++){
Thread.sleep(1000);
SharedData.count--;
System.out.println(name+":"+SharedData.count);
}
}catch(Exception e){
e.printStackTrace();
}
System.out.println(name+" is releaseing a permit ........");
sem.release();
}
}
运行结果:
A is enter and waitting for permit ........
B is enter and waitting for permit ........
A get a permit ........
A:11
A:12
A:13
A:14
A:15
A:16
A is releaseing a permit ........
B get a permit ........
B:15
B:14
B:13
B:12
B:11
B:10
B is releaseing a permit ........
相关推荐
Delphi 多线程之 Semaphore (信号对象) Delphi 多线程中,Semaphore (信号对象) 是一种高效的同步方法,用于控制多线程之间的访问顺序。Semaphore 可以同时处理多个线程,避免了线程之间的冲突和阻塞。 Semaphore ...
Semaphore:可理解为允许线程执行信号的池子,池子中放入多少个信号就允许多少线程同时执行。 private static void MultiThreadSynergicWithSemaphore() { //0表示创建Semaphore时,拥有可用信号量数值 //1表示...
本示例中,我们将深入探讨如何使用Semaphore来控制多线程的循序执行。 Semaphore是一种计数信号量,它可以有正整数值,用于管理多个线程对公共资源的访问。当信号量的值为正时,线程可以获取一个许可(或称资源),...
多线程(C++)同步Semaphore
Linux 下多线程编程-Pthread 与 Semaphore 的使用 Linux 下的多线程编程是通过使用 POSIX 线程接口,称为 pthread 实现的。要编写 Linux 下的多线程程序,需要使用头文件 pthread.h,连接时需要使用库 libpthread.a...
Java多线程编程是开发高并发应用的关键技术之一,Semaphore工具是Java并发包(java.util.concurrent)中的一个重要组件,用于控制同时访问特定资源的线程数量。本篇将深入讲解Semaphore的基本概念、工作原理以及如何...
在Java多线程编程中,线程的并发控制是非常关键的一部分,它确保多个线程能够协同工作并有效地访问共享资源。Java 5.0引入了四个新的同步工具类,它们是Semaphore、CountDownLatch、CyclicBarrier和Exchanger,用于...
在这个实例中,我们关注的是如何利用Semaphore来管理多线程对多个端口的访问,确保不会出现冲突。Semaphore类可以看作是一个计数器,它维护着一个固定数量的许可证。当一个线程请求一个许可证并获得它时,计数器减一...
"大漠多线程模板"是一个专门针对C#开发的多线程处理框架,它为开发者提供了便捷的方式来管理和优化多线程应用。这个框架由知名开发者"大漠"创建,旨在简化复杂的并发编程,提高代码的可读性和可维护性。 多线程允许...
在编程领域,多线程是一种常见的技术,它允许程序同时执行多个任务,从而提高系统效率和响应速度。尤其是在处理大量数据、并发操作或者需要进行IO等待时,多线程显得尤为重要。C#作为.NET框架的一部分,提供了丰富的...
在实际的多线程应用中,除了`lock`,还可以使用`Monitor`、`Mutex`、`Semaphore`等其他同步机制来实现互斥和资源限制。例如,`Mutex`允许跨进程的互斥访问,而`Semaphore`则可以控制同时访问资源的线程数量。 测试...
1. **线程安全**:确保共享数据在多线程环境下正确访问,通常需要使用锁(如Monitor或Mutex)、信号量(Semaphore)或原子操作来实现。 2. **线程间通信**:线程间的同步和通信至关重要,可以使用事件(Event)、...
在.NET框架中,C#语言提供了强大的多线程支持,使得开发者可以充分利用现代多核处理器的优势,实现并行处理和高效能编程。本资源包含六个C#.NET多线程的实例,涵盖了多线程的基本使用到更高级的概念,如线程互斥。...
多线程技术是现代软件开发中的重要概念,它允许程序同时执行多个任务,从而提高效率和响应性。VB6虽然相对老旧,但其支持的多线程功能依然具有实用性,尤其是在处理耗时操作或需要并发执行任务的应用场景。 VB6中的...
在C#编程中,多线程技术常用于提高应用程序的执行效率,特别是在处理数据库操作时。SQLite是一款轻量级、嵌入式的关系型数据库,它广泛应用于桌面应用、移动设备和Web开发。当多线程环境对SQLite进行读写操作时,...
在IT领域,多线程编程是一项关键技能,尤其是在性能优化和并发处理方面。本文将深入探讨多线程编程的基础知识,以帮助初学者快速入门。 首先,我们需要理解什么是多线程。多线程是指在一个进程中同时执行多个独立的...
在IT行业中,多线程编程是一项关键技能,尤其是在开发高效能的应用程序时。"易语言多线程访问网页源码" 提供了一种利用多线程技术来并发地访问网络资源的方法,这对于需要大量网络请求的项目来说尤其有用。易语言是...
.NET框架的多线程技术是开发高性能应用程序的关键组成部分,特别是在处理并发操作、并行计算以及UI更新时。在.NET 2.0版本中,多线程功能已经得到了充分的优化和增强,允许开发者构建出更加高效的应用程序。下面将...