摩尔定律失效。
面试更有底气,充分利用多核处理器的优势,提高程序性能,提高程序吞吐量,完成异步+回调等生产需求。
线程安全问题、线程锁问题、线程性能问题。
public class Test {
public static void main(String[] args) {
new Thread(() -> {
System.out.println("Test.main");
}, "myThread").start();
}
}
Java最底层的native方法,是由C++实现的,可以到openjdk查看,下载地址在这里,我们需要关注的目录是:openjdk\src\hotspot\share\runtime。
Java线程通过start方法启动执行,主要内容在native的start0()
里,OpenJDK中Thread.java对应的就是Thread.c,start0就是JVM_StartThread。
synchronized。
某一时刻,在同一实体上的多个事件,在一台处理器上同时处理多个任务。
某一时刻,在不同实体上的多个事件,在不同处理器上同时处理多个任务。
简单的说,在系统中运行的一个应用程序就是一个进程,每一个进程都有它自己的内存空间和系统资源。
也被称为轻量级进程,在同一个进程内会有1个或多个线程,是大多数操作系统进行时序调度的基本单元。
俗称Monitor(监视器),是我们平时所说的锁,比如synchronized锁。
Monitor其实是一种同步机制,它的义务是保证同一时间只有一个线程可以访问被保护的数据和代码,JVM中同步是基于进入和退出监视器对象来实现的,每个对象实例都有一个Monitor对象。Monitor对象和Java对象一同创建并销毁,底层由C++实现。
默认情况下,指的都是用户线程。
是系统的工作线程,它会完成这个程序需要完成的业务操作。
是一种特殊的线程,是为其它线程服务的,在后台默默地完成一些系统性的服务,比如:垃圾回收线程。
守护线程作为一个服务线程,没有服务对象就没有必要继续运行了,如果用户线程全部结束了,意味着程序需要完成的业务操作已经结束了,系统可以退出了,所以假如当系统只剩下守护线程的时候,Java虚拟机会自动退出。
通过java.lang.Thread#isDaemon
方法判断是否是守护线程。
public class Test {
public static void main(String[] args) {
Thread myThread = new Thread(() -> {
System.out.println(Thread.currentThread().getName() + ":" + (Thread.currentThread().isDaemon() ? "守护线程" : "用户线程"));
while(true);
}, "myThread");
myThread.setDaemon(true);
myThread.start();
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + "线程结束");
}
}
留意myThread.setDaemon(true);
语句,当myThread是用户线程的时候,main线程结束,但是myThread还在运行,当myThread是守护线程的时候,main线程结束,此时已经没有其他用户线程了,所以myThread也会结束。
如果用户线程全部结束意味着程序需要完成的业务操作已经结束了,守护线程随着JVM一同结束工作,setDaemon(true)
方法必须在start()
之前设置,否则报IllegalThreadStateException
异常。