多线程
2016-08-09 20:14
162 查看
线程的基本概念
线程,又称为轻量级进程,是程序执行流的最小单元。一个标准的线程由线程ID、当前指令指针、寄存器集合和堆栈组成。线程是系统独立调度和分派的基本单位,线程不拥有系统资源,只拥有一点在运行中必不可少的资源,但可与同属一个进程的其它线程共享进程所拥有的全部资源。
线程的状态
新线程态:新创建一个线程,就属于新线程态
可运行态:线程拥有运行所需的所有条件,并且分配了cpu
阻塞态:线程缺少运行的条件;sleep()/suspend()方法调用
线程和进程的区别
1. 地址空间和其它资源(如打开文件):进程间相互独立,同一进程的各线程间共享。某进程内的线程在其它进程不可见。
2. 通信:进程间通信IPC,线程间可以直接读写进程数据段(如全局变量)来进行通信——需要进程同步和互斥手段的辅助,以保证数据的一致性。
3. 调度和切换:线程上下文切换比进程上下文切换要快得多。
4. 在多线程OS中,进程不是一个可执行的实体。
线程,又称为轻量级进程,是程序执行流的最小单元。一个标准的线程由线程ID、当前指令指针、寄存器集合和堆栈组成。线程是系统独立调度和分派的基本单位,线程不拥有系统资源,只拥有一点在运行中必不可少的资源,但可与同属一个进程的其它线程共享进程所拥有的全部资源。
线程的状态
新线程态:新创建一个线程,就属于新线程态
可运行态:线程拥有运行所需的所有条件,并且分配了cpu
阻塞态:线程缺少运行的条件;sleep()/suspend()方法调用
线程和进程的区别
1. 地址空间和其它资源(如打开文件):进程间相互独立,同一进程的各线程间共享。某进程内的线程在其它进程不可见。
2. 通信:进程间通信IPC,线程间可以直接读写进程数据段(如全局变量)来进行通信——需要进程同步和互斥手段的辅助,以保证数据的一致性。
3. 调度和切换:线程上下文切换比进程上下文切换要快得多。
4. 在多线程OS中,进程不是一个可执行的实体。
相关文章推荐
- Python3写爬虫(四)多线程实现数据爬取
- C#实现多线程的同步方法实例分析
- 浅谈chuck-lua中的多线程
- C#简单多线程同步和优先权用法实例
- C#多线程学习之(四)使用线程池进行多线程的自动管理
- C#多线程编程中的锁系统(三)
- 解析C#多线程编程中异步多线程的实现及线程池的使用
- C#多线程学习之(六)互斥对象用法实例
- 基于一个应用程序多线程误用的分析详解
- C#多线程学习之(三)生产者和消费者用法分析
- C#多线程学习之(一)多线程的相关概念分析
- C#多线程之Thread中Thread.IsAlive属性用法分析
- 分享我在工作中遇到的多线程下导致RCW无法释放的问题
- C#多线程编程之使用ReaderWriterLock类实现多用户读与单用户写同步的方法
- C#多线程传递参数及任务用法示例
- C#控制台下测试多线程的方法
- 21天学习android开发教程之SurfaceView与多线程的混搭
- Ruby 多线程的潜力和弱点分析
- C#中WPF使用多线程调用窗体组件的方法
- C#如何对多线程、多任务管理(demo)