多线程与多进程

多线程与多进程

多线程与进程

进程(Process)

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

线程(Thread)

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

线程与进程的区别

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

单线程实战

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())

多线程实战

# -*- 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())

多进程实战

# -*- 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.net/100699.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 深入理解linux内存管理_linux内存是如何划分的

    深入理解linux内存管理_linux内存是如何划分的摘要:本章首先以应用程序开发者的角度审视Linux的进程内存管理,在此基础上逐步深入到内核中讨论系统物理内存管理和内核内存的使用方法。力求从外到内、水到渠成地引导网友分析Linux的内存管理与使用。在本章最后,我们给出一个内存映射的实例,帮助网友们理解内核内存管理与用户内存管理之间的关系,希望大家最终能驾驭Linux内存管理。前言内存管理一向是所有操作系统书籍不惜笔墨重点讨论的内容,无论市

    2025年6月16日
    3
  • source insight3.5注册码_source insight3.5注册码

    source insight3.5注册码_source insight3.5注册码安装程序下载在官网上下载SourceInsight4.0的安装程序.30天的试用安装首次启动选择授权方式,这里选择第二个选项,30天试用。image.png点击下一步,输入名称、公司或组织名称、邮箱信息,申请30天的试用。输入完成后,点击下一步,直到安装完成。修改sourceinsight4.exe用16进制编辑器(sublimetext)打开sour…

    2022年10月4日
    3
  • 系统首选dns服务器修改,Windows系统首选DNS如何设置

    系统首选dns服务器修改,Windows系统首选DNS如何设置Windows系统首选DNS如何设置的呢,有时候可能需要修改或者调整DNS服务器地址的设置,以达到优化网络连接速度的效果。该怎么办?下面是学习啦小编收集整理的Windows系统首选DNS如何设置,希望对大家有帮助~~Windows系统首选DNS的设置方法一:在图形界面下设置DNS服务器址1这里Windows8为例,首先在屏幕的右下角找到“网络连接”图标,如图所示2在“网络连接”…

    2022年5月4日
    97
  • 计算机常用编码方式有哪些_计算机网络无分类编码

    计算机常用编码方式有哪些_计算机网络无分类编码计算机常用编码方式

    2025年7月2日
    2
  • Loading class `com.mysql.jdbc.Driver’. This is deprecated警告处理,jdbc更新处

    Loading class `com.mysql.jdbc.Driver’. This is deprecated警告处理,jdbc更新处声明:使用JDK9、MYSQL8、idea  1.报错信息是这样的;处理:提示信息表明数据库驱动com.mysql.jdbc.Driver’已经被弃用了、应当使用新的驱动com.mysql.cj.jdbc.Driver’所以,按照提示更改jdbc.properties配置 .com.mysql.jdbc.Driver 改为 com.mysql.cj.jdbc.Driver…

    2022年6月23日
    41
  • 【教程】Spring+Mybatis环境配置多数据源

    一、简要概述在做项目的时候遇到需要从两个数据源获取数据,项目使用的Spring + Mybatis环境,看到网上有一些关于多数据源的配置,自己也整理学习一下,然后自动切换实现从不同的数据源获取数据功能。二、代码详解2.1 DataSourceConstants 数据源常量类/** * 数据源名称常量类 * 对应 application.xml 中 bean multipleDataSo…

    2022年2月27日
    32

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号