鱼C论坛

 找回密码
 立即注册
查看: 1169|回复: 2

[已解决]关于python的线程问题

[复制链接]
发表于 2020-7-25 10:38:35 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 proer 于 2020-7-25 10:42 编辑


为什么主线程打印出来的不是完整的五次,是因为在打印的时候线程之间进行了切换导致的吗?感谢
import threading
def action(*add):
    for arc in add:
        print(threading.current_thread().getName() +" "+ arc)
my_tuple = ("http://c.biancheng.net/python/",\
            "http://c.biancheng.net/shell/",\
            "http://c.biancheng.net/java/")

thread = threading.Thread(target=action,args=my_tuple)
thread.start()

for i in range(5):  # 为什么主线程打印出来不是固定的5次,而是不确定的
    print(threading.current_thread().getName())

'''
Thread-1 http://c.biancheng.net/python/MainThread
MainThread
MainThread
MainThread
MainThread

Thread-1 http://c.biancheng.net/shell/
Thread-1 http://c.biancheng.net/java/
'''
最佳答案
2020-7-25 12:23:52


'''
Thread-1 http://c.biancheng.net/python/MainThread
MainThread
MainThread
MainThread
MainThread


Thread-1 http://c.biancheng.net/shell/
Thread-1 http://c.biancheng.net/java/
'''


多线程有的时候两个线程正好同时运行到 print ,导致打印在同一行,实际上有打印 5 次

每次线程进度不一致,导致打印结果每次都不一样,但是打印出的次数一定会对应的上



想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-7-25 12:23:52 | 显示全部楼层    本楼为最佳答案   


'''
Thread-1 http://c.biancheng.net/python/MainThread
MainThread
MainThread
MainThread
MainThread


Thread-1 http://c.biancheng.net/shell/
Thread-1 http://c.biancheng.net/java/
'''


多线程有的时候两个线程正好同时运行到 print ,导致打印在同一行,实际上有打印 5 次

每次线程进度不一致,导致打印结果每次都不一样,但是打印出的次数一定会对应的上



想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-7-25 15:15:07 | 显示全部楼层
Twilight6 发表于 2020-7-25 12:23
多线程有的时候两个线程正好同时运行到 print ,导致打印在同一行,实际上有打印 5 次

每次线程 ...

谢谢,刚发现第一行有一个
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-19 20:26

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表