您的位置:首页 > 编程语言 > Java开发

读实战java高并发程序设计笔记02--java并行程序基础

2018-02-11 10:30 274 查看
2.1 有关线程的基础知识
    进程的官方解释:是计算机中的程序关于数据集合上的一次运行活动,是系统和调度的基本单位,是操作系统结构的基础。

进程是线程的容器。
    本书作者的解释:如图所示:


线程是轻量级进程,是程序执行的最小单位,使用多线程而不是多进程来进行并发程序的设计,是因为线程间的切换和调度的成本远远小于进程。下图是线程的生命周期:



线程的所有状态都是在Thread 中的State枚举中定义:



当线程处于NEW状态的时候表示该线程是被刚刚创建,还没有开始执行,当线程执行start()的时候,才表示线程开始执行,此时
线程处于RUNNABLE状态,此时线程还是没有运行,因为还没有获得CPU的执行资源,当此线程获得CPU的执行资源之后才正式
开始运行,当线程在执行过程中遇到synchronized关键字的时候,就会进入BLOCKED阻塞状态,这时候线程就会暂停执行,直
到获得请求的锁。WANTING和TIMED_WANTING都表示等待状态,区别在于WANTING会进入无时间限制的等待,
TIMED_WANTING会进入有时间限制的等待,那等待的线程在等待什么??一般来说,WANTING的线程正在等待一些特殊的
事件,比如通过wait()方法等待的线程在等待notify()方法,而通过join()方法等待的线程则会等待目标线程 的终止,一旦等待到
了期望的事件,线程会再次执行,进入到RUNNABLE状态。当线程执行完毕之后,则进入到TERMINATED状态,表示结束。
从NEW状态开始执行的线程无法再次回到NEW状态,同理,处于TERMINATED的线程也不能再回到RUNNABLE状态。

2.2:线程的基本操作
    2.2.1:新建线程

当线程调用start()后,线程有一个run()方法,start()方法就会新建一个线程并让这个线程执行run()方法。





内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: