上一页 1 ··· 9 10 11 12 13 14 15 16 17 ··· 37 下一页

2017年3月23日

java 多线程 25 :线程和线程组的异常处理

摘要: 线程中出现异常从上面代码可以看出来处理线程的异常设置异常的两种方式1.全局异常,也是静态异常,是个静态方法 , 类.setDefaultUncaughtExceptionHandler()2.对象一样,针对单个线程设置的异常,对象.setUncaughtExceptionHandler()ps:如果手动在线程内try catch了 那么就不会进入以上两种自己设置的异常了线程组异常从上面代码可以看... 阅读全文

posted @ 2017-03-23 18:06 signheart 阅读(415) 评论(0) 推荐(0) 编辑

java 多线程 26 : 线程池

摘要: 使用线程池与不使用线程池的差别先来看一下使用线程池与不适应线程池的差别,第一段代码是使用线程池的:public static void main(String[] args) { long startTime = System.currentTimeMillis(); final List l = new LinkedList(); ThreadPoolExecutor t... 阅读全文

posted @ 2017-03-23 18:06 signheart 阅读(273) 评论(0) 推荐(0) 编辑

java 多线程 22 :生产者/消费者模式 进阶 利用await()/signal()实现

摘要: java多线程15 :wait()和notify() 的生产者/消费者模式在这一章已经实现了 wait/notify 生产消费模型利用await()/signal()实现生产者和消费者模型一样,先定义一个缓冲区:public class ValueObject { public static String value = ""; }换种写法,生产和消费方法放在一个类里面:public c... 阅读全文

posted @ 2017-03-23 18:06 signheart 阅读(2446) 评论(0) 推荐(0) 编辑

java 多线程 23 : Timer

摘要: 前言定时/计划功能在Java应用的各个领域都使用得非常多,比方说Web层面,可能一个项目要定时采集话单、定时更新某些缓存、定时清理一批不活跃用户等等。定时计划任务功能在Java中主要使用的就是Timer对象,它在内部使用多线程方式进行处理,所以它和多线程技术关联还是相当大的。那和ThreadLocal一样,还是先讲原理再讲使用,Timer的实现原理不难,就简单扫一下就好了。 更多关于调度任务的请参... 阅读全文

posted @ 2017-03-23 18:06 signheart 阅读(156) 评论(0) 推荐(0) 编辑

java多线程17:ThreadLocal源码剖析

摘要: ThreadLocal源码剖析ThreadLocal其实比较简单,因为类里就三个public方法:set(T value)、get()、remove()。先剖析源码清楚地知道ThreadLocal是干什么用的、再使用、最后总结,讲解ThreadLocal采取这样的思路。 三个理论基础在剖析ThreadLocal源码前,先讲一下ThreadLocal的三个理论基础:1、每个线程都有一个自己的Thre... 阅读全文

posted @ 2017-03-23 18:05 signheart 阅读(216) 评论(0) 推荐(0) 编辑

java多线程18: ThreadLocal的作用

摘要: 从上一篇对于ThreadLocal的分析来看,可以得出结论:ThreadLocal不是用来解决共享对象的多线程访问问题的,通过ThreadLocal的set()方法设置到线程的ThreadLocal.ThreadLocalMap里的是是线程自己要存储的对象,其他线程不需要去访问,也是访问不到的。各个线程中的ThreadLocal.ThreadLocalMap以及ThreadLocal.Thread... 阅读全文

posted @ 2017-03-23 18:05 signheart 阅读(282) 评论(0) 推荐(0) 编辑

java 多线程 19: ReentrantLock 与 Condition

摘要: ReentrantLockReentrantLock,一个可重入的互斥锁,它具有与使用synchronized方法和语句所访问的隐式监视器锁相同的一些基本行为和语义,但功能更强大。ReentrantLock基本用法先来看一下ReentrantLock的基本用法:public class ThreadDomain38 { private Lock lock = new ReentrantLo... 阅读全文

posted @ 2017-03-23 18:05 signheart 阅读(152) 评论(0) 推荐(0) 编辑

java多线程20 : ReentrantLock中的方法 ,公平锁和非公平锁

摘要: 公平锁与非公平锁ReentrantLock有一个很大的特点,就是可以指定锁是公平锁还是非公平锁,公平锁表示线程获取锁的顺序是按照线程排队的顺序来分配的,而非公平锁就是一种获取锁的抢占机制,是随机获得锁的,先来的未必就一定能先得到锁,从这个角度讲,synchronized其实就是一种非公平锁。非公平锁的方式可能造成某些线程一直拿不到锁,自然是非公平的了。看一下例子,new ReentrantLock... 阅读全文

posted @ 2017-03-23 18:05 signheart 阅读(883) 评论(0) 推荐(0) 编辑

java多线程 21 : ReentrantReadWriteLock ,synchronized和ReentrantLock的对比

摘要: 读写锁ReentrantReadWriteLock概述大型网站中很重要的一块内容就是数据的读写,ReentrantLock虽然具有完全互斥排他的效果(即同一时间只有一个线程正在执行lock后面的任务),但是效率非常低。所以在JDK中提供了一种读写锁ReentrantReadWriteLock,使用它可以加快运行效率。读写锁表示两个锁,一个是读操作相关的锁,称为共享锁;另一个是写操作相关的锁,称为排... 阅读全文

posted @ 2017-03-23 18:05 signheart 阅读(332) 评论(0) 推荐(0) 编辑

java多线程15 :wait()和notify() 的生产者/消费者模式

摘要: 什么是生产者/消费者模型一种重要的模型,基于等待/通知机制。生产者/消费者模型描述的是有一块缓冲区作为仓库,生产者可将产品放入仓库,消费者可以从仓库中取出产品,生产者/消费者模型关注的是以下几个点:1、生产者生产的时候消费者不能消费2、消费者消费的时候生产者不能生产3、缓冲区空时消费者不能消费4、缓冲区满时生产者不能生产生产者/模型作为一种重要的模型,它的优点在于:1、解耦。因为多了一个缓冲区,所... 阅读全文

posted @ 2017-03-23 18:04 signheart 阅读(880) 评论(0) 推荐(0) 编辑

上一页 1 ··· 9 10 11 12 13 14 15 16 17 ··· 37 下一页

导航