会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132359个问题
Python 全系列/第三阶段:Python 网络与并发编程/并发编程 646楼

from threading import Thread
from time import sleep


class MyThread(Thread):
    def __init__(self, name):
        Thread.__init__(self)
        self.name = name

    def run(self):
        print(f'Threading:{self.name} start')
        sleep(3)
        print(f'Threading:{self.name} end')


if __name__ == '__main__':
    for i in range(20):
        t = MyThread(f't{i+1}')
        t.setDaemon(True)     # 设置当前线程为守护线程,值默认为 False
        t.start()

    print('主线程结束了!!!')



老师,我还是不太理解这个程序中语句的执行顺序。

我在 if __name__ == '__main__'  这条语句前打断点,发现该程序语句执行顺序如下:


1、执行  for i in range(20)                #  i = 0
2、执行  t = MyThread(f't{i+1}')       #  t = t1

3、执行 def __init__(self, name)

4、执行 Thread.__init__(self)
5、执行 slef.name = name

6、执行  for i in range(20)                #  i = 1

......

7、循环结束,执行 print('主线程结束了!!!')


问题:

1、程序是从上往下执行的,所以首先应该是创建类对象,这个类对象代表的是类 MyThrad 的结构,里面包含实例方法 run 。然后进入程序入口,执行 for 循环里的语句,执行  t = MyThread(f't{i+1}') 语句时,会先调用 __new__() 方法创建一个实例对象,再用 __init__() 方法初始化这个实例对象,其中实例对象里也有实例属性和 run 方法。我这样理解是对的吗?


2、按照我打断点后语句的执行顺序,并没有发现执行 run 方法。请问老师,这个 run 方法是怎么调用的?什么时候调用的?



Python 全系列/第三阶段:Python 网络与并发编程/并发编程 647楼
Python 全系列/第三阶段:Python 网络与并发编程/并发编程 654楼
Python 全系列/第三阶段:Python 网络与并发编程/并发编程 657楼

老师,我的电脑配置是8核16线程的,我把进程池设置为17个,每个进程sleep(2),视频老师说进程池里的数量不能随便写,最多就是自己电脑的cpu数,我这明显超过电脑cpu了,但是感觉17个进程是同时完成的。

from multiprocessing import Pool, Process
from time import sleep


def func1(name):
    a=0
    print(f"进程{name}的工作")
    for i in range(1000000):
        a+=i
    print(a)
    sleep(2)


if __name__ == '__main__':
    pool = Pool(17)
    pool.apply_async(func=func1, args=("xue1",))
    pool.apply_async(func=func1, args=("xue2",))
    pool.apply_async(func=func1, args=("xue3",))
    pool.apply_async(func=func1, args=("xue4",))
    pool.apply_async(func=func1, args=("xue5",))
    pool.apply_async(func=func1, args=("xue6",))
    pool.apply_async(func=func1, args=("xue7",))
    pool.apply_async(func=func1, args=("xue8",))
    pool.apply_async(func=func1, args=("xue9",))
    pool.apply_async(func=func1, args=("xue10",))
    pool.apply_async(func=func1, args=("xue11",))
    pool.apply_async(func=func1, args=("xue12",))
    pool.apply_async(func=func1, args=("xue13",))
    pool.apply_async(func=func1, args=("xue14",))
    pool.apply_async(func=func1, args=("xue15",))
    pool.apply_async(func=func1, args=("xue16",))
    pool.apply_async(func=func1, args=("xue17",))
    pool.close()
    pool.join()


Python 全系列/第三阶段:Python 网络与并发编程/并发编程 658楼
Python 全系列/第三阶段:Python 网络与并发编程/并发编程 659楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637