【故障诊断】使用多线程,程序不报错,但就是不运行

【故障诊断】使用多线程,程序不报错,但就是不运行

故障现象

使用多线程的时候,主函数尚且还在执行,但子函数却不执行。

if __name__=='__main__':
    print('Parent process %s.' % os.getpid())
    p = Pool(processes = 4)
    for i in range(30):
        p.apply_async(func = stitch, args=(i,))
    print('Waiting for all subprocesses done...')
    p.close()
    p.join()
    print('All subprocesses done.')

如图所示,main会执行,但stitch就不会了。

原因分析

这是因为你的参数列表,也就是args和上面stitch函数的定义不一致。

解决方案

你只要把参数列表改为一致就可以了。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
如果在多线程环境下使用 Jedis 时出现 Connection reset by peer: socket write error 的错误,可能是因为 Jedis 不是线程安全的。可以通过以下两种方式解决这个问题: 1. 使用线程安全的 JedisPool JedisPool 可以创建多个 Jedis 实例,并提供线程安全的连接池管理。可以在每个线程中获取一个 Jedis 实例来使用使用完毕后归还到连接池中,从而避免线程之间的竞争和冲突。 ```java import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; public class JedisDemo { private static JedisPool jedisPool; static { JedisPoolConfig config = new JedisPoolConfig(); config.setMaxTotal(10); config.setMaxIdle(5); config.setTestOnBorrow(true); jedisPool = new JedisPool(config, "localhost", 6379); } public static void main(String[] args) { Jedis jedis = jedisPool.getResource(); try { jedis.set("name", "JedisDemo"); String value = jedis.get("name"); System.out.println("name = " + value); } finally { if (jedis != null) { jedis.close(); } } jedisPool.close(); } } ``` 2. 在每个线程中创建新的 Jedis 实例 在每个线程中创建新的 Jedis 实例,使用完毕后立即关闭连接。这种方式会频繁地创建和关闭连接,不够高效,但是适用于并发量不高的场景。 ```java import redis.clients.jedis.Jedis; public class JedisDemo { public static void main(String[] args) { Thread thread1 = new Thread(() -> { Jedis jedis = new Jedis("localhost", 6379); try { jedis.set("name", "JedisDemo1"); String value = jedis.get("name"); System.out.println("name = " + value); } finally { if (jedis != null) { jedis.close(); } } }); thread1.start(); Thread thread2 = new Thread(() -> { Jedis jedis = new Jedis("localhost", 6379); try { jedis.set("name", "JedisDemo2"); String value = jedis.get("name"); System.out.println("name = " + value); } finally { if (jedis != null) { jedis.close(); } } }); thread2.start(); } } ``` 这个示例在两个线程中分别创建新的 Jedis 实例,设置一个键值对,获取键值对的值并打印输出,最后关闭连接。由于每个线程都使用自己的 Jedis 实例,不会出现线程之间的竞争和冲突。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

鲤鱼王的成长之路

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

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

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

打赏作者

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

抵扣说明:

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

余额充值