首页 > 编程语言 > 详细

io 线程

时间:2019-03-02 17:39:33      阅读:289      评论:0      收藏:0      [点我收藏+]

wait 释放锁(需配合synchronize使用)(wait 的缺点是一直在等待询问,导致性能低下。可以采用CountDownLantch 这个类的countDown()方法来解决这个问题)

notify 不释放锁(也就是说,调用notify()的时候,该线程还没释放锁,而是在该线程执行完后,才会释放这把锁)(需配合synchronize使用)

synchronize:同步锁

volatile:线程间通讯的修饰符

 CountDownLatch :用于实时通知的类(countDownLath.countDown(1)--这个1表示得执行多少次,await()才会唤醒、countDown.await() ,不需要配合synchronize使用)

-----------------------------

可重复锁:被一个锁所保护的代码,可以调用另一个使用相同的锁的方法。关键点是:相同的锁。代码如下

 public synchronized void service1(){
        System.out.println("进入锁1");
        //service1的锁还没释放,就执行了service()2,证明锁是可重入的。因为,这是统一把锁
        service2();
        System.out.println("进入锁11");
    }

    public synchronized void service2(){
        System.out.println("进入锁2");
        service3();
        System.out.println("进入锁22");
    }
    public synchronized void service3(){
        System.out.println("进入锁3");
    }

 

父类方法同步,子类重写该方法(没有synchronized关键字修饰),是没有同步作用的。

不同的锁没有互斥作用,代码如下:

class Service2 
    {
        Strign s=new String();
        public  void service(char name)
        {
            
            synchronized(s)            //这里锁住的是s对象
                {
                for (int i = 3; i >0; i--) {
                    System.out.println(name+":"+i);
                }
            }
        }
        public void service2(char name)      
        {
            synchronized(this)  {           //这里锁住的是this对象
                for (int i = 6; i >3; i--) {
                    System.out.println(name+":"+i);
                }
            }
        }
    }

 

synchronized方法和synchronized(this)代码块是锁定当前对象的(效果是一样的),代码如下:

public  void service(char name)
        {
            
            synchronized(this)
                {
                for (int i = 3; i >0; i--) {
                    System.out.println(name+":"+i);
                }
            }
        }
public synchronized void service2(char name)
        {
                for (int i = 6; i >3; i--) {
                    System.out.println(name+":"+i);
                }
        }

 

一个对象中的不同同步代码块是互斥的,执行完一个代码块再执行另一个代码块

syncronized static 同步静态方法,锁住的是Class对象(就是Class对象,没写错)

volatile对比synchronized

  • volitate增加了实例变量在对个线程之间的可见性,保证我们获得的是变量的最新值。
  • volatile在读上面保持了同步作用,但是在写上面不保持同步
  • synchronized的同步作用不仅保证了对同一个锁线程的互斥,还保证了数据的同步

 -----------------------------------------------

CycliBarrire(循环障碍)        ---场景:多个运动员比赛,只有所有运动员都准备好才能开始  ---多个线程都在阻塞

CoutDownLatch                      ---计时器 --一个线程等待(阻塞),多个线程通知他。

 

-----------------------------------------------------------------------

Excutor 的submit()和excute()方法的区别:

1、submit()可以传入实现了Callable的接口的类,也可以是实现了Runnable接口的类;而excute()只能传入实现了Runnable接口的类

2、submit()有返回值

io 线程

原文:https://www.cnblogs.com/drafire/p/10425399.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!