Java 并行程序基础

来源:互联网 发布:iis php mysql 编辑:程序博客网 时间:2024/05/21 10:07

1.线程中断

主要有三个方法:public void Thread.interrupt()    // 中断线程 

                                public boolean Thread.isInterrupted()    //判断是否非中断

                                public static boolean Thread.interrupted()  // 判断是否被中断,并清除当前中断状态

Thread.sleep() 函数:让当前线程休眠若干时间,会抛出InteeruptedException中断异常,必须捕获并处理,由中断抛出异常,会清楚中断标志位


2.等待(wait)和通知(notify):当一个线程调用wait()方法后,当前线程就会在这个对象上等待,进入等待队列。当notify()方法被调用,从等待队列随机选择一个线程唤醒,notifyAll()方法唤醒等待队列中所有的线程。必须包含在synchrozied语句中,都需要首先获得目标对象的一个监视器。与sleep()方法主要区别是wait()方法会释放目标对象的锁。

3. volatile() 保证操作的原子性,可见性,有序性。但是无法保证一些复合操作部的原子性


4.synchronized的作用是实现线程的同步,对同步的代码加锁,使每一次只能有一个线程进入同步块,他是不公平的锁。

   (1) 指定加锁对象:给对象加锁,进入同步对象之前要获得给定对象的锁。

   (2)直接作用于实例方法:进入同步代码前要或的当前实例的锁

   (3)直接作用于静态方法:进入同步块前要获得当前类的锁。

5. 同时有几种线程不安全的列表:ArrayList,HashMap等都是线程不安全的。

 6.其他的几种同步控制方法:

   (1) 重入锁Reentrantlock,可以被中断,锁申请等待限时,公平锁.主要方法:lock():获得锁,如果锁已经被占用,则等待。lockInterruptibly():获得锁,但优先响应中断。tryLock():尝试获得锁,该方法不等待,立即返回。tryLock(long time,TimeUnit unit) 在给定时间内尝试获得锁。unlock():释放锁。

                               

  7.提高锁的 性能几种方法:

1.减小锁粒度:缩小锁定对象的范围,从而减小锁冲突的可能  

2.减小锁持有的时间

3.读写分离锁来替换独占锁:读多写少可以有效提升性能

4.锁分离

5:锁粗化:在遇到一连串地对锁进行请求和释放的操作时,便把所有的锁操作整合成对锁的一次请求。

6:锁偏向:如果一个线程获得了锁,那马就进入偏向模式,当这个线程子再次请求,无须在做任何同步操作。  

8.比较交换(CAS):无锁

    

原创粉丝点击