仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 768|回复: 13
打印 上一主题 下一主题

[学习教程] JAVA教程之从Runnable中的运转时非常提及仓酷云

[复制链接]
因胸联盟 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-18 11:24:51 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
进而能拉拢大多数程序员用windows产品。并且从net网页编程网页编程AJAX可以跨平台这一点上,间接证明了我们的推断,至少证明了微软做过这方面的研究。所以如果哪一天突然听说了.net网页编程可以跨平台了,那么请不要吃惊,如果这一天真的到来,java就到了真正和.net网页编程决战的时刻。因为不到万不得以的时候微软是不会推出跨平台的.net网页编程的,如果跨平台的.net网页编程还不足以对抗java的话,那么微软还剩的手段就是开源了,呵呵。前段工夫,夜晚俄然收到报警,告急上线排查。因为dba操纵不妥,年夜片数据回滚,产生锁表的情形,哀求前往工夫太长,使得体系打印出大批的RejectedExecutionException的非常。定位到代码片断相似:
Java代码

  • ThreadPoolExecutorworkers=newThreadPoolExecutor(10,600,30,TimeUnit.SECONDS,newArrayBlockingQueue<Runnable>(10));
  • ShareTaskshareTask=newShareTask(shareInfo,clientId,rtnResult,
  • outerShareContext,importOuterFriend,bindingManager,shareUserManager);
  • workers.execute(shareTask);
这里就要说说ThreadPoolExecutor和ArrayBlockingQueue了,尽人皆知ArrayBlockingQueue类是一个堵塞的行列。当和ThreadPoolExecutor利用时,ThreadPoolExecutor会在初始化时开启corePoolSize(也就是下面代码中的10)个线程,往消耗行列里的task。当并发量增年夜,直到corePoolSize全都在实行task,而行列也放满了待处置的task的时分,ThreadPoolExecutor就会往创立一个新的线程。直至到达线程池中的消耗线程到达maximumPoolSize(也就是下面代码里的600)。假如这个时分再有task到场,依据默许的饱和战略,将会抛出RejectedExecutionException非常。
此次就是因为猎取数据库守候工夫超长,招致task呼应工夫变慢,继而线程池中活泼的消耗线程聚积到600个线程仍然没法对付,才抛出的RejectedExecutionException。
明显抛出RejectedExecutionException不是那末的友爱,我们在这里能够自界说饱和战略。默许体系饱和战略是抛出非常。
Java代码

  • workers.setRejectedExecutionHandler(newRejectedExecutionHandler(){
  • @Override
  • publicvoidrejectedExecution(Runnabler,ThreadPoolExecutorexecutor){

  • }
  • });
别的当线程妨碍恢复时,经由过程日记惊异的察看到,行列中的线程以串行的体例运转了一短工夫,不外很快就一般了。因而在当地写了一个测试。
Java代码

  • ThreadPoolExecutorworkers=newThreadPoolExecutor(10,100,3,TimeUnit.SECONDS,newArrayBlockingQueue<Runnable>(10));
  • for(inti=0;i<110;i++){
  • workers.execute(newRunnable(){
  • @Override
  • publicvoidrun(){
  • try{
  • Thread.sleep(1000);
  • }catch(InterruptedExceptione){
  • }
  • thrownewRuntimeException();
  • }
  • });
  • }

  • while(true){
  • try{
  • Thread.sleep(500);
  • }catch(InterruptedExceptione){
  • }
  • System.out.println(String.format(“taskcount:%s;activecount:%s”,workers.getTaskCount(),workers.getActiveCount()));
  • }
运转如上的代码,打印日记以下:
Java代码

  • taskcount:110;activecount:100
  • taskcount:10;activecount:1
  • taskcount:10;activecount:1
  • taskcount:9;activecount:1
  • taskcount:9;activecount:1

  • taskcount:2;activecount:1
  • taskcount:2;activecount:1
  • taskcount:1;activecount:1
  • taskcount:1;activecount:1
能够看到,最初的10个task是以相似串行的体例在运转。
这里的缘故原由在于ThreadPoolExecutor的中止战略,当Runnable中抛出RTE时,ThreadPoolExecutor会将实行以后的Runnable的线程Dead。因为例子的代码100%会抛出RTE,终极的了局就是ThreadPoolExecutor中存活的消耗线程数变成0。ThreadPoolExecutor创立线程只要在初始化,挪用excute等几个自动办法中才会往做,我们义务的提交早在一入手下手就已做了,终极招致的了局就是永久只存在一个线程服务这个义务行列。
那末要对照文雅的办理这个成绩,可使用FutureTask,FutureTask内里会处置运转时非常,不会将其抛出给ThreadPoolExecutor。

手机用到的是用j2me所编出来的小程序。
金色的骷髅 该用户已被删除
沙发
发表于 2015-1-21 05:32:15 | 只看该作者
[url]http://www.jdon.com/[/url]去下载,或到同济技术论坛的服务器[url]ftp://nro.shtdu.edu.cn[/url]去下,安装上有什么问题,可以到论坛上去提问。
兰色精灵 该用户已被删除
板凳
发表于 2015-1-30 08:30:55 | 只看该作者
在全球云计算和移动互联网的产业环境下,Java更具备了显著优势和广阔前景。
小妖女 该用户已被删除
地板
发表于 2015-1-30 23:04:44 | 只看该作者
你快去找一份Java的编程工作来做吧(如果是在校学生可以去做兼职啊),在实践中提高自己,那才是最快的。不过你得祈祷在公司里碰到一个高手,而且他 还愿意不厌其烦地教你,这样好象有点难哦!还有一个办法就是读开放源码的程序了。我们知道开放源码大都出自高手,他们设计合理,考虑周到,再加上有广大的程序员参与,代码的价值自然是字字珠叽,铿锵有力(对不起,偶最近《金装四大才子》看多了)。
分手快乐 该用户已被删除
5#
发表于 2015-1-31 08:15:43 | 只看该作者
任职于太阳微系统的詹姆斯·高斯林等人于1990年代初开发Java语言的雏形,最初被命名为Oak,目标设置在家用电器等小型系统的程序语言
蒙在股里 该用户已被删除
6#
发表于 2015-1-31 15:58:41 | 只看该作者
是一种简化的C++语言 是一种安全的语言,具有阻绝计算机病毒传输的功能
飘飘悠悠 该用户已被删除
7#
发表于 2015-2-4 14:58:33 | 只看该作者
有时间再研究一下MVC结构(把Model-View-Control分离开的设计思想)
小女巫 该用户已被删除
8#
发表于 2015-2-6 09:15:00 | 只看该作者
吧,现在很流行的Structs就是它的一种实现方式,不过Structs用起来实在是很繁,我们只要学习其精髓即可,我们完全可以设计自己的MVC结构。然后你再研究一下软件Refactoring (重构)和极限XP编程,相信你又会上一个台阶。 做完这些,你不如整理一下你的Java代码,把那些经典的程序和常见的应用整理出来,再精心打造一番,提高其重用性和可扩展性。你再找几个志同道合的朋友成立一个工作室吧
变相怪杰 该用户已被删除
9#
发表于 2015-2-14 01:39:47 | 只看该作者
不过,每次的执行编译后的字节码需要消耗一定的时间,这同时也在一定程度上降低了 Java 程序的运行效率。
因胸联盟 该用户已被删除
10#
 楼主| 发表于 2015-2-21 06:10:42 | 只看该作者
自从Sun推出Java以来,就力图使之无所不包,所以Java发展到现在,按应用来分主要分为三大块:J2SE,J2ME和J2EE,这也就是Sun ONE(Open Net Environment)体系。J2SE就是Java2的标准版,主要用于桌面应用软件的编程;J2ME主要应用于嵌入是系统开发,如手机和PDA的编程;J2EE是Java2的企业版,主要用于分布式的网络程序的开发,如电子商务网站和ERP系统。
小魔女 该用户已被删除
11#
发表于 2015-3-6 19:40:54 | 只看该作者
那么我书也看了,程序也做了,别人问我的问题我都能解决了,是不是就成为高手了呢?当然没那么简单,这只是万里长征走完了第一步。不信?那你出去接一个项目,你知道怎么下手吗,你知道怎么设计吗,你知道怎么组织人员进行开发吗?你现在脑子里除了一些散乱的代码之外,可能再没有别的东西了吧!
第二个灵魂 该用户已被删除
12#
发表于 2015-3-7 16:19:45 | 只看该作者
是一种将安全性(Security)列为第一优先考虑的语言
简单生活 该用户已被删除
13#
发表于 2015-3-7 16:41:34 | 只看该作者
Jive的资料在很多网站上都有,大家可以找来研究一下。相信你读完代码后,会有脱胎换骨的感觉。遗憾的是Jive从2.5以后就不再无条件的开放源代码,同时有licence限制。不过幸好还有中国一流的Java程序员关注它,外国人不开源了,中国人就不能开源吗?这里向大家推荐一个汉化的Jive版本—J道。Jive(J道版)是由中国Java界大名 鼎鼎的banq在Jive 2.1版本基础上改编而成, 全中文,增加了一些实用功能,如贴图,用户头像和用户资料查询等,而且有一个开发团队在不断升级。你可以访问banq的网站
再现理想 该用户已被删除
14#
发表于 2015-3-15 09:38:38 | 只看该作者
设计模式是高级程序员真正掌握面向对象核心思想的必修课。设计模式并不是一种具体"技术",它讲述的是思想,它不仅仅展示了接口或抽象类在实际案例中的灵活应用和智慧
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-5-11 05:36

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表