多线程
进程:一个启动的应用程序(进程A与进程B的内存独立不共享)
线程:一个进程的执行场景/单元(线程A与线程B的内存可能共享,也可能独立)
例如在Java语言中,堆内存和方法区内存共享(因为其内存空间是固定的);但占栈内存独立,一个线程一个栈,每个栈之间互不干扰,即每个线程之间互不干扰,此即为多线程并发。
java中的多线程机制,目的是提高程序的处理效率。单线程处理速度慢。
一个进程中可以启动多个线程。
main方法结束不代表所有线程结束,只代表主线程结束
多线程并发
多核CPU可以做到多线程并发
单核CPU不可以做到真正的多线程并发,但可以做到给人一种多线程并发的感觉。单核CPU在一个时间点实际上只能处理一件事情,但由于CPU的处理速度极快,因此多个线程之间频繁切换执行,几乎等同于多个线程并发执行。
java语言中,实现线程有两种方式:
方式1:编写一个类直接继承Thread ,重写run方法
方式2:编写一个类,实现接口Runnable接口
方式3:匿名内部类实现Runnable接口。此方法存在只能创建一个进程的缺陷
综上,方法2 最为适合