0. 在介绍线程前我们先看一下什么是进程?

进程是线程的母亲,如果在大学计算机课程里读过操作系统一定不会陌生。

所谓进程,它是计算机程序关于某数据集上的一次活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。

罗里吧嗦一大堆,还是不够简洁?

那就一句话来表达吧:进程是正在执行的程序实例。

进程的内存布局

逻辑上一个进程可以划分为以下几部分(段):

* 文本: 程序的指令

* 数据: 程序使用的静态变量

* 堆:   程序可以从该区域动态分配额外内存

* 栈:   随函数调用, 返回而增减的一片内存,用于为局部变量和函数调用链接信息分配存储空间

好了,关于进程就先到这里了,再深入下去就是操作系统的内容了,这不是我们这篇博文的重点。

1. 什么是线程?

线程是进程中可独立执行的子任务。

一个进程可以包含多个线程,同一个进程中的线程共享该进程所拥有的资源,如内存空间和文件句柄等。

因此,进程是线程的容器,我们使用多线程去进行程序的并发设计,因为这样调度的成本会小得多。

2. 线程的生命周期

在Java中线程有以下几种状态:

1)NEW(新生线程)

你可以用new操作符创建一个线程

eg: new Thread(r)

用上面语句创建的线程便处于新生状态。

注意:当一个线程处于新生状态时,程序还没有开始运行线程中的代码,在我们的线程可以运行之前,还有一些小工作要做。

2)RUNNABLE(可运行)

线程什么时候可以运行了呢,也就是进入Runnable状态了呢?

答案是:一旦调用了start方法,该线程就成为Runnable了。

这里要注意的是:一个Runnable线程并不代表该线程一定正在运行,这个要搞清楚!!

也可能它并没有在运行中,线程是否运行还要区间耳语操作系统为该线程提供的运行时间。

一旦线程开始运行,它并不需要始终保持运行,实际上,线程在运行过程中有时需要被中断,目的是

为了让其他线程获得运行的机会。

3)BLOCKED(线程被阻塞)

当一个线程被阻塞时,其它线程就会获得被调度运行的机会。

那么,如何发起阻塞操作呢?

场景如下:

一个线程发起一个Blocking I/O(如: 文件读写/阻塞式Socket读写), 或者试图去获得一个由其它线程持有的锁时。

4)WAITING(线程等待)

当一个线程执行某些方法之后,就会处于等待状态。

这些方法包括:

Object.wait(), Thread.join(), LockSupport.park()

而与之相对应地,我们也可以使线程继续从等待状态回到可运行(Runnable)状态,可以通过如下方法:

Object.notify(), Object.notifyAll(), LockSupport.unpark(thread)

5) TIME_WAITING(有限时间等待)

这个状态类似于WAITING, 区别是:线程并非无限等待,而是有限等待,当其它线程没有在指定时间内期望操作时,该线程状态会

自动转为可运行(RUNNABLE)。

6) TERMINATED(线程结束)

当线程执行结束时,处于状态,这个时候也就是线程的生命周期终止的时候。

线程结束有两种情况:

一种是正常结束返回

另一种则是由于异常以前终止

3. Java中启动一个线程的关键代码

首先,我们必须要知道Runnable接口

Runnable接口有一个run()方法,用于给我们的线程类来启动。

public interface Runnable

{

void run();

}

我们要做的,是写一个实现Runnable接口的类,如下:

然后为该Runnable类创建实例

Runnable r = new MyRunnable();

接着,通过把Runnable类传给Thread类的构造函数来创建Thread对象

Thread t = new Thread(r);

最后,启动线程

t.start();

Core Java-多线程-线程的生命周期的更多相关文章

  1. Java多线程——线程的生命周期和状态控制

    一.线程的生命周期 线程状态转换图: 1.新建状态 用new关键字和Thread类或其子类建立一个线程对象后,该线程对象就处于新生状态.处于新生状态的线程有自己的内存空间,通过调用start方法进入就 ...

  2. Java多线程-线程的生命周期

    线程可以分为4个状态:New(新生),Runnable(可运行):为了方便分析,还可将其分为:Runnable与Running.blocked(被阻塞),Dead(死亡). 与人有生老病死一样,线程也 ...

  3. Java 并发 线程的生命周期

    Java 并发 线程的生命周期 @author ixenos 线程的生命周期 线程状态: a)     New 新建 b)     Runnable 可运行 c)     Running 运行 (调用 ...

  4. Java中线程的生命周期

    首先简单的介绍一下线程: 进程:正在运行中的程序.其实进程就是一个应用程序运行时的内存分配空间. 线程:其实就是进程中的一条执行路径.进程负责的是应用程序的空间的标示.线程负责的是应用程序的执行顺序. ...

  5. Java 之 线程的生命周期(线程状态)

    一.线程的生命周期 (1)新建状态 new 好了一个线程对象,此时和普通的 Java对象并没有区别. (2)就绪 就绪状态的线程是具备被CPU调用的能力和状态,也只有这个状态的线程才能被CPU调用.即 ...

  6. 简要分析一下java中线程的生命周期

    面试题:您了解线程吗?简单叙述一下线程的生命周期? 答:之前学过一些有关于线程方面的知识,并且在编写代码的过程中还是要经常考虑线程,所以,我对线程还是了解一点的. 首先,创建一个线程,线程进入初始状态 ...

  7. JAVA基础知识之多线程——线程的生命周期(状态)

    线程有五个状态,分别是新建(New).就绪(Runnable).运行(Running).阻塞(Blocked)和死亡(Dead). 新建和就绪 程序使用new会新建一个线程,new出的对象跟普通对象一 ...

  8. Java之线程的生命周期

    在Java中,线程有5中不同状态,分别是:新建(New).就绪(Runable).运行(Running).阻塞(Blocked)和死亡(Dead).它们之间的转换图如下: 上图有一个例外,调用yiel ...

  9. java笔记线程的生命周期图解

  10. java线程的生命周期及五种基本状态

    一.线程的生命周期及五种基本状态 关于Java中线程的生命周期,首先看一下下面这张较为经典的图: 上图中基本上囊括了Java中多线程各重要知识点.掌握了上图中的各知识点,Java中的多线程也就基本上掌 ...

随机推荐

  1. sqlite 截取字符串函数substr

    函数:substr(string string,num start,num length) 用法: string为字符串: start为起始位置:字符串的第一个字符的位置为1,不是从0开始计算 len ...

  2. apk中添加第三方so文件

    如果你是把so放在libs/armeabi/下,eclipse中so会自动打包进去,然后使用System.load("data/data/xxx.xxx.xxx/lib/xx.so" ...

  3. MySQL中进行树状所有子节点的查询 . mysql根据父id 查询所有的子id

    在Oracle 中我们知道有一个 Hierarchical Queries 通过CONNECT BY 我们可以方便的查了所有当前节点下的所有子节点.但很遗憾,在MySQL的目前版本中还没有对应的功能. ...

  4. wince程序调用另外一个wince exe程序?

    记住:要释放句柄 清空内存(当前程序) 在虚拟机下测试如图: 在reyo.ini文件中配置另一wince执行程序的路径,如果不配置程序会报错: 如果配置的程序不存在报错: 没有问题就调用所在位置的wi ...

  5. 女子监狱第一季/全集Orange Is the New Black迅雷下载

    本季第一季 Orange Is the New Black 1 (2013) 看点:该剧描述主人公Piper Chapman(Taylor Schilling)在大学里结识了毒贩Alex(Laura ...

  6. [A类会议] 国内论文检索

    https://www.cn-ki.net/ http://www.koovin.com

  7. java转义符和正则表达式转义符

    举例来说,连续相同的3位数字的正则表达式的标准语法是: ([\d])\1{2} 但是如果在java代码中这么写,就会出现语法错误,如下: String regEx = "([\d])\1{2 ...

  8. 深入理解多线程(五)—— Java虚拟机的锁优化技术

    本文是<深入理解多线程>的第五篇文章,前面几篇文章中我们从synchronized的实现原理开始,一直介绍到了Monitor的实现原理. 前情提要 通过前面几篇文章,我们已经知道: 1.同 ...

  9. VMware vSphere中的HA工作原理介绍

    http://blog.51cto.com/linkinsds/416738 HA全称High Availability.它是VMware的企业应用环境中用来保障企业级应用的不间断运行需求所产生的一个 ...

  10. Chapter 3 -- Ordering

    Guava's fluent comparator class, Ordering, explained. explained Updated Jun 27, 2013 by cpov...@goog ...