前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >多线程与多进程

多线程与多进程

作者头像
全栈程序员站长
发布2022-06-29 15:14:13
3370
发布2022-06-29 15:14:13
举报
文章被收录于专栏:全栈程序员必看

多线程与进程

进程(Process)

代码语言:javascript
复制
是计算机中的程序关于某数据集合上的一次运动活动,是系统进行资源分配
和调度的基本单位,是操作系统结构的基础。

线程(Thread)

代码语言:javascript
复制
有时被称为轻量级进程(Lightweight Process,LWP),是程序执行流的最
小单位。线程是进程中的一个实体,是被系统独立调度和分配的基本单位,
一个进程可以包含多个线程,但是线程不能包含多个进程。线程自己不拥有
系统资源,在单个程序中同时运行多个线程完成不同的工作,称为多线程。

线程与进程的区别

代码语言:javascript
复制
线程和进程的区别在于,子进程和父进程有不同的代码和数据空间,
而多个线程则共享数据空间,每个线程有自己的执行堆栈和程序计算器
为其执行上下文。

单线程实战

代码语言:javascript
复制
from time import ctime,sleep

def talk():
    print("start talk :%r"%ctime())
    sleep(2)

def write():
    print("start write:%r"%ctime())
    sleep(3)

if __name__ == '__main__' :
    talk()
    write()
    print("All end !%r" %ctime())

多线程实战

代码语言:javascript
复制
# -*- coding: utf-8 -*-
from time import sleep,ctime
import threading

# 定义说和写
def talk(content,loop):
    for i in range(loop):
        print("start talk:%s %s"%(content,ctime()))
        sleep(2)

def write(content,loop):
    for i in range(loop):
        print("start write:%s %s"%(content,ctime()))
        sleep(3)
# 定义和加载说和写的线程
threads = []

t1 = threading.Thread(target=talk,args=("hello",2))
threads.append(t1)

t2 = threading.Thread(target=write,args=("人生苦短,我用python!",2))
threads.append(t2)
# 执行多线程
if __name__ == '__main__':
    for t in threads:
        t.start()
    for t in threads:
        t.join()
    print("线程全部执行完成!%s"%ctime())

多进程实战

代码语言:javascript
复制
# -*- coding: utf-8 -*-
from time import ctime,sleep
# 导入multiprocessing进程模块
import multiprocessing

# 定义两个方法 说和写
def talk(content,loop):
    for i in range(loop):
        print("Tlak: %s %s"%(content,ctime))
        sleep(2)


def write(content, loop):
    for i in range (loop):
        print ("write: %s %s" % (content, ctime))
        sleep (3)

# 定义两个进程
process = []
p1 = multiprocessing.Process(target=talk,args=("hello",2))
process.append(p1)

p2 = multiprocessing.Process(target=write,args=("人生苦短,我用python",2))
process.append(p2)

# 调用进程
if __name__ == "__main":
    for p in process:
        p.start()
    for p in process:
        p.join()
    print("调用进程结束 %s"%ctime())

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/100699.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年5月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 多线程与进程
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档