摘要: 生产者消费者问题是线程模型中的经典问题:生产者和消费者在同一时间段内共用同一存储空间,生产者向空间里生产数据,而消费者取走数据。 ​ 这里实现如下情况的生产 消费模型: ​ 生产者不断交替地生产两组数据“姓名 1 内容 1”,“姓名 2 内容 2”,消费者不断交替地取得这两组数据,这里的“姓名 1” 阅读全文
posted @ 2018-04-11 16:58 zailushang1996 阅读(147) 评论(0) 推荐(0) 编辑
摘要: 如果线程在等待时接到通知,但线程等待的条件还不满足,此时,线程接到的就是早期通知,如果条件满足的时间很短,但很快又改变了,而变得不再满足,这时也将发生早期通知。这种现象听起来很奇怪,下面通过一个示例程序来说明问题。 ​ 很简单,两个线程等待删除List中的元素,同时另外一个线程正要向其中添加项目。代 阅读全文
posted @ 2018-04-11 16:03 zailushang1996 阅读(127) 评论(0) 推荐(0) 编辑
摘要: notify通知的遗漏很容易理解,即threadA还没开始wait的时候,threadB已经notify了,这样,threadB通知是没有任何响应的,当threadB退出synchronized代码块后,threadA再开始wait,便会一直阻塞等待,直到被别的线程打断。 遗漏通知的代码 ​ 下面给 阅读全文
posted @ 2018-04-11 15:37 zailushang1996 阅读(223) 评论(0) 推荐(0) 编辑
摘要: 在Java中,可以通过配合调用Object对象的wait()方法和notify()方法或notifyAll()方法来实现线程间的通信。在线程中调用wait()方法,将阻塞等待其他线程的通知(其他线程调用notify()方法或notifyAll()方法),在线程中调用notify()方法或notify 阅读全文
posted @ 2018-04-11 15:33 zailushang1996 阅读(140) 评论(0) 推荐(0) 编辑
摘要: 当线程需要同时持有多个锁时,有可能产生死锁。考虑如下情形: ​ 线程A当前持有互斥所锁lock1,线程B当前持有互斥锁lock2。接下来,当线程A仍然持有lock1时,它试图获取lock2,因为线程B正持有lock2,因此线程A会阻塞等待线程B对lock2的释放。如果此时线程B在持有lock2的时候 阅读全文
posted @ 2018-04-11 15:16 zailushang1996 阅读(167) 评论(0) 推荐(0) 编辑
摘要: 在集合API中,最初设计的Vector和Hashtable是多线程安全的。例如:对于Vector来说,用来添加和删除元素的方法是同步的。如果只有一个线程与Vector的实例交互,那么,要求获取和释放对象锁便是一种浪费,另外在不必要的时候如果滥用同步化,也有可能会带来死锁。因此,对于更改集合内容的方法 阅读全文
posted @ 2018-04-11 15:10 zailushang1996 阅读(116) 评论(0) 推荐(0) 编辑
摘要: 在并发编程中,多线程同时并发访问的资源叫做临界资源,当多个线程同时访问对象并要求操作相同资源时,分割了原子操作就有可能出现数据的不一致或数据不完整的情况,为避免这种情况的发生,我们会采取同步机制,以确保在某一时刻,方法内只允许有一个线程。 ​ 采用synchronized修饰符实现的同步机制叫做互斥 阅读全文
posted @ 2018-04-11 14:59 zailushang1996 阅读(471) 评论(0) 推荐(0) 编辑
摘要: Java中实现多线程有两种方法:继承Thread类、实现Runnable接口,在程序开发中只要是多线程,肯定永远以实现Runnable接口为主,因为实现Runnable接口相比继承Thread类有如下优势: ​ 1、可以避免由于Java的单继承特性而带来的局限; ​ 2、增强程序的健壮性,代码能够被 阅读全文
posted @ 2018-04-11 14:21 zailushang1996 阅读(235) 评论(0) 推荐(0) 编辑
摘要: volatile用处说明 ​ 在JDK1.2之前,Java的内存模型实现总是从主存(即共享内存)读取变量,是不需要进行特别的注意的。而随着JVM的成熟和优化,现在在多线程环境下volatile "关键字" 的使用变得非常重要。 在当前的Java内存模型下, "线程" 可以把 "变量" 保存在本地内存 阅读全文
posted @ 2018-04-11 14:17 zailushang1996 阅读(493) 评论(0) 推荐(0) 编辑
摘要: 守护线程 Java中有两类线程:User Thread(用户线程)、Daemon Thread(守护线程) ​ 用户线程即运行在前台的线程,而守护线程是运行在后台的线程。 守护线程作用是为其他前台线程的运行提供便利服务,而且仅在普通、非守护线程仍然运行时才需要,比如垃圾回收线程就是一个守护线程。当V 阅读全文
posted @ 2018-04-11 13:53 zailushang1996 阅读(150) 评论(0) 推荐(0) 编辑
摘要: 挂起和恢复线程 ​ Thread 的API中包含两个被淘汰的方法,它们用于临时挂起和重启某个线程,这些方法已经被淘汰,因为它们是不安全的,不稳定的。如果在不合适的时候挂起线程(比如,锁定共享资源时),此时便可能会发生死锁条件——其他线程在等待该线程释放锁,但该线程却被挂起了,便会发生死锁。另外,在长 阅读全文
posted @ 2018-04-11 13:44 zailushang1996 阅读(782) 评论(0) 推荐(0) 编辑
摘要: 【Java并发编程】之二:线程中断 使用interrupt()中断线程 ​ 当一个线程运行时,另一个线程可以调用对应的Thread对象的interrupt()方法来中断它,该方法只是在目标线程中设置一个标志,表示它已经被中断,并立即返回。这里需要注意的是,如果只是单纯的调用interrupt()方法 阅读全文
posted @ 2018-04-11 13:40 zailushang1996 阅读(196) 评论(0) 推荐(0) 编辑