JAVA线程从零开始(一)——进程和线程初认识
来源:互联网 发布:网络爬虫技术介绍 编辑:程序博客网 时间:2024/05/18 02:53
什么是进程?什么是线程?他们的联系和区别是什么?
进程,是并发执行的程序在执行过程中分配和管理资源的基本单位,是一个动态概念,竞争计算机系统资源的基本单位。每一个进程都有一个自己的地址空间,即进程空间。进程至少有五种基本状态:初始态,执行态,等待状态,就绪状态,终止状态。
线程,在网络或多用户环境下,一个服务器通常需要接收大量且不确定数量用户的并发请求,为每一个请求都创建一个进程显然是行不通的,——无论是从系统资源开销方面或是响应用户请求的效率方面来看。因此,操作系统中线程的概念便被引进了。线程是进程的一部分,一个没有线程的进程可以被看作是单线程的。线程有时又被称为轻量级进程或轻权进程,也是CPU调度的一个基本单位。
进程和线程的联系和区别:
1、线程的划分尺度小于进程,线程隶属于某个进程;
2、进程是程序的一种动态形式,是CPU、内存等资源占用的基本单位,而线程是不能独立的占有这些资源的;
3、进程之间相互独立,通信比较困难,而线程之间共享一块内存区域,通信比较方便;
4、进程在执行过程中,包含比较固定的入口、执行顺序和出口,而线程的这些过程会被应用程序所控制
举个简单的小例子来说明理解进程、线程以及它们在操作系统中的关系和联系:
1、计算机的核心是CPU,它承担了所有的计算任务。把它看成一座工厂,时刻在运行;
2、工厂里面有五个车间,假设工厂的电力有限(CPU的处理能力有限),一次只能供给一个车间使用。也就是说,一个车间开工的时候,其他车间都必须停工(因为CPU资源有限,只能供给一个进程使用);
3、一个车间里,可以有很多个工人。它们协同完成一个任务(线程就好比车间里的工人);
4、车间的空间是工人们共享的,比如许多房间是每个工人都可以进出的。(这就好比一个进程所占有的内存空间对于线程来说是共享的,每个线程都可以使用这些共享内存);
5、可是每间房间的大小不同,有些房间最多只能容纳一个人,比如厕所。里面有人的时候,其他人就不能进去了。(这代表一个线程使用某些共享内存时,其他线程必须等它结束,才能使用这一块内存)
6、一个防止他人进入的简单方法,就是门口加一把锁。先到的人锁上门,后到的人看到上锁,就在门口排队,等锁打开再进去。这就叫“互斥锁”(Mutual exclusion,缩写Mutex),防止多个线程同时读写某一块内存区域。
7、还有些房间,可以同时容纳n个人,比如厨房。也就是说,如果人数大于n,多出来的人只能在外面等着。这好比某些内存区域,只能供给固定数目的线程使用。
这时的解决方法,就是在门口挂n把钥匙。进去的人就取一把钥匙,出来时再把钥匙挂回原处。后到的人发现钥匙架空了,就知道必须在门口排队等着了。这种做法叫做“信号量”(Semaphore),用来保证多个线程不会互相冲突。
理解第6点和第7点,可以看出mutex其实是semaphore的一种特殊情况(n=1)。也就是说,完全可以用后者替代前者。但是,因为mutex较为简单,且效率高,所以在必须保证资源独占的情况下,还是采用这种设计。
- JAVA线程从零开始(一)——进程和线程初认识
- Java线程从零开始(三)——进一步认识线程之生命周期
- java并发(一、进程和线程)
- JAVA线程从零开始(二)——创建线程
- Java进程&线程(一)
- 进程和线程(一)
- 进程和线程(一)
- 进程和线程(一)
- java回忆录——进程和线程
- Java——进程和线程
- java基础——进程和线程
- java之多线程(一)进程和线程的区别
- Java多线程(一)进程和线程的基础知识
- 操作系统——进程线程(一)
- Java线程和线程池(一)
- Java 进程和线程
- Java线程和进程
- java 进程和线程
- sqlite3 查询数据库表结构
- 不一样的C++系列--类模板与特化
- 视觉SLAM十四讲调试
- 中文乱码问题
- C++如何对字符串进行删除操作
- JAVA线程从零开始(一)——进程和线程初认识
- esp32+ov7670wifi发射失败率过高debug记录
- 2017.7.4 模拟赛
- Spring mvc(2)spring mvc+quarz+mybatis+druid
- Maven项目的建立
- POJ 2376 Cleaning Shifts 简单的贪心
- CullingGroup API的使用说明
- Linux中的8种查看命令
- ADB工具介绍及常用命令