线程、进程、jvm、分布式锁的联系和区别

参考链接:https://blog.csdn.net/Noreaday/article/details/80343736

理解的结论:

            一个进程可以拥有多个线程。

            一个程序可以有多个进程(多次执行,也可以没有进程,不执行)

            一台机器上可以有多个JVM实例(也可以没有JVM实例)

            进程是指一段正在执行的程序

            线程是程序执行的最小单位。

            通过多次执行一个程序可以有多个进程,通过调用一个进程可以有多个程序。

        程序运行时,会首先建立一个JVM实例----------所以说,JVM实例是多个的,每个运行的程序对应一个JVM实例。每个java程序都运行在一个单独的JVM实例上,(new创建实例,存放在堆空间),所以说一个java程序的多个线程,共享堆内存。

总的来说,操作系统的执行单元是进程,每一个JVM实例就是一个进程,而在该实例上运行的主程序是一个主线程(可以看成一个轻量级的进程),该程序下还存在很多线程。

事实上在执行java程序时,我们注意到命令行为“java xxx”,其实java就是实例化jvm实例的命令。所以当一个程序中调用了另一个程序时,并没有再次加载一个新的JVM实例,只是认为调用了一个方法而已。

 

 

结论:一个进程可以包括多个线程,在一个程序中使用了多线程那么使用本地锁就可以解决多线程问题,因为这时候就一个进程也就一个jvm;

           同一台服务器可以有多个jvm,一个进程也就会运行在一个jvm上,一个进程也就会开启一个端口号,换句话说,有多少个端口号就会有多少个jvm。同一台服务器,分布式部署同一份程序,虽然是伪分布式,但是端口号不同,这是就需要使用分布式锁解决冲突的问题,不同服务器分布式部署同一份程序,也要使用分布式锁解决问题。

    (以上观点只是本人总结所得,不一定正确,不喜勿喷)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值