一、进程与线程

  1. 进程
    进程是操作系统资源分配的单位 例:I/O资源,内存资源…
  2. 线程
    线程是资源调度的单位,真正执行的指令 例:操作数据的执行流
    在Java内存模型中:
    线程共享的:方法区、堆区
    线程私有的:虚拟机栈、本地方法栈、程序计数器
  3. 进程和线程的关系
    进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,
    线程只是一个进程中的不同执行路径,有自己的堆栈和局部变量,但线程之间没有单独的地址空间,一个线程死掉就等于整个进程死掉,
    所以多进程的程序要比多线程的程序健壮,但在进程切换时,耗费资源较大,效率要差一些。
    但对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,不能用进程。
  1. 一个程序至少有一个进程,一个进程至少有一个线程.
  2. 线程的划分尺度小于进程,使得多线程程序的并发性高。
  3. 进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率。
  4. 线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。
  5. 从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。 但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配。
  1. Java中启动main方法是进程还是线程?
    Java中main方法启动的是一个进程也是一个主线程,main方法里面的其他线程均为子线程,是一个线程也是一个进程,一个java程序启动后它就是一个进程,进程相当于一个空盒(分配了内存空间、JVM虚拟机实例)。它只提供资源装载的空间,具体的调度并不是由进程来完成的,而是由线程来完成的。
    一个java程序从main开始之后,进程启动,为整个程序提供各种资源,而此时将启动一个线程,这个线程就是主线程,它将调度资源,进行具体的操作。Thread、Runnable的开启的线程是主线程下的子线程,是父子关系,此时该java程序即为多线程的,这些线程共同进行资源的调度和执行。
  2. 多线程编程的好处?
    在多线程程序中,多个线程被并发的执行以提高程序的效率, CPU不会因为某个线程需要等待资源而进入空闲状态。
    多个线程共享堆内存(heap memory),因此创建多个线程去执行一些任务会比创建多个进程更好
  3. Java线程与操作系统之间的关系
    Java中创建的进程和线程最终会映射到本地操作系统的进程、线程模型上
    windows的进程线程模型和Linux的进程线程模型不一致
  4. 进程间的通讯方式

1).管道通信、消息队列、信号量
在内核空间建搞出一块内存来,你写了我能看见,我写了你也能看见。
进程不在一个地址空间中,共享内核空间,所以通信复杂 ,
同一个进程的所有线程都在一个地址空间中,共享堆和数据段,通信非常方便

2)共享内存
进程1 =》 自己的虚拟地址空间 =》(多级页表映射) 映射的是物理内存块3
进程2 =》 自己的虚拟地址空间 =》(多级页表映射) 映射的是物理内存块3
最终多个进程映射带同一块物理内存上去了