线程

进程只是用来把资源集中到一起(进程只是一个资源单位,或者说资源集合)而线程才是cpu上的执行单位

1.同一个进程内的多个线程共享该进程内的地址资源

2.创建线程的开销远小于创建进程的开销(创建一个进程,就是创建一个车间,涉及到申请空间,而且在该空间内建至少一条流水线,但创建线程,就只是在一个车间        内造一条流水线,无需申请空间,所以创建开销小)

开启线程的两种方式

import time
import random
from threading import Thread def piao(name):
print('%s piaoing' %name)
time.sleep(random.randrange(1,5))
print('%s piao end' %name) if __name__ == '__main__':
#实例化得到一个对象
t1=Thread(target=piao,args=('egon',)) #必须加,号 #调用对象下的方法,开启一个进程
t1.start()
print('主线程')
'''
打印结果:
egon piaoing
主线程
egon piao end
'''

方式一

import time
import random
from threading import Thread class MyThread(Thread):
def __init__(self,name):
super().__init__()
self.name=name
def run(self):
print('%s piaoing' %self.name)
time.sleep(random.randrange(1,5))
print('%s piao end' %self.name) if __name__ == '__main__':
t1=MyThread('egon')
t1.start() #start会自动调用run
print('主')
'''
打印结果:
egon piaoing

egon piao end
'''

方式二

进程线程的区别

1.开进程的开销远大于开线程
2.同一进程内的多个线程共享该进程的地址空间;而进程之间的内存是隔离的
3.开多个进程,每个进程都有不同的pid;在主进程下开启多个线程,每个线程的pid都和主进程的pid一样
# 1.开进程的开销远大于开线程

import time
from threading import Thread
from multiprocessing import Process def piao(name):
print('%s piaoing' %name)
time.sleep(1)
print('%s piao end' %name) if __name__ == '__main__':
p1 = Process(target=piao, args=('egon',)) # 必须加,号
p1.start() # t1=Thread(target=piao,args=('egon',)) #必须加,号
# t1.start()
print('主线程')
'''
打印结果:
进程
主线程
egon piaoing
egon piao end 线程
egon piaoing
主线程
egon piao end
'''

区别一

from threading import Thread
from multiprocessing import Process n=100
def task():
global n
n=0 if __name__ == '__main__':
# p1 = Process(target=task) # 必须加,号
# p1.start()
# p1.join() t1=Thread(target=task,) #必须加,号
t1.start()
t1.join()
print('主线程',n)
'''
打印结果
进程
主线程 100
证明进程在使用内存空间是互相隔离 线程
主线程 0
证明同一进程内的多个线程共享该进程的地址空间
'''

区别二

from threading import Thread
from multiprocessing import Process,current_process
import os n=100
def task():
# print(current_process().pid) # 查看当前进程的id号
print('子进程PID:%s 父进程PID:%s' %(os.getpid(),os.getppid())) if __name__ == '__main__':
p1 = Process(target=task) # 必须加,号
p1.start() # print('主线程',current_process().pid)
print('主进程', os.getpid())
'''
打印结果
主进程 10576
子进程PID:9744 父进程PID:10576
'''
def task():
print('子进程PID:%s' %(os.getpid())) if __name__ == '__main__':
t1 = Thread(target=task())
print('主进程', os.getpid())
'''
打印结果:
子进程PID:9956
主进程 9956
'''

区别三

Thread的其他属性

Thread对象的方法:

  • t.isAlive() 和 t.is_alive() # 返回线程是否存活
  • t.setName()  # 设置进程名
  • t.getName() # 返回进程名

threading模块的方法:

  • threading.currentThread() # 获取当前线程的对象
  • threading.enumerate()   # 返回一个包含正在运行的线程的list。正在运行指线程启动后、结束前,不包括启动前和终止后的线程。
  • threading.activeCount() # 返回已经启动的线程数量,与len(threading.enumerate())有相同的结果。
from threading import Thread,currentThread,active_count,enumerate
import time def task():
print('%s is running' %currentThread().getName()) # currentThread()相当于对象t1
time.sleep(2)
print('%s is done' % currentThread().getName()) if __name__ == '__main__':
t=Thread(target=task,name='子线程1')
t.start()
t.setName('儿子线程1') # 修改线程的名
t.join() # 让主线程去等待子线程结束
print(t.getName())
currentThread().setName('主线程') # 设置主线程的名字
print(t.is_alive()) # 查看是否存活
print('主线程',currentThread().getName()) t.join()
print(active_count()) # 活跃的线程数
print(enumerate()) # 拿到当前活跃线程的对象
'''
打印结果:
子线程1 is running
儿子线程1 is done
儿子线程1
False
主线程 主线程
'''

并发编程---线程---开启方式---进程线程的区别----Thread的其他属性的更多相关文章

  1. 并发编程(六)--进程/线程池、协程、gevent第三方库

    一.进程/线程池 1.进程池 (1)什么是进程池 如果需要创建的子进程数量不大,可以直接利用multiprocess中的Process来创建.但是当需要创建上百个或上千个,手动创建就较为繁琐,这时就可 ...

  2. 并发编程(六)——进程/线程池、协程、gevent第三方库

    进程/线程池.协程.gevent第三方库 一.进程/线程池 1.进程池 (1)什么是进程池 如果需要创建的子进程数量不大,可以直接利用multiprocess中的Process来创建.但是当需要创建上 ...

  3. java并发编程笔记(三)——线程安全性

    java并发编程笔记(三)--线程安全性 线程安全性: ​ 当多个线程访问某个类时,不管运行时环境采用何种调度方式或者这些进程将如何交替执行,并且在主调代码中不需要任何额外的同步或协同,这个类都能表现 ...

  4. Java并发编程(您不知道的线程池操作), 最受欢迎的 8 位 Java 大师,Java并发包中的同步队列SynchronousQueue实现原理

    Java_并发编程培训 java并发程序设计教程 JUC Exchanger 一.概述 Exchanger 可以在对中对元素进行配对和交换的线程的同步点.每个线程将条目上的某个方法呈现给 exchan ...

  5. Java并发编程(您不知道的线程池操作)

    Java并发编程(您不知道的线程池操作) 这几篇博客,一直在谈线程,设想一下这个场景,如果并发的线程很多,然而每个线程如果执行的时间很多的话,这样的话,就会大量的降低系统的效率.这时候就可以采用线程池 ...

  6. 【Java并发编程】之二:线程中断

    [Java并发编程]之二:线程中断 使用interrupt()中断线程 ​ 当一个线程运行时,另一个线程可以调用对应的Thread对象的interrupt()方法来中断它,该方法只是在目标线程中设置一 ...

  7. java并发编程笔记(七)——线程池

    java并发编程笔记(七)--线程池 new Thread弊端 每次new Thread新建对象,性能差 线程缺乏统一管理,可能无限制的新建线程,相互竞争,有可能占用过多系统资源导致死机或者OOM 缺 ...

  8. java并发编程笔记(五)——线程安全策略

    java并发编程笔记(五)--线程安全策略 不可变得对象 不可变对象需要满足的条件 对象创建以后其状态就不能修改 对象所有的域都是final类型 对象是正确创建的(在对象创建期间,this引用没有逸出 ...

  9. python并发编程基础之守护进程、队列、锁

    并发编程2 1.守护进程 什么是守护进程? 表示进程A守护进程B,当被守护进程B结束后,进程A也就结束. from multiprocessing import Process import time ...

随机推荐

  1. Java性能分析神器-JProfiler详解(一)(转)

    前段时间在给公司项目做性能分析,从简单的分析Log(GC log, postgrep log, hibernate statitistic),到通过AOP搜集软件运行数据,再到PET测试,感觉时间花了 ...

  2. Context namespace element 'component-scan' and its parser class [org.springframework.context.annotation.ComponentScanBeanDefinitionParser] are only available on JDK 1.5 and higher

    异常信息如下: 错误: Unexpected exception parsing XML document from class path resource [spring/applicationCo ...

  3. 【CF717G】Underfail 费用流

    [CF717G]Underfail 题意:赌城拉斯维起司的赌场最近推出了一种新式赌法.它的玩法是由庄家(Joker)设局,赌徒只需要交付一定数额的赌资即可入局.具体地,Joker将给出一个长度为 $n ...

  4. day10 多媒体(文字 图片 音频 视频)

    1计算机表示图形的几种方式     bmp:以高质量保存     用于计算机     jpg:以良好的质量保存    用于计算机或者网络     png:以高质量保存     图片大小的计算公式:图片 ...

  5. perl 遍历指定目录下的所有文件,替换指定文本内容,返回受影响的文件路径

    不会读取 影藏文件 main #!/usr/bin/perl use autodie; use utf8; use Encode qw(decode encode); if(@ARGV ne 3){ ...

  6. html5__Notifications API 桌面通知

    MDN地址 google 文档 https://developers.google.cn/web/fundamentals/push-notifications/ const koa2 = requi ...

  7. db2命令参数with ur

    查询DB2数据库,老遇到select * from XXX with ur, 好奇ur是什么作用(转) DB2中,共有四种隔离级:RS,RR,CS,UR,DB2提供了这4种不同的保护级别来隔离数据. ...

  8. PL-SVO

    pl-svo对第一帧提取点和线段特征,点特征直接保存为Point2f就行,对于线段特征保存线段的两个端点 void detectFeatures( FramePtr frame, vector< ...

  9. linux命令瞎记录find xargs

    1.创建多个文件 touch test{0..100}.txt 2.重定向 “>>” 追加重定向,追加内容,到文件的尾部 “>” 重定向,清除原文件里面所有内容,然后把内容追加到文件 ...

  10. block diagonal matrix 直和 块对角矩阵 不完美 有缺陷 缩放 射影几何

    小结: 1.block diagonal matrix  直和 块对角矩阵 A block diagonal matrix is a block matrix that is a square mat ...