文章标题

来源:互联网 发布:企业内部数据共享方案 编辑:程序博客网 时间:2024/06/03 04:10

线程学习(一)
程序,进程和线程
1. 程序(Program) 是一个指令集它是一种静态概念(是指所写的代码)
2. 进程(Process) 是操作系统去调度程序这是一种动态概念(一个程序代表一个进程)
3. 线程(Thread) 在进程内多条执行路径(模拟出来的多条路径)
进程和线程的区别
1. 进程:有独立的内存空间,进程中的数据存放空间(栈空间和堆空间)是独立的,每个进程都至少有一个线程。
2. 线程:堆空间是共享的,栈空间是独立的,线程消耗的资源也比进程小,相互之间是可以影响的,有被称为轻型进程或者说是进程元。
多线程的随机性
在一个进程中的多个线程的运行方式是并发运行的,那么我们可以从微观角度上考虑这些线程的执行,是有先后顺序的。那么到底是哪个线程执行?这取决于CPU调度器(JVM来调度),程序员是控制不了的。我们可以将多线程的并发理解为多个线程在某一瞬间抢占CPU资源,谁抢到谁就去执行自己的工作,这种抢占式获取资源的方式造就了线程的随机性。
线程的调度
通常在PC机只有一个CPU的时候,在任意时刻只能执行一条计算机指令,每个进程只有获得CPU的使用权才会执行指令。而多线程的并发运行可以看成是每个线程在轮流使用CPU来执行自己的任务。在这期间JVM来负责线程的调度。

原创粉丝点击