摘要:上次是说到了多线程的创建和状态乐字节,接下来,我们再来接着说多线程同步和线程通信生产者消费者模式。另一方面,线程通信使线程能够等待其他线程的信号。
大家伙周末愉快,小乐又来给大家献上技术大餐。上次是说到了Java多线程的创建和状态|乐字节,接下来,我们再来接着说Java多线程-同步:synchronized 和线程通信:生产者消费者模式。
一、同步:synchronized多个线程同时访问一个对象,可能造成非线程安全,数据可能错误,所谓同步:就是控制多个线程同时访就是控制多线程操作同一个对象时,注意是同一个对象,数据的准确性, 确保数据安全,但是加入同步后因为需要等待,所以效率相对低下。
如:一个苹果,自己一个人去咬怎么都不会出问题,但是多个人同时去咬,这个时候如果控制不好,就可能会咬到对方了。 再强调一下是一个苹果。
12306 中的火车票,为什么抢到票时,需要等待,锁定席位才付款?这就是确保一张票只能一个人去购买。
1、同步块synchronized +块:同步块
synchronized (引用类型|对象|类.class) {
}
2、同步方法修饰符 synchronized 返回类型|void 方法签名{
}
3、死锁过多的同步容易死锁
/** * 死锁:容易造成死锁 * @author Administrator * */ public class TestDeadLock { /** * @param args */ public static void main(String[] args) { Object obj1 =new Object(); Object obj2 =new Object(); new A(obj1,obj2).start(); new B(obj1,obj2).start(); } } class A extends Thread{ Object obj1 ; Object obj2; public A() { } public A(Object obj1, Object obj2) { super(); this.obj1 = obj1; this.obj2 = obj2; } @Override public void run() { synchronized(obj1){ try { Thread.sleep(200); } catch (InterruptedException e) { e.printStackTrace(); } synchronized(obj2){ } } System.out.println("给我烟"); } } class B extends Thread{ Object obj1 ; Object obj2; public B() { } public B(Object obj1, Object obj2) { super(); this.obj1 = obj1; this.obj2 = obj2; } @Override public void run() { synchronized(obj2){ try { Thread.sleep(100); } catch (InterruptedException e) { e.printStackTrace(); } synchronized(obj1){ } } System.out.println("给我钱"); } }二、线程通信:生产者消费者模式
线程通信的目标是使线程间能够互相发送信号。另一方面,线程通信使线程能够等待其
他线程的信号。
Java 有一个内建的等待机制来允许线程在等待信号的时候变为非运行状态。
java.lang.Object 类定义了三个方法,wait()、notify()和 notifyAll()来实现这个等待机制。一个线程一旦调用了任意对象的 wait()方法,就会变为非运行状态,直到另一个线程调用了同一个对象的 notify()方法。为了调用 wait()或者 notify(),线程必须先获得那个对象的锁。也就是说,线程必须在同步块里调用 wait()或者 notify()。
以下为一个使用了 wait()和 notify()实现的线程间通信的共享对象:
/** * 街道 * @author Administrator * */ public class Street { //红绿灯 //false 红灯 -->人等 车走 -->换灯 通知人走 //true 绿灯 -->车等 人走 -->换灯 通知车走 private boolean flag=false; //东西向 -->人道 public synchronized void west(){ if(flag==false){ try { this.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } try { Thread.sleep(500); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("东西向-->人走"); //换灯 this.flag =false; this.notify(); //唤醒等待者 } //南北向 车道 public synchronized void north(){ if(flag==true){ try { this.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } try { Thread.sleep(200); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("南北向-->车走"); //换灯 this.flag =true; this.notify(); //唤醒等待者 } } class Person extends Thread { private Street s ; public Person(Street s) { this.s = s; } public void run() { for(int i=0;i<10;i++){ s.west(); //东西向 } } } class Car extends Thread { private Street s ; public Car(Street s) { this.s = s; } public void run() { for(int i=0;i<10;i++){ s.north(); } } }
Java多线程的同步和线程通信就介绍到这里,更多技术干货请关注乐字节。乐字节原创!
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/76034.html
摘要:本文对多线程基础知识进行梳理,主要包括多线程的基本使用,对象及变量的并发访问,线程间通信,的使用,定时器,单例模式,以及线程状态与线程组。源码采用构建,多线程这部分源码位于模块中。通知可能等待该对象的对象锁的其他线程。 本文对多线程基础知识进行梳理,主要包括多线程的基本使用,对象及变量的并发访问,线程间通信,lock的使用,定时器,单例模式,以及线程状态与线程组。 写在前面 花了一周时...
摘要:程序执行时,至少会有一个线程在运行,这个运行的线程被称为主线程。程序的终止是指除守护线程以外的线程全部终止。多线程程序由多个线程组成的程序称为多线程程序。线程休眠期间可以被中断,中断将会抛出异常。 线程 我们在阅读程序时,表面看来是在跟踪程序的处理流程,实际上跟踪的是线程的执行。 单线程程序 在单线程程序中,在某个时间点执行的处理只有一个。 Java 程序执行时,至少会有一个线程在运行...
摘要:典型地,和被用在等待另一个线程产生的结果的情形测试发现结果还没有产生后,让线程阻塞,另一个线程产生了结果后,调用使其恢复。使当前线程放弃当前已经分得的时间,但不使当前线程阻塞,即线程仍处于可执行状态,随时可能再次分得时间。 1、说说进程,线程,协程之间的区别 简而言之,进程是程序运行和资源分配的基本单位,一个程序至少有一个进程,一个进程至少有一个线程.进程在执行过程中拥有独立的内存单元...
摘要:下面是线程相关的热门面试题,你可以用它来好好准备面试。线程安全问题都是由全局变量及静态变量引起的。持有自旋锁的线程在之前应该释放自旋锁以便其它线程可以获得自旋锁。 最近看到网上流传着,各种面试经验及面试题,往往都是一大堆技术题目贴上去,而没有答案。 不管你是新程序员还是老手,你一定在面试中遇到过有关线程的问题。Java语言一个重要的特点就是内置了对并发的支持,让Java大受企业和程序员...
摘要:提供了多线程升级方案将同步替换成了显示的操作。线程间通信接口可以替代传统的线程间通信,用替换,用替换,用替换。商品执行上述代码,观察结果可以看到,多个线程同时生产消费,由于指定唤醒互异线程,因此并不会引起错误。 JDK 1.5提供了多线程升级方案将同步synchronized替换成了显示的Lock操作。可以实现唤醒、冻结指定的线程。 Lock接口Lock 实现提供了比使用 synchr...
阅读 2954·2021-09-22 15:18
阅读 3375·2019-08-30 15:54
阅读 3244·2019-08-30 15:53
阅读 547·2019-08-30 14:12
阅读 791·2019-08-29 17:01
阅读 2181·2019-08-29 14:04
阅读 1358·2019-08-29 13:09
阅读 837·2019-08-26 17:40