多线程和信号量Semaphore

4 篇文章 0 订阅

    信号量Semaphore是一个并发工具类,用来控制可同时并发的线程数,其内部维护了一组虚拟许可,通过构造器指定许可的数量,每次线程执行操作时先通过acquire方法获得许可,执行完毕再通过release方法释放许可。如果无可用许可,那么acquire方法将一直阻塞,直到其它线程释放许可。

 

比如说我们现在要处理一批订单,(如下单,取消,或者对账),订单量比较多,才用多线程处理

先创建一个简单订单model示例

package test;

import java.io.Serializable;

/**
 * @Description
 * @Author penn
 * @Date 2019-08-28
 */
public class Order implements Serializable {
    private static final long serialVersionUID = 7592930394427200495L;

    private String orderId;

    private String orderName;

    public String getOrderId() {
        return orderId;
    }

    public void setOrderId(String orderId) {
        this.orderId = orderId;
    }

    public String getOrderName() {
        return orderName;
    }

    public void setOrderName(String orderName) {
        this.orderName = orderName;
    }
}

然后我们通过线程池去处理,最多10个线程,意思是同一时刻,最多10个线程在处理订单业务

package test;

import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Semaphore;
import java.util.concurrent.TimeUnit;

/**
 * @Description
 * @Author penn
 * @Date 2019-08-28
 */
public class Gtest {
    private static SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");

    public static void main(String args[]){

        try{

            ExecutorService executorService = Executors.newFixedThreadPool(10);
            final Semaphore semaphore       = new Semaphore(10);
            List<Order> persons = initData();
            for(Order p : persons){
                executorService.execute(() -> {
                    try {
                        semaphore.acquire();
                        System.out.println(p.getOrderId() + "," + p.getOrderName() + getFormatTimeStr());
                        //业务代码开始
                        //业务代码
                        //业务代码结束
                        semaphore.release();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                });
            }
            executorService.shutdown();
            executorService.awaitTermination(1, TimeUnit.MINUTES);
        }catch (Exception e){
            System.out.println(e.getMessage());
        }
    }

    private static List<Order> initData(){
        List<Order> persons = new ArrayList<>();
        for(int i =0;i<100;i++){
            Order person = new Order();
            person.setOrderId("ID_" + (1000+i));
            person.setOrderName("NAME" + (1000+i));
            persons.add(person);
        }
        return persons;
    }

    public static String getFormatTimeStr() {
        return sf.format(new Date());
    }
}

处理完成后,记得关闭线程池!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
PyQt是一个Python的GUI编程工具包,它提供了丰富的功能和组件来创建图形用户界面。在PyQt中,多线程信号量可以用来实现并发执行和线程间的通信。 多线程是指在一个程序中同时执行多个线程,每个线程都可以独立执行不同的任务。在PyQt中,可以使用QThread类来创建和管理多线程。通过继承QThread类,并重写其run()方法,可以实现自定义的线程逻辑。在多线程中,需要注意线程间的数据共享和同步问题,可以使用信号量来进行线程间的通信和同步。 信号量是一种用于控制并发访问资源的机制。在PyQt中,可以使用QSemaphore类来创建和管理信号量。通过调用QSemaphore的acquire()方法可以获取一个信号量,如果当前信号量的值大于0,则减少信号量的值并继续执行;如果当前信号量的值为0,则阻塞线程直到有可用的信号量。通过调用QSemaphore的release()方法可以释放一个信号量,增加信号量的值。 下面是一个简单的示例代码,演示了如何在PyQt中使用多线程信号量: ```python from PyQt5.QtCore import QThread, QSemaphore class WorkerThread(QThread): def __init__(self, semaphore): super().__init__() self.semaphore = semaphore def run(self): self.semaphore.acquire() # 获取信号量 # 执行线程逻辑 print("Thread started") # 释放信号量 self.semaphore.release() # 创建一个信号量,初始值为1 semaphore = QSemaphore(1) # 创建并启动线程 thread = WorkerThread(semaphore) thread.start() # 等待线程执行完毕 thread.wait() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xinqing5130

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值