volatile:是Java虚拟机提供的轻量级的同步机制

  1. volatile:是Java虚拟机提供的轻量级的同步机制 
    1.   1、保证可见性
    2.     2、不保证原子性
    3.     3、禁止指令重排
  2. ArrayList是线程不安全的集合,如何变成线程安全的呢
    1. new vector<>() ;  这个是jdk1.0开始的,ArrayList是jdk1.2开始,相比arraylist在add()方法加了synchrized
    2. Collections.synchronizedList(new ArrayList<>())
    3. new CopyOnWriteArrayList<>()
      public boolean add(E e) {
      final ReentrantLock lock = this.lock;
      lock.lock();
      try {
      Object[] elements = getArray();
      int len = elements.length;
      Object[] newElements = Arrays.copyOf(elements, len + 1);
      newElements[len] = e;
      setArray(newElements);
      return true;
      } finally {
      lock.unlock();
      }
      }
  3. collection是接口,list、set实现了该接口。collections是集合类,提供了集合操作相关的工具
  4. HashSet是基于HashMap实现的,通过其构造方法就可以发现,由于HashMap是key-value格式,所以系统会默认创建new Object()作为所有元素的value.
  5. 性能:硬盘< 内存 < CPU(缓存)
  6. 可重入锁(递归锁):线程可以进入任何一个它已经拥有的锁所同步着的代码块
  7. synchronized和Lock有什么区别?用新的lock有什么好处?你举例说说
    1. 原始构成
      1. synchronized是关键字,属于jvm层面。(idea 执行javap)
        • monitorenter(底层是通过monitor对象来完成, 其实wait/notify等方法也依赖于monitor对象只有在同步块或方法中才能调wait/notify等方法)
        • monitorexit
      2. lock是具体类(Java.util.concurrent.locks.lock)是api层面的锁
    2. 使用方法
      1. synchronized 不需要用户去手动释放锁,当synchronized代码执行完后系统会自动释放对锁的占用
      2. ReentrantLock则需要用户手动释放锁若没有主动释放锁,就有可能导致出现死锁现象。
        需要lock()和unlock()方法配合try/finally语句块来完成
    3. 等待是否可中断
      1. synchronized不可中断,除非抛出异常或者正常运行完成
      2. ReentrantLock 可中断,
        • 设置超时方法 trylock(long timeout, TimeUnit unit)
        • lockInterruptibly()放代码块中,调用interrupt()方法可中断
    4. 加锁是否公平
      1. synchronized非公平锁
      2. ReentrantLock两者都可以,默认是非公平锁,构造方法可以传入boolean值, true为公平锁, false为非公平锁
    5. 锁绑定多个条件condition
      1. synchronized 没有
      2. ReentrantLock用来实现分组唤醒需要唤醒的线程们,可以精确唤醒,而不是像synchronized要么随机唤醒一个, 要么唤醒全部线程
  8. 接口继承接口用extends关键字,用 implements 编译器会提示报错

留下评论

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理