• Java并发编程—java多线程相关概念


    一、什么是进程?

    ​ 1、概念:是程序的一次执行过程,是系统进行资源分配和调度的独立单位,每一个进程都有它自己的内存空间和系统资源;在OS的眼里,进程就是一个担当分配系统资源CPU时间、内存的实体。

    ​ 2、说人话:电脑启动了一个软件就是开启了一个进程;

    二、什么是线程?

    ​ 1、概念:是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。

    ​ 2、说人话:在同一个进程内可以执行多个任务,而这每一个任务就可以看成是一个线程,然后真正在工作的就是这个线程,因为他就是运算调度的最小单位了;

    三、进程和线程的关系:

    ​ 一个进程会有1个或者多个线程

    四、操作系统的设计:

    ​ (1)以多进程形式,允许多个任务(qq.exe,wx.exe)同时运行;

    ​ (2)以多线程形式,允许单个任务分成不同的部分(qq.exe里面的聊天,天气,更改签名…)运行;

    ​ (3)提供协调机制,一方面防止进程之间和线程之间的冲突,另一方面允许进程之间和线程之间共享资源;

    五、java多线程运行为啥要考虑加锁?

    ​ 当多个线程同时去访问某一共享资源时,就会出现资源之间的竞争,如果没有锁机制的保证,就可能会导致数据的不一致性.

    ​ 在这里不讨论有几种锁,和如何加锁的问题,这种大家可以自行了解,主要是说一下这个锁是如何实现的;

    用普通的互斥锁synchronized举例,看看它是如何实现加锁和解锁的,在这解析之前,先分享一个新的知识点;
    七、什么是管程?有什么用?
    是什么?

    ​ 操作系统中叫Monitor(监视器),口语也就是我们平时所说的锁,java代码中是synchronized;

    有什么用?

    ​ Monitor其实是一种同步机制,它的义务是保证(同一时间)只有一个线程可以访问被保护的数据和代码;所以这个就和synchronized在我们平时使用相关联起来了;

    八、锁原理解析
    JVM中同步时基于进入和退出监视器对象(Monitor,管程对象)来实现的,每个对象实例都会有一个Monitor对象;
    Monitor对象会和java对象一同创建并销毁,底层时C++语言来实现的。

    ​ 基于上面的这句话进行解析,写一段代码

     //1、创建一个对象 同时会有一个管程对象Monitor创建
            Object o = new Object();
            new Thread(() -> {
                //2、这里{就是jvm同步进入到这个o对象的Monitor对象中,实现加锁
                synchronized (o) {
    
                //3、这里}结束就是退出Monitor对象,实现解锁
                }
            }, "t1" ).start();
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    从代码的角度,分析了在哪个地方实现了加锁和解锁

    九、总结:

    ​ Monitor就是我们常说的锁,给临界区加锁就实现了线程安全;

    ​ 执行线程就要求先成功持有管程,然后才能执行方法,最后当方法完成(无论是正常完成还是非正常完成)时释放管程。在方法执行期间,执行线程持有了管程,其他任务线程都无法再获取到同一个管程;

  • 相关阅读:
    团队协作中如何处理ConflictingBeanDefinitionException异常
    工业交换机选用技巧
    Java中,对象一定在堆中分配吗?
    如何看待PyTorch 2.0?
    Python实现面向对象版学员管理系统
    智能语音和自然语言处理技术
    Spring Boot中如何实现bean加载
    LuaHttp库写的一个简单的爬虫
    flink-cdc同步mysql数据到kafka
    【线性表,队列和栈,栈溢出,链表和顺序表的特点】
  • 原文地址:https://blog.csdn.net/qq_52545155/article/details/128129291