synchronized底层实现原理分析

说明:本文是我对自己学习知识的一个简单总结,可能存在许多不足,我希望通过此方式来回顾知识,加强理解,也希望大家能指出文中的错误与不足,互相学习,谢谢。

1.线程安全问题的出现原因

  之前说过,线程可以看作是轻量级进程,进程的上下文切换代价比较高,线程的上下文切换比较低,所以线程的出现提高了程序切换运行的时间。但是多线程的出现也引发了一些安全问题,比如:有可能会出现多个线程同时访问同一个共享、可变资源的情况,这种资源可能是:对象、变量、文件等。所以引出的问题是:由于线程执行的过程是不可控的,所以需要采用同步机制来协同对对象可变状态的访问。

共享:资源可以由多个线程同时访问
可变:资源可以在其生命周期内被修改

2.线程安全解决方案

  正因为有了上面说的多线程访问共享资源带来的线程安全问题,所以我们就要去解决这些问题,在Java中可以通过synchronized加锁的方式来解决大部分问题【这里不会介绍synchronized的具体用法,具体用法可以参考API文档等】。

  • 加锁目的:序列化访问临界资源【即同一时刻只能有一个线程访问临界资源(同步互斥访问)】。锁分类:主要分为显示锁和隐式锁。

显示锁:ReentrantLock,实现juc里Lock,实现是基于AQS实现,需要手动加锁跟解锁lock(),unlock()。
隐式锁:

你可能感兴趣的:(java基础,多线程)