- 1. 简介
- 2. 进程和线程
- 3. 线程的状态
- 4. wait与sleep的区别
- 5. 串行与并行
- 5.1 串行模式
- 5.2 并行模式
- 6. 并行与并发
- 7. 管程的概念
- 8. 用户线程与守护线程
在Java中,线程部分是一个重点,本篇文章说的JUC也是关于线程的。JUC就是java.util.concurrent工具包的简称。这是一个处理线程的工具包,JDK1.5开始出现的。
2. 进程和线程进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是 *** 作系统结构的基础。在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是 *** 作系统结构的基础。程序是指令、数据及其组织形式的描述,进程是程序的实体。
线程(thread)是 *** 作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。
3. 线程的状态- new:新建
- runnable:准备就绪
- blocked:阻塞
- waiting:等待
- timed_waiting:等待超时就不等了
- terminated:终结
- sleep是Thread的静态方法,wait是Object的方法,任何对象实例都能调用。
- sleep不会释放锁,它也不需要占用锁。wait会释放锁,但调用它的前提是当前线程占有锁(即代码要在synchronized中)。
- 它们都可以被interrupted方法中断。
串行表示所有任务都一一按先后顺序进行
。串行意味着必须先装完一车柴才能运送这车柴,只有运送到了,才能卸下这车柴,并且只有完成了这整个三个步骤,才能进行下一个步骤。
串行是一次只能取得一个任务,并执行这个任务
。
并行意味着可以同时取得多个任务,并同时去执行所取得的这些任务
。并行模式相当于将长长的一条队列,划分成了多条短队列,所以并行缩短了任务队列。
并发:同一时刻多个线程在访问同一个资源,多个线程对一个点。
例子:春运抢票电商秒杀…
并行:多项工作一起执行,之后再汇总
例子:泡方便面,电水壶烧水,一边撕调料倒入桶中
- 英文叫Monitor,翻译过来是监视器,就是我们平时说的锁。
- 本身是一种同步机制,保证同一个时间,只有一个线程访问被保护数据或者代码。
- jvm同步基于进入和退出,使用管程对象实现
- 用户线程:用户自定义的线程
- 守护线程:比如垃圾回收
main线程结束了,但是用户线程依旧会继续运行,jvm继续运行。
public class 用户自定义线程 {
public static void main(String[] args) {
Thread aa = new Thread(() -> {
//isDaemon():判断是否为守护线程
System.out.println(Thread.currentThread().getName() + "::" + Thread.currentThread().isDaemon());
while (true) {
}
}, "aa");
aa.start();
System.out.println(Thread.currentThread().getName() + "over");
}
}
main线程结束了,守护线程也跟着结束了,jvm结束 。
public class 用户自定义线程 {
public static void main(String[] args) {
Thread aa = new Thread(() -> {
//isDaemon():判断是否为守护线程
System.out.println(Thread.currentThread().getName() + "::" + Thread.currentThread().isDaemon());
while (true) {
}
}, "aa");
//变为守护线程
aa.setDaemon(true);
aa.start();
System.out.println(Thread.currentThread().getName() + "over");
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)