名词解释:

进程: 一个具有一定独立功能的程序关于某个数据集合的一次运行活动,是系统进行资源分配和调度运行的基本单位
1. 并行
在某个*时间点*,两件或两件以上的事件(任务)同时执行.
比如说,有三条车道,某个时刻,有三辆车同时在这三个车道上跑.
2. 并发
在某个*时间段*内,两件或两件以上的事件(任务),轮流交替使用某一资源,目的是提高效率.
比如说,有一条单行车道,允许一辆车通过,有A,B两辆车要通过单行道,那么只有当A或B先通过后,另一辆车才能启动通过该单行道.
并行并发区别:
并行是从微观上,在某一具体的时间点,有不同的程序在执行,这就要求系统又多个处理器(多核).
并发是从宏观上,在一个时间段上来看,是同时执行的;但从微观上来说,相当于串行(宏观上*并行*,微观上*串行*)
3. 同步
一个任务的完成需要依赖另一个任务,只有被依赖的任务完成后,依赖的任务才能算完成.这两个任务,要么都成功,要么都失败,状态可以保持一致.
举例:
A和B两个任务,A任务执行过程中需要调用B任务,调用B任务后,需要等待B的响应结果(B给出明确的反馈返回给A),如果A没有收到B的响应,A会一直等待,不会继续向下执行,只有B返回响应结果给A后,A任务才会继续向下执行.
4. 异步
一个任务的完成不需要等待被依赖的任务完成,只是通知被依赖的任务需要做什么,通知完之后,依赖任务会继续向下执行,自己完成了,整个任务就算完成.
举例:
A任务执行过程中可能需要调用B,C,D等其他任务,在调用B,C,D等其他任务后,A不需要等待它们的返回结果,只是简单的调用,其他任务的执行结果或情况与A无关,A只是把消息或指令传给它们,A会继续向下执行,A执行完成,任务就算完成了.
银行的转账系统,对数据库的保存操作等等,会使用同步交互操作,其余情况优先使用异步交互操作
Java中的同步和异步两种交互方式
同步交互: 指发送一个请求,需要等待返回,然后才能发送下一个请求,有个等待过程;
异步交互: 指发送一个请求,不需要等待返回,随时可以发送下一个请求,即不需要等待.
阻塞,非阻塞:
概念: 程序等待调用结果时的状态
5. 阻塞
调用结果返回之前,执行线程会被挂起,不释放cpu执行权,线程不能做其他事情,只能等待,只有等到调用结果返回了,才能接着往下执行.
6. 非阻塞
在没有获取调用结果时,不是一直等待,线程可以往下执行,如果是同步的,通过轮询的方式检查调用结果有没有返回,如果是异步的,会通知回调.
7. 守护进程
运行在后台的一种特殊进程。它独立于控制终端并且周期性地执行某种任务或等待处理某些发生的事件。它不需要用户输入就能运行而且提供某种服务,不是对整个系统就是对某个用户程序提供服务。

执行代码

1. 建立开启子进程两种方式

from multiprocessing import Process
import os
import time# 开启子进程的两种方式
# 方式1
def run(num):print('子进程%s执行,进程id:%s' % (num, os.getpid()))time.sleep(1.5)print('子进程%s结束,进程id:%s' % (num, os.getpid()))if __name__ == '__main__':print('父进程执行,进程id:%s' % os.getpid())for i in range(3):p = Process(target=run, args=(i,))p.start()print('父进程结束,进程id:%s' % os.getpid())  # 进程代码逐行读取,主进程不会等待子进程结束(主进程,子进程异步)
# 执行结果
父进程执行,进程id:4472
子进程0执行,进程id:4473
父进程结束,进程id:4472
子进程1执行,进程id:4474
子进程2执行,进程id:4475
子进程0结束,进程id:4473
子进程1结束,进程id:4474
子进程2结束,进程id:4475# 方式2,继承Process类
class MyProcess(Process):def __init__(self, name):super().__init__()self.name = namedef run(self):print('子进程%s,进程id:%s' % (self.name, os.getpid()))if __name__ == '__main__':print('父进程开始')p = MyProcess('jason')p.start()  # 自动触发调用类中的run方法
    p.join()print('父进程结束')
# 执行结果
父进程开始
子进程jason,进程id:4486
父进程结束

2. 进程的常用方法

# p.start(); p.join(); p.is_alive(); p.terminate()
def func():print('测试进程中常用方法')if __name__ == '__main__':p = Process(target=func,)p.start()  # 开启一个进程p.terminate()  # 杀掉一个进程print(p.is_alive())  # 判断进程是否还存活p.join()  # 等待进程结束,再继续向下执行;异步变同步print(p.is_alive())print('父进程结束')
# 执行结果
True
False
父进程结束

3. 进程的属性

# p.name; p.pid; p.daemon = True(将进程p变为守护进程,daemon默认为False)
def func():n = 1while n:time.sleep(1)print('测试进程的属性--%s' % n)n += 1if __name__ == '__main__':p = Process(target=func,)p.daemon = True  # 子进程变为守护进程; 守护进程会随着父进程的结束而结束; 守护进程不能创建子进程
    p.start()print(p.name)  # 获取子进程名print(p.pid)  # 获取进程IDtime.sleep(5)print('父进程结束')
# 执行结果
Process-1
4512
测试进程的属性--1
测试进程的属性--2
测试进程的属性--3
测试进程的属性--4
父进程结束

转载于:https://www.cnblogs.com/gandoufu/p/9507754.html

Python-进程相关概念相关推荐

  1. python进程socket通信_python实现多进程通信实例分析

    操作系统会为每一个创建的进程分配一个独立的地址空间,不同进程的地址空间是完全隔离的,因此如果不加其他的措施,他们完全感觉不到彼此的存在.那么进程之间怎么进行通信?他们之间的关联是怎样的?实现原理是什么 ...

  2. python进程和线程_Python进程与线程知识

    好程序员Python 培训分享进程与线程知识 , Python 开发语言现在已经是被大家非常看中的编程语言了,本篇文章给读者们分享一下 Python 进程与线程知识小结,本篇文章具有一定的参考借鉴价值 ...

  3. Python进程、线程、协程详解

    进程与线程的历史 我们都知道计算机是由硬件和软件组成的.硬件中的CPU是计算机的核心,它承担计算机的所有任务. 操作系统是运行在硬件之上的软件,是计算机的管理者,它负责资源的管理和分配.任务的调度. ...

  4. Python 进程之间共享数据(全局变量)

    Python 进程之间共享数据(全局变量) 进程之间共享数据(数值型): import multiprocessing def func(num): num.value=10.78 #子进程改变数值的 ...

  5. python的用途实例-python进程池作用展示及实例解析

    在以下的文章之中我们来了解一下什么是python中的进程池.了解一下python进程池的相关知识,以及进程池在python编程之中能起到什么样的作用. 进程池 Pool类描述了一个工作进程池,他有几种 ...

  6. 【Linux 内核】进程管理 ( 进程特殊形式 | 内核线程 | 用户线程 | C 标准库与 Linux 内核中进程相关概念 | Linux 查看进程命令及输出字段解析 )

    文章目录 一.进程特殊形式 ( 内核线程 | 用户线程 ) 二.C 标准库与 Linux 内核中进程相关概念 三.Linux 查看进程命令及输出字段解析 一.进程特殊形式 ( 内核线程 | 用户线程 ...

  7. python进程、线程的学习心得

    什么是多线程竞争? 线程不是独立的,同一个进程里的线程,线程间的数据是共享的,多线程操作时,容易造成数据的混乱,线程不安全. 如何解决? 互斥锁. 好处:能够保证某段关键代码执行时,只有一个线程操作, ...

  8. python进程池调用实例方法_Python进程池Pool应用实例分析

    本文实例讲述了Python进程池Pool应用.分享给大家供大家参考,具体如下: 当需要创建的子进程数量不多时,可以直接利用multiprocessing中的Process动态成生多个进程,但如果是上百 ...

  9. python进程共享全局变量 时延_Python 进程之间共享数据(全局变量)的方法

    进程之间共享数据(数值型): import multiprocessing def func(num): num.value=10.78 #子进程改变数值的值,主进程跟着改变 if __name__= ...

  10. python进程、线程、协程

    基本观点: 1.一个python进程一个GIL(全局锁),每个线程需要获取这个锁才能执行. 2.cpu密集型的程序,使用多进程. 3.IO密集型的程序,多线程可能会比多进程快. 4.多核cpu执行多进 ...

最新文章

  1. xmind 模板_xmind模板打包下载
  2. Hadoop 三大发行版本
  3. Jupyter Notebook 的快捷键
  4. 梳理MVC 架构 MVVM架构
  5. 类加载机制-深入理解jvm
  6. mysql分库一致性_分库分表带来的完整性和一致性问题
  7. ubuntu服务器ssh登录密码修改,Ubuntu-18.04 下修改root用户密码,安装SSH服务,允许root用户远程登录,安装vsftp服务器...
  8. 列表解析(list comprehension) 与三目运算符
  9. 机器学习基础(四十八)—— 概率
  10. 三款新旧 MacBook Pro 怎么选?
  11. 免责条款html5,蚂蚁HTML5社区
  12. WPS Linux 2019领先的背后
  13. [高通SDM450][Android9.0]CTA认证--去掉通话记录功能
  14. 免费比对工具DiffMerge
  15. 关于不锈钢管TIG+MAG
  16. 最新消息: 百度办公楼门口拉横幅抗议百度竞价广告(图)
  17. SMTP-关于邮件编码的格式
  18. 默纳克调试说明书_默纳克 - NICE3000调试说明书(修改版) -
  19. Real-Time Rendering Fourth Edition 学习笔记之 -- 第一章:介绍
  20. layui把表格重载为最新状态,复选框选中去重

热门文章

  1. Begin to use Tex Example (from others)
  2. 大话存储学习笔记(4)
  3. Android实用代码七段(二)
  4. MySql 你知道事务隔离是怎么回事吗?
  5. Mr.J--贪吃蛇demo
  6. Ajax补充之serialize
  7. [HDU4635] Strongly connected
  8. iOS 多线程的简单理解(1) 方式 :同步 异步
  9. oracle参数优化
  10. mysql索引的使用[下]