当前位置: 首页 > news >正文

一个新网站做多久才有流量转化石景山区百科seo

一个新网站做多久才有流量转化,石景山区百科seo,找个美工做淘宝网站需要多少钱,官方网站找做化妆品套盒子2019独角兽企业重金招聘Python工程师标准>>> 在java多线程程序中,所有线程都不允许抛出未捕获的checked exception(比如sleep时的InterruptedException),也就是说各个线程需要自己把自己的checked exception处理掉。这…

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

  在java多线程程序中,所有线程都不允许抛出未捕获的checked exception(比如sleep时的InterruptedException),也就是说各个线程需要自己把自己的checked exception处理掉。这一点是通过java.lang.Runnable.run()方法声明(因为此方法声明上没有throw exception部分)进行了约束。但是线程依然有可能抛出unchecked exception(如运行时异常),当此类异常跑抛出时,线程就会终结,而对于主线程和其他线程完全不受影响,且完全感知不到某个线程抛出的异常(也是说完全无法catch到这个异常)。JVM的这种设计源自于这样一种理念:“线程是独立执行的代码片断,线程的问题应该由线程自己来解决,而不要委托到外部。”基于这样的设计理念,在Java中,线程方法的异常(无论是checked还是unchecked exception),都应该在线程代码边界之内(run方法内)进行try catch并处理掉.换句话说,我们不能捕获从线程中逃逸的异常。
看下面的例子:

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;public class ExceptionThread implements Runnable {@Overridepublic void run() {throw new RuntimeException("这个线程就干了这么一件事,抛出一个运行时异常");}public static void main(String[] args) {try {ExecutorService exec = Executors.newCachedThreadPool();exec.execute(new ExceptionThread());System.out.println("该干嘛干嘛去");} catch (RuntimeException e) {System.out.println("能不能捕获到异常?");}}}

运行结果:

该干嘛干嘛去
Exception in thread "pool-1-thread-1" java.lang.RuntimeException: 这个线程就干了这么一件事,抛出一个运行时异常at ExceptionThread.run(ExceptionThread.java:8)at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)at java.lang.Thread.run(Thread.java:619)

从运行结果中,我们可以看到的是,这个异常在main线程中没有catch到,即System.out.println("能不能捕获到异常?");永远不会执行到。问题来了,我们如果需要捕获其线程的unchecked异常时该怎么办?Java SE5之后,我们可以通过Executor来解决这个我问题。为了解决这个问题,我们需要修改Executor产生线程的方式。Thread.UncaughtExceptionHandler是java SE5中的新接口,它允许我们在每一个Thread对象上添加一个异常处理器。(UncaughtExceptionHandler)。Thread.UncaughtExceptionHandler.uncaughtException()方法会在线程因未捕获的异常而面临死亡时被调用。下面这个例子简单的演示了如何使用UncaughtExceptionHandler

public class ExceptionThread2 implements Runnable {@Overridepublic void run() {Thread t = Thread.currentThread();System.out.println("run() by" + t);System.out.println("eh=" + t.getUncaughtExceptionHandler());throw new RuntimeException("抛出运行时异常");}
}
import java.lang.Thread.UncaughtExceptionHandler;/*** 用于捕获异常---捕获的是uncheckedException* * @author February30th* */
public class MyUnchecckedExceptionhandler implements UncaughtExceptionHandler {@Overridepublic void uncaughtException(Thread t, Throwable e) {System.out.println("捕获到异常:" + e);}}
import java.util.concurrent.ThreadFactory;public class HandlerThreadFactory implements ThreadFactory {@Overridepublic Thread newThread(Runnable r) {System.out.println("创建一个新的线程");Thread t = new Thread(r);t.setUncaughtExceptionHandler(new MyUnchecckedExceptionhandler());System.out.println("eh121 = " + t.getUncaughtExceptionHandler());return t;}}
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;public class ThreadExceptionTest {/*** @param args*/public static void main(String[] args) {//下面有3中方式来执行线程。//第1种按照普通的方式。这是能捕获到异常Thread t = new Thread(new ExceptionThread2());t.setUncaughtExceptionHandler(new MyUnchecckedExceptionhandler());t.start();//第2种按照现成池,直接按照thread方式,此时不能捕获到异常,为什么呢?因为在下面代码中创建了一个线程,且设置了异常处理器,//但是呢,在我们线程池中会重设置新的Thread对象,而这个Thread对象没有设置任何异常处理器,换句话说,我们在线程池外对线程做的//任何操作都是没有用的ExecutorService exec1 = Executors.newCachedThreadPool();Runnable runnable = new ExceptionThread2();Thread t1 = new Thread(runnable);t1.setUncaughtExceptionHandler(new MyUnchecckedExceptionhandler());exec1.execute(runnable);//第3种情况一样的,也是走的线程池,但是呢是通过ThreadFactory方式,在ThreadFactory中会对线程做一些控制,可以设置异常处理器//此时是可以捕获异常的。ExecutorService exec = Executors.newCachedThreadPool(new HandlerThreadFactory());exec.execute(new ExceptionThread2());}}

运行结果

创建一个新的线程
eh121 = MyUnchecckedExceptionhandler@1b8e059
run() byThread[Thread-0,5,main]
eh=MyUnchecckedExceptionhandler@1b8e059
捕获到异常:java.lang.RuntimeException: 抛出运行时异常

从上述的运行结果中可以看到,未捕获的异常是通过uncaughtException来捕获的。

按照上述的实例,我们可以按照具体的情况,逐个地设置处理器。但是如果我们知道将要在代码的所有地方都是用相同的异常处理器,那么更简单的方式是在Thread类中设置一个静态域,并将这个处理器设置为默认的未捕获异常处理器。看下面的例子:

Thread.setDefaultUncaughtExceptionHandler(new MyUnchecckedExceptionhandler());ExecutorService exec = Executors.newCachedThreadPool(new HandlerThreadFactory());exec.execute(new ExceptionThread2());

这个默认的处理器只有在线程不存在非默认的异常处理器时才会调用。 在运行时,系统会检查线程是否有属于自己的异常处理器,如果发现没有,就去检查相应的线程组是否有专有的异常处理器,如果发现也没有,再调用默认的异常处理器。

 

 

转载于:https://my.oschina.net/LucasZhu/blog/1377184

http://www.lbrq.cn/news/2375659.html

相关文章:

  • 我需要把网站做软文推广模板
  • 做网站怎样快速收录手机一键优化
  • 制作网站的固定成本浙江短视频seo优化网站
  • 前端主要学些什么百度网站优化方案
  • 南京哪家网络公司做网站优化好南昌seo优化公司
  • 教育中介公司网站建设费用绍兴seo优化
  • 网站开发运营公司夸克搜索网页版
  • 武汉洪山区做网站的公司安徽seo优化规则
  • 网站备案进度百度账号注册
  • 昆明公司做网站seo精准培训课程
  • 网站开发语安卓优化大师官方版本下载
  • 重庆技术网站建设网站内部链接优化方法
  • 网站建设行业解决方案新媒体口碑营销案例
  • 做海外正品代购的十个网站免费网站在线观看人数在哪
  • 专业做网站哪里有营销软文广告
  • 政府网站建设服务商最新舆情信息网
  • 怎么提高自己网站的知名度广州seo诊断
  • 郑州网站seo优化希爱力双效片用后感受
  • 做料理网站关键词怎么设置发布软文的平台
  • 上海自助建站 上海网站建设拉新推广赚钱的app
  • 找工作平台网站深圳互联网公司排行榜
  • 广告联盟没有网站怎么做廊坊关键词排名首页
  • 网站流量超seo外链发布软件
  • seo发展前景怎么样啊玉溪seo
  • 下城区网站建设价格查询seo百度快速排名
  • 化妆品网站源码asp北京中文seo
  • 网站的营销推广百度推广在哪里能看到
  • 全国做网站找哪家好网络广告策划案
  • 如何做网站支付链接今日军事新闻最新消息新闻报道
  • 嘉兴手机端建站模板seo服务外包客服
  • 零基础入门:用C++从零实现TCP Socket网络小工具
  • mongodb-org-mongos : Depends: libssl1.1 (>= 1.1.1) but it is not installable
  • React事件处理
  • 深度学习之反向传播
  • 消息中间件(Kafka VS RocketMQ)
  • DHTMLX Suite 9.2 重磅发布:支持历史记录、类Excel交互、剪贴板、拖放增强等多项升级