threadpool 1

本文介绍了一个简单的Python迭代器项目实现,包括初始化数据、设置数据大小、获取下一个元素等功能,并使用线程锁确保线程安全。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

class Project:
    def __init__(self):
        self.data = range(0,3)
        self.index = 0
        self.lock = threading.Lock()
    def __iter__(self):
        return self
    def set_data_size(self,size):
        self.data = range(0, size)
    def next(self):
        self.lock.acquire()
        dt = None
        if self.index < len(self.data):
            dt = self.data[self.index]
            self.index += 1
        else:
            self.lock.release()
            raise StopIteration
        self.lock.release()
        return dt
    @staticmethod
    def MyStaticFunc():
        print 'hello static'

proj = Project()

//线程池,以单线程的方式执行订单的创建(在mysql中扣减库存后新增一个订单) /开启线程池/ private static final ExecutorService CACHE_THREADPOOl1 = Executors.newSingleThreadExecutor();public void run() { while (true){ try { //获取消息队列中的消息,对应的命令XREADGROUP GROUP g1 ‘消费者名称’ COUNT 1 BLOCK 2000 STREAMS stream.order List<MapRecord<String, Object, Object>> r1 = stringRedisTemplate.opsForStream().read( Consumer.from(“group1”, “c1”), StreamReadOptions.empty().count(1).block(Duration.ofSeconds(2)), StreamOffset.create(“stream.order”, ReadOffset.lastConsumed()) ); //判别消息是否获取成功了 if(r1 == null || r1.isEmpty()){ //如果获取失败了,继续下次的循环 continue; } //取出第一条消息 MapRecord<String, Object, Object> objectRecord = r1.get(0); Map<Object, Object> value = objectRecord.getValue(); tb_vouther_order tbVoutherOrder = BeanUtil.fillBeanWithMap(value, new tb_vouther_order(), true); //获取消息成功了,开始下一步操作 //创建锁对象,redisson对象创建锁对象时,自动生成一个唯一值作为value,后续释放锁redisson自动通过该key"lock:order:" + tbVoutherOrder.getUid()获取value,比较锁是否被修改,才能进行释放 RLock redisLock = redissonClient.getLock("lock:order:" + tbVoutherOrder.getUid().toString()); //通过redisson的获取redis的全局锁 boolean b = redisLock.tryLock(2000, TimeUnit.MICROSECONDS); //成功获取了锁 try { //判别是否获取了锁成功(通过redis的nex命令概念建立了互斥锁的概念,因此不判别也没事,因为nex命令只能对一个key执行一次的,因此并发下,只能有一个请求获取全局锁) if(!b){ //并发下单业务,避免重复下单,直接返回失败(不等待直接退出)该步骤是异步处理的,因此不需要返回给前端 log.error("该用户:" + tbVoutherOrder.getUid() + ",已经下单了"); } //消息的确认(保证了消息的可靠性) Long g1 = stringRedisTemplate.opsForStream().acknowledge("stream.order", "g1", objectRecord.getId()); //通过开启的线程任务,异步的操控mysql数据库完成库存的扣减和下单的操作 tbvoutherorderservice.addseckillVouther2(tbVoutherOrder); }finally{ //释放锁 redisLock.unlock(); } }}你帮我分析一下异步下单的代码,线程池采用了单线程,需要考虑分布式全局互斥锁保证线程之间的安全
03-18
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值