Java—进程与线程
- 进程与线程
进程是程序(任务)的执行过程,具有动态性;持有资源(共享内存、共享文件)和线程,是资源和线程的载体。
线程是系统中最小的执行单元,同一进程中有多个线程,线程共享进程的资源。
线程的交互,交互的方式包括互斥与同步。
- 线程的常用方法
java对线程的支持主要体现在类Thread和接口Runnable,它们都继承java.lang包,有一个共同的方法run()
- 线程停止错误的方法:stop()、interrupt()
- 线程停止的正确方法
public class ArmyRunnable implements Runnable {
//volatile保证了线程可以正确读取其他线程写入的值
volatile boolean keepRunning = true;
@Override
public void run() {
while(keepRunning) {
//发动五连击
for (int i = 0; i < 5 ; i++) {
System.out.println(Thread.currentThread().getName() + "进攻对方[" + i + "]");
}
//暂停
Thread.yield();
}
System.out.println(Thread.currentThread().getName() + "结束了战斗");
}
}
- 争用条件
当多个线程同时共享访问同一数据(内存区域)时,每个线程都尝试操作该数据,从而导致数据被破坏(corrupted),这种现象称为争用条件。
- 线程的交互:互斥与同步
互斥:在同一时间,只能有一条线程去对我们的关键数据或临界区进行操作。
互斥的实现:sysnchronized(intrinsic lock),sysnchronized相当于给代码加上一把锁,使其他线程不能进入这个关键区域访问我们的关键资源。
同步:是线程之间的一种通信机制, 由于一条线程的某些条件不具备,使得其他线程处于某种等待的状态,之后由于条件具备了,一条线程会用某种方式唤醒其他的线程。
同步的实现:wait()/notify()/notifyAll()--Object对象的成员方法
wait set 是线程的休息室
public void transfer(int from, int to, double amount) {
//通过synchronized 关键字来实现互斥,synchronized既可以出现在方法之上,也能以块的形式出现在方法体之中
//通过对lockObj加锁实现互斥
//加锁操作是有开销的,多次加锁操作会降低系统的性能
synchronized (lockObj) {//while循环,保证条件不满足时任务都会被条件阻挡,而不是继续竞争CPU资源
while (energyBoxes[from] < amount) {
try {
//条件不满足,将当前线程放入锁对象(lockObj)上的wait set
//wait set 是线程的休息室
lockObj.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
System.out.println(Thread.currentThread().getName());
energyBoxes[from] -= amount;
System.out.printf("从%d转移%10.2f单位能量到%d", from, amount, to);
energyBoxes[to] += amount;
System.out.printf("能量总和:%10.2f%n",getTotalEnergies()); //唤醒所有在lockObj对象上等待的线程
lockObj.notifyAll();
} }
- Runnable方式和Thread方式创建线程的区别
- Runnable方式可以避免Thread方式由于Java单继承特性带来的缺陷
- Runnable的代码可以被多个线程(Thread实例)共享,适合于多个线程处理同一资源的情况
- 线程的生命周期
- 就绪:创建了线程对象后,调用了线程的start()方法(此时线程只是进入了线程队列,等待获取CPU服务,具备了运行的条件,但并不一定已经开始运行了)。
- 运行:处于就绪状态的线程,一旦获取了CPU资源,便进入到运行状态,开始执行run()方法里面的逻辑。
- 终止:线程的run()方法执行完毕,或者线程调用了stop()方法(这种方法已经out),线程便进入终止状态。
- 阻塞:一个正在执行的线程在某些情况下,由于某种原因而暂时让出了CPU资源,暂停了自己的执行,便进入了阻塞状态,如调用了sleep()方法
- 用户线程和守护线程
- 用户线程:运行在前台,执行具体的任务,如程序的主线程、连接网络的子线程
- 守护线程:运行在后台,为其他前台线程服务,一旦所有用户线程都结束运行,守护线程会随JVM一起结束工作。
- 守护线程的应用:数据库连接池中的监测线程、JVM虚拟机启动后的监测线程。最常见的守护线程是垃圾回收线程
- 设置守护线程:通过调用Thread类的setDaemon(true)方法来设置当前的线程为守护线程。注意:setDaemon(true)必须在start()方法之前调用,否则会抛出异常;在守护线程中产生的新线程也是守护线程;不是所有的任务都可以分配给守护线程来执行,比如读写操作或者计算逻辑。
- 扩展
Java Memory Mode
Locks & Condition
线程安全性: 原子性与可见性 ...
多线程编程常用的交互模型
Java5中并发编程工具
- 参考书
core java
Java concurrency in practice
Java—进程与线程的更多相关文章
- Java进程和线程关系及区别
1.定义 进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位. 线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基 ...
- Java 进程和线程
进程和线程 在并发编程中,有两个基本的执行单元:进程和线程.在Java编程语言中,通常并发编程主要与线程有关.但是进程也很重要. 计算机系统通常具有许多活动的进程和线程.即使在只有一个执行核心,因此在 ...
- Java进程与线程的区别
每个进程都独享一块内存空间,一个应用程序可以同时启动多个进程.比如浏览器,打开一个浏览器就相当于启动了一个进程. 线程指进程中的一个执行流程,一个进程可以包含多个线程. 每个进程都需要操作系统为其分配 ...
- [Java]进程与线程的区别(转)
线程是指进程内的一个执行单元,也是进程内的可调度实体. 与进程的区别: (1)地址空间:进程内的一个执行单元;进程至少有一个线程;它们共享进程的地址空间;而进程有自己独立的地址空间; (2)资源拥有: ...
- java - 进程和线程的区别及联系
1. 进程 (1)进程主要有两个特征: a. 进程是一个实体,占有一定的地址空间.每一个进程都有它自己的地址空间,一般情况下,包括文本区域(text region).数据区域(data region) ...
- java进程和线程的区别
什么是进程,什么是线程系统要做一件事,运行一个任务,所有运行的任务通常就是一个程序:每个运行中的程序就是一个进程,这一点在任务管理器上面可以形象的看到.当一个程序运行时,内部可能会包含多个顺序执行流, ...
- 面试4——java进程和线程相关知识
1.线程和进程的概念.并行和并发的概念
- Java进程和线程
进程是资源分配和任务调度的基本单位, 进程就是包含上下文切换的程序执行时间总和=CPU加载上下文环境+CPU执行+CPU保存上下文环境,可以理解为时间片段: 进程的颗粒度太大了,将进程分块,按照a,c ...
- 巧用Grafana和Arthas自动抓取K8S中异常Java进程的线程堆栈
前言 近期发现业务高峰期时刻会出现CPU繁忙导致的timeout异常,通过监控来看是因为Node上面的一些Pod突发抢占了大量CPU导致的. 问: 没有限制CPU吗?是不是限制的CPU使用值就可以解决 ...
随机推荐
- Shiro如何使用Ehcache实现Session共享
最近项目中用到的Session共享场景:两个独立应用,希望实现DB层共享用户,而且用户只需要登录一次. 分析:这种场合,不适用单点,因为用户数据并不需要单独在第三方应用管理,而且添加单点也会增加整个系 ...
- 转载 Python 操作 MySQL 的正确姿势 - 琉璃块
Python 操作 MySQL 的正确姿势 收录待用,修改转载已取得腾讯云授权 作者 |邵建永 编辑 | 顾乡 使用Python进行MySQL的库主要有三个,Python-MySQL(更熟悉的名字可能 ...
- Java - 冒泡排序的优化算法(尚学堂第七章数组)
import java.util.Arrays; public class TestBubbleSort2 { public static void main(String[] args) { int ...
- python+selenium打开浏览器报错问题
报关键字,升级selenium版本 若打开IE浏览器,停在IE界面,无法跳转对应的地址,设置一下IE的页面缩放,设置为100%
- sql server 保留小数,向上保留指定位数的小数,仅记录,勿看。
比如 4.05 要取成 4.1 , 4.16 取成 4.2 ,4.5 取成 4.5 ,意思就是小数部分第二位不管是多少都丢掉然后加0.1,但是如果是 4.5 这样完整的就不需要处理. 可以像下面这么写 ...
- js方法的使用(z)
http://www.108js.com/article/article1/10025.html?id=58 javascript中正则匹配有3个方法,match,exec,test.这些方法都跟字符 ...
- OC SEL (@selector) 原理及使用总结(转)
SEL 类成员方法的指针 可以理解 @selector()就是取类方法的编号,他的行为基本可以等同C语言的中函数指针,只不过C语言中,可以把函数名直接赋给一个函数指针,而Object-C的类不能直接应 ...
- 8.28_the end
HomeWork the first level 1. 盒模型 #parent { width: 100px; height: 100px; background:black; overflow: h ...
- 机器学习——LightGBM
基础概念 LigthGBM是boosting集合模型中的新进成员,它和xgboost一样是对GBDT的高效实现,很多方面会比xgboost表现的更为优秀.原理上它和GBDT及xgboot类似,都采用损 ...
- Firebird DatabaseAccess WireCrypt DB2Provider
目前最新的Firebird版本是:3.0.3 使用过程的一些必经问题,嵌入式的模式就不再说了. 在使用标准Server版时,第一个要考虑的就是数据库文件的存放位置,默认配置放在windows/syst ...