Java进程与线程

1.线程与进程

1.进程是操作系统进行资源分配的基本单位。
2.线程是资源调度的单位,一个进程就是一条数据执行流。
在Java内存模型中:
线程共享的:方法区、堆区
线程私有的:虚拟机栈、本地方法栈、程序计数器

2.进程和线程的关系

1.进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响;线程只是一个进程中的不同执行路径,一个线程崩溃会导致整个进程死掉。(多进程的程序要比多线程的程序健壮,但在进程切换时,耗费资源较大,效率要差一些,在高并发下使用线程多一点)
2.一个程序至少要有一个进程,一个进程至少要有一个线程。
3.进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率。

3.进程间通信方式

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

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

4.Java中启动main方法是进程还是线程?

Java中main方法启动的是一个进程也是一个主线程,main方法里面的其他线程均为子线程,是一个线程也是一个进程,一个java程序启动后它就是一个进程,进程相当于一个空盒(分配了内存空间、JVM虚拟机实例)。它只提供资源装载的空间,具体的调度并不是由进程来完成的,而是由线程来完成的。
一个java程序从main开始之后,进程启动,为整个程序提供各种资源,而此时将启动一个线程,这个线程就是主线程,它将调度资源,进行具体的操作。Thread、Runnable的开启的线程是主线程下的子线程,是父子关系,此时该java程序即为多线程的,这些线程共同进行资源的调度和执行。

5.Java线程与操作系统之间的关系

Java中创建的进程和线程最终会映射到本地操作系统的进程、线程模型上
windows的进程线程模型和Linux的进程线程模型不一致

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值