玩转Python:深入理解进程与线程的区别与应用
最编程
2024-02-21 19:21:33
...
进程与多线程
1. 进程
1.1 什么是进程
- 进程是操作系统分配内存资源的最小单位
- 一个进程之内会默认有一个线程
- 进程是Python程序中执行多任务的一种方式
1.2 多进程的使用
- 进程创建的三步:
- 导入包
import multiprocessing
- 创建进程
- 启动进程
start
- 导入包
import multiprocessing
import time
def dance():
for item in range(1, 5):
print("跳舞...")
time.sleep(0.2)
pass
pass
def sing():
for item in range(1, 5):
print("唱歌...")
time.sleep(0.2)
pass
pass
if __name__ == "__main__":
# group 进程组,默认是None,一般不会使用
# target 所需要执行的任务
# name 进程名,默认是process-1,2,.....
# args 参数(元组类型)
dance_process = multiprocessing.Process(target=dance)
dance_process.start()
sing()
import multiprocessing
import time
def dance():
for item in range(1, 5):
print("跳舞...")
time.sleep(0.2)
pass
pass
def sing():
for item in range(1, 5):
print("唱歌...")
time.sleep(0.2)
pass
pass
if __name__ == "__main__":
dance_process = multiprocessing.Process(target=dance)
sing_process = multiprocessing.Process(target=sing)
dance_process.start()
sing_process.start()
1.3 获取进程的编号
- 获取主进程和子进程编号
os.getpid()
- 在子进程内获取他的父进程编号
os.getppid()
- 通过进程编号停止进程
os.kill(process_id, 9)
import multiprocessing
import time
import os
def dance():
dance_process_id = os.getpid()
print("dance进程编号: ", dance_process_id, multiprocessing.current_process)
dance_process_parent_id = os.getppid
推荐阅读
-
Java 类加载器的作用 - 简介:类加载器是 Java™ 中一个非常重要的概念。类加载器负责将 Java 类的字节码加载到 Java 虚拟机中。本文首先详细介绍了 Java 类加载器的基本概念,包括代理模型、加载类的具体过程和线程上下文类加载器等。然后介绍了如何开发自己的类加载器,最后介绍了类加载器在 Web 容器和 OSGi™ 中的应用。 类加载器是 Java 语言的一项创新,也是 Java 语言广受欢迎的重要原因之一。它允许将 Java 类动态加载到 Java 虚拟机中并执行。类加载器从 JDK 1.0 开始出现,最初是为了满足 Java Applets 的需求而开发的,Java Applets 需要从远程位置下载 Java 类文件并在浏览器中执行。现在,类加载器已广泛应用于网络容器和 OSGi。一般来说,Java 应用程序的开发人员不需要直接与类加载器交互;Java 虚拟机的默认行为足以应对大多数情况。但是,如果遇到需要与类加载器交互的情况,而您又不太了解类加载器的机制,就很容易花费大量时间调试异常,如 ClassNotFoundException 和 NoClassDefFoundError。本文将详细介绍 Java 的类加载器,帮助读者深入理解 Java 语言中的这一重要概念。下面先介绍一些基本概念。 类加载器的基本概念 顾名思义,类加载器用于将 Java 类加载到 Java 虚拟机中。一般来说,Java 虚拟机以如下方式使用 Java 类:Java 源程序(.java 文件)经 Java 编译器编译后转换为 Java 字节代码(.class 文件)。类加载器负责读取 Java 字节代码并将其转换为 java.lang 实例。每个实例都用来表示一个 Java 类。通过该实例的 newInstance 方法创建该类的对象。实际情况可能更加复杂,例如,Java 字节代码可能是由工具动态生成或通过网络下载的。 基本上,所有类加载器都是 java.lang.ClassLoader 类的实例。下面将详细介绍这个 Java 类。 java.lang.ClassLoader 类简介 java.lang.ClassLoader 类的基本职责是根据给定类的名称为其查找或生成相应的字节码,然后根据这些字节码定义一个 Java 类,即 java.lang.Class 类的实例。除此之外,ClassLoader 还负责加载 Java 应用程序所需的资源,如图像文件和配置文件。不过,本文只讨论它加载类的功能。为了履行加载类的职责,ClassLoader 提供了许多方法,其中比较重要的方法如表 1 所示。下文将详细介绍这些方法。 表 1.与加载类相关的 ClassLoader 方法
-
玩转Kotlin性能测试:JMH入门指南一 - 测试基础" "深入理解JMH在Kotlin中的应用:基准测试实战解析" "轻松实践Kotlin基准测试:JMH工具详解与实例总结
-
Python里的多任务入门:如何在Python中应用多进程与多线程
-
详解Windows核心机制与实战笔记(第四部分): Windows下的进程与线程概念——深入理解进程
-
深入理解Java基础:探索进程与线程-2 - 详解线程的五种工作状态与切换机制
-
理解Android中的应用进程与后台线程操作
-
Python:深入浅出理解进程与线程实例剖析
-
理解进程与线程:深入比较两者的工作原理
-
理解进程、线程与应用程序间的互动关联
-
玩转Python:深入理解进程与线程的区别与应用