轻轻松松带你了解线程与进程

一:进程与线程介绍

进程:进程是程序(任务)的执行过程,持有资源(共享内存,共享文件)和线程。比如eclipse,qq在运行后都是进程。

线程:进程运行时的一个功能,比如用qq打字聊天,上传照片都是不同的线程。

线程的特点:1. 线程是系统中最小的执行单元      2 .同一进程中有多个线程         3. 线程共享进程的资源

举例:如果把进程比作班级,班级的每个学生都可看作线程,教室中扫把,垃圾桶(资源)都是学生们的共享资源。

二:多个线程的交互

争用条件:当多个线程同时共享访问同一数据(内存区域时),每个线程都尝试操作该数据,从而导致数据被破坏,这种现象称为争用条件。

解决争用条件的方法:线程的互斥与同步

互斥:在同一时间只能有一个线程对我们的关键数据或者临界区进行操作。
同步:线程之间的一种通信机制,比如说一个线程做完某一件事情时,用某种方式去告诉其它线程我做完了。

线程的互斥解决途径:
首先定义一个锁对象  private final Object lockObject = new Object()

然后使用synchronized关键字加锁。
synchronized(lockObject ) 给我们线程加上一把锁,java语法保证同一时间,只能有一个线程获得我们的lockObject 锁对象
例如:
synchronized(lockObject ){
     关键代码(需要进行互斥操作的代码)....
}

线程同步解决途径:
wait(),线程进入wait set中等待
notify()  ,唤醒wait set(等待池)中的一条线程,是哪条,随机的
motifyAll(),  唤醒wait set(等待池)中的所有线程,唤醒的线程又可以去竞争资源。

下面举个例子让你分分钟了解线程互斥与同步

女神在周日想约会,张三,李四,王五,小东都想跟女神约会,但是女神为了防止屌丝们打架,同一时间只能跟一个男生约会,最终女神决定跟小东约会,小东就给女神加了把锁(synchronized关键字)别的屌丝就没戏了,这就是互斥。
但是有一个周末女神生病了,屌丝们又来约女神了,女神说我生病了要呆在家里,不约会了,你们都等着吧(相当于调用了wait()方法,屌丝们都在wait set中等着),到了下个周末女神用微信给屌丝们发了一条信息(“我的病好了,今天可以约会”,这相当于notifyAll() 方法),屌丝们快乐的从等待池(wait set)中出来,都又一起约女神,这就是同步。

三:线程中的常用方法

Thread.yield(); 目标线程让出cpu,下次哪个线程执行是随机的
   Thread.join();  目标线程将一直执行,不会被打断,其它线程会等待
   Thread.sleep(1000) 目标线程休眠一段时间,参数为毫秒级,1000为1秒

四:线程中容易用错的方法

stop()方法这是一个错误退出线程的方法,因为,线程调用这个方法后,线程还没执行完,就会被强行停止,你想想,如果这发生在我们对数据库的一个事务进行操作中,会有什么现象了?
        正确的退出线程的方法就是设置一个标志位keepRunning,的当keepRunning=true时线程执行,keepRunning=false时,线程退出,这样线程会执行完才会退出线程。这样保证线程的安全,这才是我们推荐退出线程的方法。

有人说interrupt()方法也能停止当前线程,其实interrupt()方法的初衷并不是用于停止线程,interrupt()是中断我们的线程,如果我们只是调用interrupt()方法线程不会停止,还会继续执行。如果我们一定要使用interrupt()停止线程执行时,需要了解一下isInterrupted()方法,返回一个boolean值(但是这个缺点是,运行中不能跟sleep()合用,会出错,所以一般也不用况请自己)。实现原理和上面的设置标志位退出线程相似。

各位看官,是否对进程与线程有了清晰的了解了,下次我们再见~谢谢观看

时间: 2024-11-05 10:20:10

轻轻松松带你了解线程与进程的相关文章

【Python之路Day11】网络篇之线程、进程、协程

目录: 基本概念 线程 进程 协程  一. 基本概念 现在的操作系统,如Unix.Linux.Windows.Mac OS X等,都是支持“多任务”的操作系统. 什么叫”多任务“呢?简单理解,就是我们可以一般上网浏览某车之家的网页,看看喜欢的车型信息:一边打开某易云音乐听听好歌:一边打开某软件股市行情图,不安的盯着曲线图...卧槽,又尼玛跌了!  这就是多任务喽. 多核心的CPU已经很普及了,但是,就是在过去的单核心CPU上,也可以执行多任务. PS: CPU是分时间片的,假设任务1执行0.01

Linux 线程与进程,以及通信

http://blog.chinaunix.net/uid-25324849-id-3110075.html 部分转自:http://blog.chinaunix.net/uid-20620288-id-3025213.html 1.首先要明确进程和线程的含义: 进程(Process)是具有一定独立功能的程序关于某个数据集合上的一次运行活动,是系统进行资源分配和调度的一个独立单位.与程序相比,程序只是一组指令的有序集合,它本身没有任何运行的含义,只是一个静态实体.进程是程序在某个数据集上的执行,

python线程、进程和协程

链接:http://www.jb51.net/article/88825.htm 引言 解释器环境:python3.5.1 我们都知道python网络编程的两大必学模块socket和socketserver,其中的socketserver是一个支持IO多路复用和多线程.多进程的模块.一般我们在socketserver服务端代码中都会写这么一句: server = socketserver.ThreadingTCPServer(settings.IP_PORT, MyServer) Threadi

python 线程,进程与协程

引言 线程 创建普通多线程 线程锁 互斥锁 信号量 事件 条件锁 定时器 全局解释器锁 队列 Queue:先进先出队列 LifoQueue:后进先出队列 PriorityQueue:优先级队列 deque:双向队列 引言 在学习过socket和socketserver后,我们了解到socketserver可以支持IO多路复用.在定义socketserver服务端的时候一般会使用: server = socketserver.ThreadingTCPServer(settings.IP_PORT,

线程,进程 ,队列 基本用法总结

一.线程(线程是最小的工作单位,同一进程内的线程共享资源) 创建线程:threading模块 创建一个线程:threading.Thread(target=函数名,args=(参数,) )  *这里的args后面必须是元祖,而且当括号内是一个参数是,第一个参数后加逗号 我们利用threading模块创建的线程都是子线程,因为解释器在工作的时候会创建一个主线程来进行工作,我们自己创造的线程都是子线程 import threading import time def f1(a1,a2): time.

python之线程、进程和协程

引言 解释器环境:python3.5.1我们都知道python网络编程的两大必学模块socket和socketserver,其中的socketserver是一个支持IO多路复用和多线程.多进程的模块.一般我们在socketserver服务端代码中都会写这么一句:server = socketserver.ThreadingTCPServer(settings.IP_PORT, MyServer)ThreadingTCPServer这个类是一个支持多线程和TCP协议的socketserver,它的

Python 基础之 线程与进程

Python 基础之 线程与进程 在前面已经接触过了,socket编程的基础知识,也通过socketserver 模块实现了并发,也就是多个客户端可以给服务器端发送消息,那接下来还有个问题,如何用多线程与多进程来实现并发呢?今天就来了解一下这方面的知识. 一.进程与线程的概念介绍 多任务处理是指用户可以在同一时间内运行多个应用程序,每个应用程序被称作一个任务.Linux.windows就是支持多任务的操作系统,比起单任务系统它的功能增强了许多. 运行一个任务就需要cpu去处理,那同时运行多个任务

Python 模块(八) socketserver 以及 线程、进程

目录 异常处理 socketserver 线程.进程 一.异常处理 try的工作原理是,当开始一个try语句后,python就在当前程序的上下文中作标记,这样当异常出现时就可以回到这里,try子句先执行,接下来会发生什么依赖于执行时是否出现异常. 代码示例: while True: n1 = input('input a number: ') n2 = input('input a number: ') try: n1 = int(n1) n2 = int(n2) res = n1 + n2 p

Python_oldboy_自动化运维之路_线程,进程,协程(十一)

本节内容: 线程 进程 协程 IO多路复用 自定义异步非阻塞的框架 线程和进程的介绍: 举个例子,拿甄嬛传举列线程和进程的关系: 总结:1.工作最小单元是线程,进程说白了就是提供资源的 2.一个应用程序至少有一个进程,一个进程里至少有一个线程 3.应用场景:io密集型适合用多线程,计算密集型(cpu)适合用多进程 4.GIL:全局解释器锁,作用:保证同一个进程中只能有一个线程同时被调用 5.python的一个诟病:前提是被cpu调度,因为有GIL,一个应用只有一个进程,纵容有多个线程,也体现不出