为什么多线程重要?
两个方面:
1.硬件方面 摩尔定律:失效
它是由英特尔创始人之一Gordon Moore(戈登·摩尔)提出来的。其内容为:
当价格不变时,集成电路上可容纳的元器件的数目约每隔18-24个月便会增加一倍,性能也将提升一倍。
换言之,每一美元所能买到的电脑性能,将每隔18-24个月翻一倍以上。这一定律揭示了信息技术进步的速度。
可是从2003年开始CPU主频已经不再翻倍,而是采用多核而不是更快的主频。
2.软件方面:
高并发系统,异步+回调等生产需求
线程start开始:
java线程是通过start的方法启动执行的,主要内容在native方式start0中,
openJdk的写JNI一般是一一对应的,Thread.java对应的就是Thread.c
start0其实就是JVM_StartThread, 看源代码可以看到在jvm.h中找到了声明,jvm.cpp中有实现。
进程:
是程序的一次执行,是系统进行资源分配和调度的独立单位,每一个进程都有它自己的内存空间和系统资源
线程:
在同一个进程内又可以执行多个任务,而这每一个任务我们就可以看做是一个线程
一个进程会有1个或多个线程
操作系统的设计,因此可以归结为三点:
- 以多进程形式,允许多个任务同时运行
- 以多线程形式,允许单个任务分成不同的部分运行
- 提供协调机制,一方面防止进行之间和线程之间产生冲突,另一方面允许进程之间和线程之间共享资源
管程:
Monitor监视器,也就是我们平时所说的锁,
Monitor其实是一种同步机制,她的义务是保证(同一时间)只有一个线程可以访问被保护的数据和代码
JVM中同步时基于进入和退出监控器对象(Monitor,管程对象)来实现的,每个对象实例都会有一个Monitor对象
Monitor对象会和Java对象一同创建并销毁,它底层是有C++语言实现的。
执行线程就要求先持有管程,然后才能执行方法,最后方法完成(无论是正常完成还是非正常完成)时释放管程。
在方法执行期间,执行线程持有了管程,其他任何线程都无法再获取到同一个管程
用户线程和守护线程:
java线程分为用户线程和守护线程
线程的Daemon属性为true表示守护线程,false表示用户线程
守护线程 是一种特殊的线程,在后台默默的完成一些系统性的服务,比如垃圾回收线程
用户线程是系统的工作线程,它会完成这个程序需要完成的业务操作
当程序中所有用户线程执行完毕之后,不管守护线程是否结束,系统都会自动退出,
设置守护线程,需要在start()方法之前进行
如果用户线程全部结束了,意味着程序需要完成的业务操作已经结束了,系统可以退出了
所以当系统只剩下守护进程的时候,java虚拟机会自动退出