线程同步与死锁马剑威第121讲课程大纲1、多线程共享数据2、线程同步3、同步准则4、线程死锁1、多线程共享数据•在多线程的操作中,多个线程有可能同时处理同一个资源,这就是多线程中的共享数据。2、线程同步•解决数据共享问题,必须使用同步,所谓同步就是指多个线程在同一个时间段内只能有一个线程执行指定代码,其他线程要等待此线程完成之后才可以继续执行。•线程进行同步,有以下两种方法:•(1)同步代码块•synchronized(要同步的对象){•要同步的操作;•}•(2)同步方法•publicsynchronizedvoidmethod(){•要同步的操作;•}3、同步准则•当编写synchronized块时,有几个简单的准则可以遵循,这些准则在避免死锁和性能危险的风险方面大有帮助:•(1)使代码块保持简短。把不随线程变化的预处理和后处理移出synchronized块。•(2)不要阻塞。如InputStream.read()。•(3)在持有锁的时候,不要对其它对象调用方法。4、线程死锁•过多的同步有可能出现死锁,死锁的操作一般是在程序运行的时候才有可能出现。•多线程中要进行资源的共享,就需要同步,但同步过多,就可能造成死锁谢谢Thanks