仓酷云

标题: JAVA网站制作之Java SE 8: 尺度库加强仓酷云 [打印本页]

作者: 小女巫    时间: 2015-1-18 11:22
标题: JAVA网站制作之Java SE 8: 尺度库加强仓酷云
前些天,在CSDN上看到了一个消息,说是net网页编程网页编程AJAX成功在Linux上运行,这一点对我触动很大,而且引发了我许多感叹,所以想写出来分享一下。Lambda表达式是JavaSE8的中心功效,年夜部分的改善都环绕lambda表达式睁开。(Jigsaw项目已被推延到JavaSE9。)关于lambda表达式的内容,已在上一篇文章中举行了申明。这篇文章次要先容JavaSE8中包括的其他Java尺度库的加强。
并行排序

跟着多核CPU的盛行,Java平台的尺度库完成也尽量使用底层硬件平台的才能来进步功能。JavaSE7中引进了Fork/Join框架作为一个轻量级的并行义务实行引擎。JavaSE8把Fork/Join框架用到了尺度库的一些办法的完成中。对照典范的是java.utils.Arrays类中新增的parallelSort办法。与已有的sort办法分歧的是,parallelSort办法利用Fork/Join框架来完成。在多核CPU平台上的功能更好。上面的代码对包括1亿个整数的数组分离利用parallelSort和sort举行排序。
  1. Randomrandom=newRandom();intcount=100000000;int[]array=newint[count];Arrays.parallelSetAll(array,(index)->random.nextInt());int[]copy=newint[count];System.arraycopy(array,0,copy,0,array.length);Arrays.parallelSort(array);Arrays.sort(copy);
复制代码
在自己的4核CPU的平台上,parallelSort和sort办法的耗时分离是7112毫秒和16777毫秒。以是parallelSort办法的功能要好很多。不外parallelSort办法只在数据量较年夜时有对照分明的功能提拔。当数据量较小时,Fork/Join框架自己所带来的分外开支足以抵消它带来的功能提拔。
汇合批量数据操纵
在Java使用的开辟中,对汇合的操纵是对照罕见的。不外在JavaSE8之前的Java尺度库中,对汇合所能举行的操纵对照无限,基础上都环绕汇合遍向来睁开。相对其他编程言语来讲,Java尺度库在这一块是对照弱的。JavaSE8中lambda表达式的引进和尺度库的加强改善了这类情况。详细来讲表现在两个方面上的改善:第一个方面是对汇合的操纵体例上。得益于默许办法的引进,Java汇合框架中的接口能够举行更新,增加了更多有效的操纵体例,即一般所说的“filter/map/reduce”等操纵。第二个方面是对汇合的操纵逻辑的暗示体例上。新增加的操纵体例利用了java.util.function包中的新的函数式接口,能够很便利地利用lambda表达式来暗示对汇合的处置逻辑。这两个方面分离起来,失掉的是加倍直不雅和简便的代码。
新的汇合批量处置操纵的中心是新增的java.util.stream包,个中最主要的是java.util.stream.Stream接口。Stream接口的观点相似于JavaI/O库中的流,暗示的是一个撑持按次和并行操纵的元素的序列。在该序列上能够举行分歧的转换操纵。序列中包括的元素也能够被消耗以发生所需的了局。Stream接口所暗示的只是操纵层面上的笼统,与底层的数据存储并没有干系。一般的利用体例是从汇合中创立出Stream接口的对象,再举行各类分歧的转换操纵,最初消耗操纵实行的了局。
Stream接口中包括的操纵分红两类:第一类是对序列中元素举行转换的两头操纵,如filter和map等。这类两头操纵是提早举行的,能够级联起来。第二类是消耗序列中元素的停止操纵,如forEach和count等。当对一个Stream接口的对象实行了停止操纵以后,该对象没法被再次处置。这点切合一样平常意义上关于“流”的了解。上面的代码给出了Stream接口中的filter、map和reduce操纵的基础利用体例。Stream接口中的办法大批利用了函数式接口,能够用lambda表达式很便利地举行操纵。
  1. IntStream.range(1,10).filter(i->i%2==0).findFirst().ifPresent(System.out::println);//保存偶数并输入第一个元素IntStream.range(1,10).map(i->i*2).forEach(System.out::println);//一切元素乘以2并输入
复制代码
intvalue=IntStream.range(1,10).reduce(0,Integer::sum);//乞降
Stream接口的reduce操纵还撑持一种加倍庞大的用法,以下面的代码所示:
  1. List<String>fruits=Arrays.asList(newString[]{"apple","orange","pear"});inttotalLength=fruits.stream().reduce(0,(sum,str)->sum+str.length(),Integer::sum);//字符串长度的总和
复制代码
这类体例的reduce办法必要3个参数,分离是初始值、积累函数和组合函数。初始值是reduce操纵的肇端值;积累函数把部分了局和新的元素积累成新的部分了局组合函数则把两个部分了局组分解新的部分了局,最初发生终极了局。这类情势的reduce操纵一般能够简化成一个map操纵和别的一个复杂的reduce操纵,以下面的代码所示。两种体例的效果是一样的,不外上面的体例加倍简单了解一些。
  1. inttotalLength=fruits.stream().mapToInt(String::length).reduce(0,Integer::sum);
复制代码
别的一种特别的reduce操纵是collect操纵。它与reduce的分歧的地方在于,collect操纵的过程当中所举行的是对一个了局对象举行修正操纵。如许能够制止不用要的对象创立,进步功能。上面代码中的了局是一个StringBuilder类的对象。
  1. StringBuilderupperCase=fruits.stream().collect(StringBuilder::new,(builder,str)->builder.append(str.substring(0,1).toUpperCase()),StringBuilder::append);//字符串首字母年夜写并毗连
复制代码
Stream接口中的操纵能够是按次实行或并行实行的。这是在Stream接口的对象创立时所断定的。好比Collection接口供应了stream和parallelStream办法来创立两种分歧实行体例的Stream接口的对象。这两种分歧的体例是能够切换的,经由过程Stream接口的sequential和parallel办法就能够完成。
日期和工夫

Java尺度库中的日期和工夫处置API一向为开辟职员所诟病。年夜多半开辟职员会选择JodaTime如许的第三方库来举行替换。JSR310作为JavaSE8的一部分,从头界说了新的日期和工夫API,自创了已有第三方库中的最好理论。I界说在java.time包中的新的日期和工夫API基于尺度的ISO8601日历体系。
在新的日期和工夫API中,中心的类是LocalDateTime、OffsetDateTime和ZonedDateTime。LocalDateTime类暗示的是ISO8601日历体系中不带时区的日期和工夫信息。OffsetDateTime类在基础的日期和工夫基本上增添了与UTC的偏移量。ZonedDateTime类则加上了时区的相干信息。上面的代码给出了日期和工夫API的基础用法,包含对日期和工夫的修正、输入息争析。
  1. LocalDateTime.now().plusDays(3).minusHours(1).format(DateTimeFormatter.ISO_LOCAL_DATE_TIME);//输入日期和工夫ZonedDateTime.now().withZoneSameInstant(ZoneId.of("GMT+08:00")).format(DateTimeFormatter.ISO_ZONED_DATE_TIME);//输入日期、工夫和时区DateTimeFormatter.ofPattern("yyyyMMdd").parse("20010125").query(TemporalQuery.localDate());//日期的剖析
复制代码
除上述3个类以外,另有几个值得一提的帮助类。

其他更新

除下面提到的几个对照年夜的更新之前,另有一些小的修改。
Base64编码

Base64编码在Java使用开辟中常常会用到,好比在HTTP基础认证中。在JavaSE8之前,必要利用第三方库来举行Base64编码与解码。JavaSE8增添了java.util.Base64类举行编码息争码。上面的代码给出了复杂的示例。
  1. Base64.Encoderencoder=Base64.getEncoder();Stringencoded=encoder.encodeToString("username:password".getBytes());Base64.Decoderdecoder=Base64.getDecoder();Stringdecoded=newString(decoder.decode(encoded));
复制代码
并发处置

JavaSE8进一步加强了并发处置的相干API。在java.util.concurrent.atomic中新增了LongAccumulator、LongAdder、DoubleAccumulator和DoubleAdder等几个类。这几个类用来在多线程的情形下更新某个Long或Double范例的变量。上面的代码给出了LongAccumulator类的利用示例。

j2EE和asp比较,其实也没什么比的,原因和我上面说那些比较差不了多少,也是稳定性,安全性,J2EE比asp高,速度上比不过asp,asp也是延续着它的拖拽控件的方法,提高速度。
作者: 愤怒的大鸟    时间: 2015-1-20 22:03
你可以去承接一些项目做了,一开始可能有些困难,可是你有技术积累,又考虑周全,接下项目来可以迅速作完,相信大家以后都会来找你的,所以Money就哗啦啦的。。。。。。
作者: 柔情似水    时间: 2015-1-30 06:31
我大二,Java也只学了一年,觉得还是看thinking in java好,有能力的话看英文原版(中文版翻的不怎么好),还能提高英文文档阅读能力。
作者: 深爱那片海    时间: 2015-1-30 19:50
是一种突破用户端机器环境和CPU
作者: admin    时间: 2015-2-2 22:13
多重继承(以接口取代)等特性,增加了垃圾回收器功能用于回收不再被引用的对象所占据的内存空间,使得程序员不用再为内存管理而担忧。在 Java 1.5 版本中,Java 又引入了泛型编程(Generic Programming)、类型安全的枚举、不定长参数和自动装/拆箱等语言特性。
作者: 简单生活    时间: 2015-2-6 21:27
吧,现在很流行的Structs就是它的一种实现方式,不过Structs用起来实在是很繁,我们只要学习其精髓即可,我们完全可以设计自己的MVC结构。然后你再研究一下软件Refactoring (重构)和极限XP编程,相信你又会上一个台阶。 做完这些,你不如整理一下你的Java代码,把那些经典的程序和常见的应用整理出来,再精心打造一番,提高其重用性和可扩展性。你再找几个志同道合的朋友成立一个工作室吧
作者: 因胸联盟    时间: 2015-2-7 11:09
Java是一种计算机编程语言,拥有跨平台、面向对java
作者: 第二个灵魂    时间: 2015-2-21 19:17
多重继承(以接口取代)等特性,增加了垃圾回收器功能用于回收不再被引用的对象所占据的内存空间,使得程序员不用再为内存管理而担忧。在 Java 1.5 版本中,Java 又引入了泛型编程(Generic Programming)、类型安全的枚举、不定长参数和自动装/拆箱等语言特性。
作者: 小魔女    时间: 2015-3-1 02:42
设计模式是高级程序员真正掌握面向对象核心思想的必修课。设计模式并不是一种具体"技术",它讲述的是思想,它不仅仅展示了接口或抽象类在实际案例中的灵活应用和智慧
作者: 透明    时间: 2015-3-4 15:31
是一种语言,用以产生「小应用程序(Applet(s))
作者: 冷月葬花魂    时间: 2015-3-11 20:11
J2SE开发桌面应用软件比起 VC,VB,DEPHI这些传统开发语言来说,优势好象并不明显。J2ME对于初学者来说,好象又有点深奥,而且一般开发者很难有开发环境。
作者: 金色的骷髅    时间: 2015-3-19 11:03
是一种由美国SUN计算机公司(Sun Microsystems, Inc.)所研究而成的语言
作者: 精灵巫婆    时间: 2015-3-27 19:09
我大二,Java也只学了一年,觉得还是看thinking in java好,有能力的话看英文原版(中文版翻的不怎么好),还能提高英文文档阅读能力。




欢迎光临 仓酷云 (http://ckuyun.com/) Powered by Discuz! X3.2