摘要: 一:概念 在多线程并发访问的情况下,为了解决线程安全,一般我们会使用synchronized关键字,如果并发访问量不是很大,可以使用synchronized, 但是如果数据量比较大,我们可以考虑使用ThreadLocal,顾名思义,就是线程的本地存储,对于类中的成员变量,如果多个线程同时访问 就会存 阅读全文
posted @ 2017-09-16 22:59 warrior1234 阅读(283) 评论(0) 推荐(0) 编辑
摘要: 一:概念 生产者消费者模式是java并发编程中很经典的并发情况,首先有一个大的容器,生产者put元素到 容器中,消费者take元素出来,如果元素的数量超过容器的容量时,生产者不能再往容器中put元素 ,处于阻塞状态,如果元素的数量等于0,则消费者不能在从容器中take数据,处于阻塞状态。 二:示例 阅读全文
posted @ 2017-09-16 21:29 warrior1234 阅读(287) 评论(0) 推荐(0) 编辑
摘要: 一:概念 线程通信中经常用到wait和notify,顾名思义,wait即让当前线程处于等待状态,notify通知锁对象 上的另一个线程被唤醒,这里的唤醒是指可以去争夺锁资源,nofityAll是唤醒该对象上面所有处于 wait状态的线程 二:示例 线程t2一运行就处于wait等待状态,然后线程t1运 阅读全文
posted @ 2017-09-16 18:37 warrior1234 阅读(971) 评论(0) 推荐(0) 编辑
摘要: 一:概念 volatile关键字是一个轻量级的线程同步,它可以保证线程之间对于共享变量的同步,假设有两个线程a和b, 它们都可以访问一个成员变量,当a修改成员变量的值的时候,要保证b也能够取得成员变量最新的值,程序的 内存模型是这样的,程序运行时,成员变量的值被加载到内存中,如果线程a运行时,会把变 阅读全文
posted @ 2017-09-16 17:46 warrior1234 阅读(333) 评论(0) 推荐(0) 编辑