python17进程
import os
import time
from multiprocessing.dummy import Process def so_sth(name):
print("进程名称{},{}".format(name, os.getpid()))
time.sleep(5)
print("进程ok") #面向对象实现
class MyProcess(Process): def __init__(self,name,*args,**kwargs):
self.myname = name#不能用self.name,因为这个父类里面已经有了
#这个变量,下面调用父类的会出错
super().__init__(*args,**kwargs) def run(self):
print("进程名称{},{}".format(self.myname, os.getpid()))
time.sleep(5)
print("进程ok") if __name__ == "__main__":
#p = Process(target=so_sth,args=("quan",))
p = MyProcess("myprocessclass")
p.start()
p.join()
输出结果:
D:\anaconda\python.exe D:/PycharmProjects/untitled0406/test1.py
进程名称myprocessclass,12436
进程ok
import time
import random
from multiprocessing.dummy import Process
from queue import Queue class WriteProcess(Process):
"""写的进程"""
def __init__(self,q,*args,**kwargs):
self.q = q
super().__init__(*args,**kwargs) def run(self):
"""实现写进程的业务逻辑"""
ls = [
"11111111111",
"22222222222",
"33333333333",
"44444444444",
] for line in ls:
#写入
print("x写入内容{}".format(line))
self.q.put(line)
time.sleep(random.randint(1,5)) class ReadProcess(Process):
"""读的进程"""
def __init__(self, q, *args, **kwargs):
self.q = q
super().__init__(*args, **kwargs) def run(self):
while True:
content = self.q.get()
print("读取达到的内容为{}".format(content)) if __name__ == "__main__":
#通过Queue共享数据
q = Queue()
t_write = WriteProcess(q)
t_write.start()
#读取进程
t_read= ReadProcess(q)
t_read.start() t_write.join()
#t_read.join()#由于读进程是死循环,无法等待其结束,只能强制终止
t_read.terminate() #####################
#Queue通过实例传给两个不同的进程, 结果:
x写入内容11111111111
读取达到的内容为11111111111
x写入内容22222222222
读取达到的内容为22222222222
x写入内容33333333333
读取达到的内容为33333333333
x写入内容44444444444
读取达到的内容为44444444444
import time
from multiprocessing.context import Process
import random class WP(Process):
"""写入文件""" def __init__(self,file_name,num,*args,**kwargs):
self.file_name = file_name
self.num = num
super().__init__(*args,**kwargs) def run(self):
for i in range(5):
content = "现在是:{0},{1}.{2}\n".format(
self.name,
self.pid,
self.num
)
with open(self.file_name, "a+",encoding="utf-8") as f:
f.write(content)
time.sleep(random.randint(1,5))
print(content) if __name__ == "__main__":
file_name = "test.txt"
for x in range(5):
p = WP(file_name,x)
p.start() 结果:
现在是:WP-3,18280.2
现在是:WP-2,2004.1
现在是:WP-1,17244.0
现在是:WP-5,17600.4
现在是:WP-3,18280.2
现在是:WP-4,17712.3
现在是:WP-5,17600.4
现在是:WP-1,17244.0
现在是:WP-2,2004.1
现在是:WP-5,17600.4
现在是:WP-2,2004.1
现在是:WP-3,18280.2
现在是:WP-4,17712.3
现在是:WP-5,17600.4
现在是:WP-5,17600.4
现在是:WP-1,17244.0
现在是:WP-2,2004.1 现在是:WP-1,17244.0
现在是:WP-4,17712.3
现在是:WP-3,18280.2
现在是:WP-1,17244.0
现在是:WP-4,17712.3
现在是:WP-2,2004.1
现在是:WP-4,17712.3
从上面可以看出写的是杂乱无章的
我们可以加个进程锁
import time
from multiprocessing.context import Process
import random
from multiprocessing import Lock class WP(Process):
"""写入文件""" def __init__(self,file_name,num,lock,*args,**kwargs):
self.file_name = file_name
self.num = num
self.lock = lock
super().__init__(*args,**kwargs) def run(self): try:
self.lock.acquire()
for i in range(5):
content = "现在是:{0},{1}.{2}\n".format(
self.name,
self.pid,
self.num
)
with open(self.file_name, "a+",encoding="utf-8") as f:
f.write(content)
time.sleep(random.randint(1,5))
print(content)
finally:
self.lock.release() if __name__ == "__main__":
file_name = "test.txt"
lock = Lock()
for x in range(5):
p = WP(file_name,x,lock)
p.start() 结果:
现在是:WP-1,9852.0
现在是:WP-1,9852.0
现在是:WP-1,9852.0
现在是:WP-1,9852.0
现在是:WP-1,9852.0
现在是:WP-4,18316.3
现在是:WP-4,18316.3
现在是:WP-4,18316.3
现在是:WP-4,18316.3
现在是:WP-4,18316.3
现在是:WP-2,15132.1
现在是:WP-2,15132.1
现在是:WP-2,15132.1
现在是:WP-2,15132.1
现在是:WP-2,15132.1
现在是:WP-5,18260.4
现在是:WP-5,18260.4
现在是:WP-5,18260.4
现在是:WP-5,18260.4
现在是:WP-5,18260.4
现在是:WP-3,17568.2
现在是:WP-3,17568.2
现在是:WP-3,17568.2
现在是:WP-3,17568.2
现在是:WP-3,17568.2
还有Rlock,可以进行多重锁,
对于锁忘记释放,也可以是哟个位置参数进行防止
with self.lock:
import random
import time
from multiprocessing.pool import Pool from multiprocessing.process import current_process def run(file_name,num):
"""
进程执行的业务逻辑
往文件中写入数据
:param file_name:
:param num:
:return:
"""
with open(file_name,"a+",encoding="utf-8") as f:
#当前进程
now_process = current_process()
content = "{0} --{1} --{3}".format(
now_process.name,
now_process.pid,
num
)
f.write(content)
f.write("\n")
#写完随机休息1-5秒
time.sleep(random.randint(1,5))
print(content)
return "ok" if __name__ == "__main__":
file_name = "test_pool.txt"
#进程池
pool = Pool(2)
for i in range(20):
rest = pool.apply(run,args=(file_name,i))
print("{0}---{1}".format(i,rest)) pool.close()
pool.join()
python17进程的更多相关文章
- Python17个常用内置模块总结
Python17个常用内置模块总结 1.getpass 2.os 3.sys 4.subprocess 5.hashlib 6.json 7.pickle 8.shutil 9.time 10.dat ...
- 故障重现, JAVA进程内存不够时突然挂掉模拟
背景,服务器上的一个JAVA服务进程突然挂掉,查看产生了崩溃日志,如下: # Set larger code cache with -XX:ReservedCodeCacheSize= # This ...
- 死磕内存篇 --- JAVA进程和linux内存间的大小关系
运行个JAVA 用sleep去hold住 package org.hjb.test; public class TestOnly { public static void main(String[] ...
- 使用Monit监控本地进程
目前用它监控某些服务,失败自动重启,同时监控特定的日志文件,如果有变化,就发邮件报警 安装不细写了,网上好多 我先用cat /proc/version看了下我的系统是el6的,于是wget http: ...
- [APUE]进程控制(上)
一.进程标识 进程ID 0是调度进程,常常被称为交换进程(swapper).该进程并不执行任何磁盘上的程序--它是内核的一部分,因此也被称为系统进程.进程ID 1是init进程,在自举(bootstr ...
- [APUE]UNIX进程的环境(下)
一.共享库 共享库使得可执行文件中不再需要包含常用的库函数,而只需在所有进程都可存取的存储区中保存这种库例程的一个副本.程序第一次执行的时候或第一次调用某个库函数的时候,用动态链接方法将程序与共享库函 ...
- Tomcat shutdown执行后无法退出进程问题排查及解决
问题定位及排查 上周无意中调试程序在Linux上ps -ef|grep tomcat发现有许多tomcat的进程,当时因为没有影响系统运行就没当回事.而且我内心总觉得这可能是tomcat像nginx一 ...
- 查看w3wp进程占用的内存及.NET内存泄露,死锁分析
一 基础知识 在分析之前,先上一张图: 从上面可以看到,这个w3wp进程占用了376M内存,启动了54个线程. 在使用windbg查看之前,看到的进程含有 *32 字样,意思是在64位机器上已32位方 ...
- 探索ASP.NET MVC5系列之~~~6.Session篇(进程外Session)
其实任何资料里面的任何知识点都无所谓,都是不重要的,重要的是学习方法,自行摸索的过程(不妥之处欢迎指正) 汇总:http://www.cnblogs.com/dunitian/p/4822808.ht ...
随机推荐
- LeetCode:数组专题
数组专题 有关数组的一些 leetcode 题,在此做一些记录,不然没几天就忘光光了 二分查找 双指针 滑动窗口 前缀和/差分数组 二分查找 本文内容摘录自公众号labuladong中有关二分查找的文 ...
- netty传输java bean对象
在上一篇博客(netty入门实现简单的echo程序)中,我们知道了如何使用netty发送一个简单的消息,但是这远远是不够的.在这篇博客中,我们来使用netty发送一个java bean对象的消息,但是 ...
- 8M的摄像头,30fps摄像时,60hz的LCD刷新频率,请问camera每秒向BB传输多少数据,如何计算
8M的摄像头,30fps摄像时,60hz的LCD刷新频率,请问camera每秒向BB传输多少数据,如何计算 xiang2012 Post at 2012/8/7 10:37:33 8M的摄像头,30f ...
- linux下软链接文件的拷贝
最近在编译libnl库准备拷贝到其他机器中使用的时候出现无法拷贝问题,原因是sd卡是fat32文件系统格式,这种文件系统不支持linux下的ln软链接文件, void@void-ThinkPad-E4 ...
- linux中的分号 && ||
几个符号的用法 ; 顺序地独立执行各条命令, 彼此之间不关心是否失败, 所有命令都会执行. && 顺序执行各条命令, 只有当前一个执行成功时候, 才执行后面的. & 放在启动参 ...
- 0x03
指数级枚举:1到n任意选取的所有方案数: #include<bits/stdc++.h> using namespace std; int n,a[1100],vis[1100],cnt, ...
- 一次fork引发的惨案!
"你还有什么要说的吗?没有的话我就要动手了",kill程序最后问道. 这一次,我没有再回答. 只见kill老哥手起刀落,我短暂的一生就这样结束了··· 我是一个网络程序,一直以来都 ...
- flyway的使用
1.使用它之前先要了解一些概念: 版本:对数据库的每一次变更可称为一个版本. 迁移:Flyway把数据库结构从一个版本更新到另一个版本叫做迁移. 可用的迁移:Flyway的文件系统识别出来的迁移版本. ...
- SkyWalking部署及.Net Core简单使用
SkyWalking官方网站非常详细,以下只是本人学习过程的整理 一.SkyWalking简介 1.概念 SkyWalking是分布式系统的应用程序性能监视工具,专为微服务.云原生架构而设计 SkyW ...
- 算法学习->求解三角形最小路径
00 问题 00-1 描述 对给定高度为n的一个整数三角形,找出从顶部到底部的最小路径和.每个整数只能向下移动到与之相邻的整数. 找到一个一样的力扣题:120. 三角形最小路径和 - 力扣(LeetC ...