感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的:
① 2000多本Python电子书(主流和经典的书籍应该都有了)
② Python标准库资料(最全中文版)
③ 项目源码(四五十个有趣且经典的练手项目及源码)
④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)
⑤ Python学习路线图(告别不入流的学习)
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
3.多进程完成多任务的代码
import multiprocessing
import time
跳舞任务
def dance():
for i in range(5):
print(“跳舞中…”)
time.sleep(0.2)
唱歌任务
def sing():
for i in range(5):
print(“唱歌中…”)
time.sleep(0.2)
if name == ‘main’:
创建跳舞的子进程
group: 表示进程组,目前只能使用None
target: 表示执行的目标任务名(函数名、方法名)
name: 进程名称, 默认是Process-1, …
dance_process = multiprocessing.Process(target=dance, name=“myprocess1”)
sing_process = multiprocessing.Process(target=sing)
启动子进程执行对应的任务
dance_process.start()
sing_process.start()
4.小结
1.获取进程编号的目的
2.获取当前进程编号
import multiprocessing
import time
import os
跳舞任务
def dance():
获取当前进程的编号
print(“dance:”, os.getpid())
获取当前进程
print(“dance:”, multiprocessing.current_process())
for i in range(5):
print(“跳舞中…”)
time.sleep(0.2)
扩展:根据进程编号杀死指定进程
os.kill(os.getpid(), 9)
唱歌任务
def sing():
获取当前进程的编号
print(“sing:”, os.getpid())
获取当前进程
print(“sing:”, multiprocessing.current_process())
for i in range(5):
print(“唱歌中…”)
time.sleep(0.2)
if name == ‘main’:
获取当前进程的编号
print(“main:”, os.getpid())
获取当前进程
print(“main:”, multiprocessing.current_process())
创建跳舞的子进程
group: 表示进程组,目前只能使用None
target: 表示执行的目标任务名(函数名、方法名)
name: 进程名称, 默认是Process-1, …
dance_process = multiprocessing.Process(target=dance, name=“myprocess1”)
sing_process = multiprocessing.Process(target=sing)
启动子进程执行对应的任务
dance_process.start()
sing_process.start()
3.获取当前父进程编号
import multiprocessing
import time
import os
跳舞任务
def dance():
获取当前进程的编号
print(“dance:”, os.getpid())
获取当前进程
print(“dance:”, multiprocessing.current_process())
获取父进程的编号
print(“dance的父进程编号:”, os.getppid())
for i in range(5):
print(“跳舞中…”)
time.sleep(0.2)
扩展:根据进程编号杀死指定进程
os.kill(os.getpid(), 9)
唱歌任务
def sing():
获取当前进程的编号
print(“sing:”, os.getpid())
获取当前进程
print(“sing:”, multiprocessing.current_process())
获取父进程的编号
print(“sing的父进程编号:”, os.getppid())
for i in range(5):
print(“唱歌中…”)
time.sleep(0.2)
if name == ‘main’:
获取当前进程的编号
print(“main:”, os.getpid())
获取当前进程
print(“main:”, multiprocessing.current_process())
创建跳舞的子进程
group: 表示进程组,目前只能使用None
target: 表示执行的目标任务名(函数名、方法名)
name: 进程名称, 默认是Process-1, …
dance_process = multiprocessing.Process(target=dance, name=“myprocess1”)
sing_process = multiprocessing.Process(target=sing)
启动子进程执行对应的任务
dance_process.start()
sing_process.start()
4.小结
1.进程执行带有参数的任务的介绍
2.args参数的使用
示例代码:
import multiprocessing
import time
带有参数的任务
def task(count):
for i in range(count):
print(“任务执行中…”)
time.sleep(0.2)
else:
print(“任务执行完成”)
if name == ‘main’:
创建子进程
args: 以元组的方式给任务传入参数
sub_process = multiprocessing.Process(target=task, args=(5,))
sub_process.start()
3.kwargs参数的使用
示例代码:
import multiprocessing
import time
带有参数的任务
def task(count):
for i in range(count):
print(“任务执行中…”)
time.sleep(0.2)
else:
print(“任务执行完成”)
if name == ‘main’:
创建子进程
kwargs: 表示以字典方式传入参数
sub_process = multiprocessing.Process(target=task, kwargs={“count”: 3})
sub_process.start()
4.小结
1.进程的注意点介绍
2.进程之间不共享全局变量
import multiprocessing
import time
定义全局变量
g_list = list()
添加数据的任务
def add_data():
for i in range(5):
g_list.append(i)
print(“add:”, i)
time.sleep(0.2)
代码执行到此,说明数据添加完成
print(“add_data:”, g_list)
def read_data():
print(“read_data”, g_list)
if name == ‘main’:
创建添加数据的子进程
add_data_process = multiprocessing.Process(target=add_data)
创建读取数据的子进程
read_data_process = multiprocessing.Process(target=read_data)
启动子进程执行对应的任务
add_data_process.start()
主进程等待添加数据的子进程执行完成以后程序再继续往下执行,读取数据
add_data_process.join()
read_data_process.start()
print(“main:”, g_list)
总结: 多进程之间不共享全局变量
3.进程之间不共享全局变量的小结
4.主进程会等待所有的子进程执行结束再结束
import multiprocessing
import time
定义进程所需要执行的任务
def task():
for i in range(10):
print(“任务执行中…”)
time.sleep(0.2)
if name == ‘main’:
创建子进程
sub_process = multiprocessing.Process(target=task)
sub_process.start()
主进程延时0.5秒钟
time.sleep(0.5)
print(“over”)
exit()
总结: 主进程会等待所有的子进程执行完成以后程序再退出
保证主进程正常退出的示例代码:
import multiprocessing
import time
定义进程所需要执行的任务
def task():
for i in range(10):
print(“任务执行中…”)
time.sleep(0.2)
if name == ‘main’:
创建子进程
sub_process = multiprocessing.Process(target=task)
设置守护主进程,主进程退出子进程直接销毁,子进程的生命周期依赖与主进程
sub_process.daemon = True
sub_process.start()
time.sleep(0.5)
print(“over”)
让子进程销毁
sub_process.terminate()
exit()
总结: 主进程会等待所有的子进程执行完成以后程序再退出
如果想要主进程退出子进程销毁,可以设置守护主进程或者在主进程退出之前让子进程销毁
5.主进程会等待所有的子进程执行结束再结束的小结
1.线程的介绍
在Python中,想要实现多任务除了使用进程,还可以使用线程来完成,线程是实现多任务的另外一种方式。
2.线程的概念
3.线程的作用
4.小结
1.导入线程模块
2.线程类Thread参数说明
3.启动线程
启动线程使用start方法
4.多线程完成多任务的代码
import threading
import time
唱歌任务
def sing():
扩展: 获取当前线程
print(“sing当前执行的线程为:”, threading.current_thread())
for i in range(3):
print(“正在唱歌…%d” % i)
time.sleep(1)
跳舞任务
def dance():
扩展: 获取当前线程
print(“dance当前执行的线程为:”, threading.current_thread())
for i in range(3):
print(“正在跳舞…%d” % i)
time.sleep(1)
if name == ‘main’:
扩展: 获取当前线程
print(“当前执行的线程为:”, threading.current_thread())
创建唱歌的线程
target: 线程执行的函数名
sing_thread = threading.Thread(target=sing)
创建跳舞的线程
dance_thread = threading.Thread(target=dance)
开启线程
sing_thread.start()
dance_thread.start()
5.小结
1.线程执行带有参数的任务的介绍
2.args参数的使用
示例代码:
import threading
import time
带有参数的任务
def task(count):
for i in range(count):
print(“任务执行中…”)
time.sleep(0.2)
else:
print(“任务执行完成”)
if name == ‘main’:
创建子线程
args: 以元组的方式给任务传入参数
sub_thread = threading.Thread(target=task, args=(5,))
sub_thread.start()
3.kwargs参数的使用
示例代码:
import threading
import time
带有参数的任务
def task(count):
for i in range(count):
print(“任务执行中…”)
time.sleep(0.2)
else:
print(“任务执行完成”)
if name == ‘main’:
创建子线程
kwargs: 表示以字典方式传入参数
sub_thread = threading.Thread(target=task, kwargs={“count”: 3})
sub_thread.start()
4.小结
1.线程的注意点介绍
2.线程之间执行是无序的
import threading
import time
def task():
time.sleep(1)
print(“当前线程:”, threading.current_thread().name)
if name == ‘main’:
for _ in range(5):
sub_thread = threading.Thread(target=task)
sub_thread.start()
3.主线程会等待所有的子线程执行结束再结束
假如我们现在创建一个子线程,这个子线程执行完大概需要2.5秒钟,现在让主线程执行1秒钟就退出程序,查看一下执行结果,示例代码如下:
import threading
import time
测试主线程是否会等待子线程执行完成以后程序再退出
def show_info():
for i in range(5):
print(“test:”, i)
time.sleep(0.5)
if name == ‘main’:
sub_thread = threading.Thread(target=show_info)
sub_thread.start()
主线程延时1秒
time.sleep(1)
print(“over”)
设置守护主线程的示例代码:
import threading
import time
测试主线程是否会等待子线程执行完成以后程序再退出
def show_info():
for i in range(5):
print(“test:”, i)
time.sleep(0.5)
if name == ‘main’:
创建子线程守护主线程
daemon=True 守护主线程
守护主线程方式1
sub_thread = threading.Thread(target=show_info, daemon=True)
设置成为守护主线程,主线程退出后子线程直接销毁不再执行子线程的代码
守护主线程方式2
sub_thread.setDaemon(True)
sub_thread.start()
主线程延时1秒
time.sleep(1)
print(“over”)
4.线程之间共享全局变量
import threading
import time
定义全局变量
my_list = list()
写入数据任务
def write_data():
for i in range(5):
my_list.append(i)
time.sleep(0.1)
print(“write_data:”, my_list)
读取数据任务
def read_data():
print(“read_data:”, my_list)
if name == ‘main’:
创建写入数据的线程
write_thread = threading.Thread(target=write_data)
创建读取数据的线程
read_thread = threading.Thread(target=read_data)
write_thread.start()
延时
time.sleep(1)
主线程等待写入线程执行完成以后代码在继续往下执行
write_thread.join()
print(“开始读取数据啦”)
read_thread.start()
5.线程之间共享全局变量数据出现错误问题
import threading
定义全局变量
g_num = 0
循环一次给全局变量加1
def sum_num1():
for i in range(1000000):
global g_num
g_num += 1
print(“sum1:”, g_num)
循环一次给全局变量加1
def sum_num2():
for i in range(1000000):
global g_num
g_num += 1
print(“sum2:”, g_num)
if name == ‘main’:
创建两个线程
first_thread = threading.Thread(target=sum_num1)
second_thread = threading.Thread(target=sum_num2)
启动线程
first_thread.start()
启动线程
second_thread.start()
线程等待的示例代码:
import threading
定义全局变量
g_num = 0
循环1000000次每次给全局变量加1
def sum_num1():
最后
Python崛起并且风靡,因为优点多、应用领域广、被大牛们认可。学习 Python 门槛很低,但它的晋级路线很多,通过它你能进入机器学习、数据挖掘、大数据,CS等更加高级的领域。Python可以做网络应用,可以做科学计算,数据分析,可以做网络爬虫,可以做机器学习、自然语言处理、可以写游戏、可以做桌面应用…Python可以做的很多,你需要学好基础,再选择明确的方向。这里给大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!
👉Python所有方向的学习路线👈
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
👉Python必备开发工具👈
工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。
👉Python全套学习视频👈
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。
👉实战案例👈
学python就与学数学一样,是不能只看书不做题的,直接看步骤和答案会让人误以为自己全都掌握了,但是碰到生题的时候还是会一筹莫展。
因此在学习python的过程中一定要记得多动手写代码,教程只需要看一两遍即可。
👉大厂面试真题👈
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!