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

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()方法。






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值