`
- 浏览:
793487 次
- 性别:
- 来自:
上海
-
-
- int a = 0b01111_00000_11111_00000_10101_01010_10;
- short b = (short)0b01100_00000_11111_0;
- byte c = (byte)0B0000_0001;
-
其次,二进制同十进制和十六进制相比,可以一目了然的看出数据间的关系。例如下面这个数组中展示了每次移动一位后数字的变化。
- public static final int[] phases = {
- 0b00110001,
- 0b01100010,
- 0b11000100,
- 0b10001001,
- 0b00010011,
- 0b00100110,
- 0b01001100,
- 0b10011000
- }
如果用十六进制来表示的,它们之间的关系就无法一眼看出来了。
- public static final int[] phases = {
- 0x31, 0x62, 0xC4, 0x89, 0x13, 0x26, 0x4C, 0x98
- }
特性2:数字变量对下划线_的支持
你可以在数值类型的变量里添加下滑线,除了以下的几个地方不能添加:
数字的开头和结尾
小数点前后
F或者L前
需要出现string类型值的地方(针对用0x或0b表示十六进制和二进制,参考第一点),比如0x101,不能用0_x101
- int num = 1234_5678_9;
- float num2 = 222_33F;
- long num3 = 123_000_111L;
-
-
-
- int nu = _123;
- int nu = 123_;
-
- float f = 123_.12;
- float f = 123._12;
-
- long l = 123_L;
- float f = 123_F;
-
- int num = 0_b123;
- float f = 0_x123F;
这个,我个人觉得没什么实际作用,只是可以提升代码的可读性。
特性3:switch 对String的支持
这个大家期待很久了,switch终于支持String了
- public static void first() {
-
- String status = "approval";
-
-
-
- switch (status) {
- case "shouli":
- System.out.println("状态是受理");
- break;
- case "approval":
- System.out.println("状态是审批");
- break;
- case "finish":
- System.out.println("状态是结束");
- break;
- default:
- System.out.println("状态未知");
- }
- }
每个case是使用String的equals方法来进行比较的,对大小写敏感。
和一连串的if-else-then想比,使用switch来计较String,Java编译器会生成更加有效的字节码,写一个例子测试一下。
- public static void second() {
- String status = "approval";
- if ("shouli".equals(status)) {
- System.out.println("状态是受理");
- } else if ("approval".equals(status)) {
- System.out.println("状态是审批");
- } else if ("finish".equals(status)) {
- System.out.println("状态是结束");
- } else {
- System.out.println("状态未知");
- }
- }
使用javap之后,生成字节码如下:
switch
- public static void first();
- Code:
- 0: ldc #2
- 2: astore_0
- 3: aload_0
- 4: astore_1
- 5: iconst_m1
- 6: istore_2
- 7: aload_1
- 8: invokevirtual #3
- 11: lookupswitch {
- -1274442605: 72
- -903146056: 44
- 1185244739: 58
- default: 83
- }
- 44: aload_1
- 45: ldc #4
- 47: invokevirtual #5
- 50: ifeq 83
- 53: iconst_0
- 54: istore_2
- 55: goto 83
- 58: aload_1
- 59: ldc #2
- 61: invokevirtual #5
- 64: ifeq 83
- 67: iconst_1
- 68: istore_2
- 69: goto 83
- 72: aload_1
- 73: ldc #6
- 75: invokevirtual #5
- 78: ifeq 83
- 81: iconst_2
- 82: istore_2
- 83: iload_2
- 84: tableswitch {
- 0: 112
- 1: 123
- 2: 134
- default: 145
- }
- 112: getstatic #7
- 115: ldc #8
- 117: invokevirtual #9
- 120: goto 153
- 123: getstatic #7
- 126: ldc #10
- 128: invokevirtual #9
- 131: goto 153
- 134: getstatic #7
- 137: ldc #11
- 139: invokevirtual #9
- 142: goto 153
- 145: getstatic #7
- 148: ldc #12
- 150: invokevirtual #9
- 153: return
用if-else串生成的字节码
- public static void second();
- de:
- 0: ldc #2
- 2: astore_0
- 3: ldc #4
- 5: aload_0
- 6: invokevirtual #5
- 9: ifeq 23
- 12: getstatic #7
- 15: ldc #8
- 17: invokevirtual #9
- 20: goto 71
- 23: ldc #2
- 25: aload_0
- 26: invokevirtual #5
- 29: ifeq 43
- 32: getstatic #7
- 35: ldc #10
- 37: invokevirtual #9
- 40: goto 71
- 43: ldc #6
- 45: aload_0
- 46: invokevirtual #5
- 49: ifeq 63
- 52: getstatic #7
- 55: ldc
- 57: invokevirtual #9
- 60: goto 71
- 63: getstatic #7
- 66: ldc #12
- 68: invokevirtual #9
- 71: return
网上说,用switch之后比用if-else生成的字节码更有效一些,不过目前至少从长度上来说,switch还是长一些
特性4:try-with-resources 声明
try-with-resources 是一个定义了一个或多个资源的try 声明,这个资源是指程序处理完它之后需要关闭它的对象。try-with-resources 确保每一个资源在处理完成后都会被关闭。
可以使用try-with-resources的资源有:
任何实现了java.lang.AutoCloseable 接口和java.io.Closeable 接口的对象。
来看例子:
- public static String readFirstLineFromFile(String path) throws IOException {
- try (BufferedReader br = new BufferedReader(new FileReader(path))) {
- return br.readLine();
- }
- }
在java 7 以及以后的版本里,BufferedReader实现了java.lang.AutoCloseable接口。
- try (Closeable obj = new Closeable() {
- @Override
- public void close() throws IOException {
-
- }
- }) {
-
- }
-
- try (AutoCloseable obj = new AutoCloseable() {
- @Override
- public void close() throws IOException {
-
- }
- }) {
-
- }
-
由于BufferedReader定义在try-with-resources 声明里,无论try语句正常还是异常的结束,它都会自动的关掉。而在java7以前,你需要使用finally块来关掉这个对象。
- public static String readFirstLineFromFileWithFinallyBlock(String path) throws IOException {
- BufferedReader br = new BufferedReader(new FileReader(path));
- try {
- return br.readLine();
- } finally {
- if (br != null) br.close();
- }
- }
然而,如果 readLine() 和 close() 这两个方法都抛出异常,那么readFirstLineFromFileWithFinallyBlock 方法只会抛出后面部分也就是finally块中的内容,try块中的异常就被抑制了,对于我们的程序来说,这显然不是一种好的方式。
而在java 7中,无论是try块还是try-with-resource中抛出异常,readFirstLineFromFile会捕捉到try块的异常,try-with-resources中中异常被禁止了。在java 7 中,你能捕捉到被禁止的异常。getSuppressed()方法被用来检索被抛出异常抑制的其他异常。同样,Throwable类中添加了一个新的构造函数,而这个类可用来启用或禁用对异常的抑制(仅Oracle JDK)。
另外,一个try-with-resourcse声明了可以包含多个对象的声明,用分号隔开,和声明一个对象相同,会在结束后自动调用close方法,调用顺序和生命顺序相反。
- try (
- java.util.zip.ZipFile zf = new java.util.zip.ZipFile(zipFileName);
- java.io.BufferedWriter writer = java.nio.file.Files.newBufferedWriter(outputFilePath, charset)
- ) {
-
- }
此外,try-with-resources 可以跟catch和finally,catch和finally的是在try-with-resources里声明的对象关闭之后才执行的。
特性5:捕获多种异常并用改进后的类型检查来重新抛出异常
1、捕获多种异常
在Java SE7里,一个catch可以捕获多个异常,这样可以减少重复代码。每个异常之间用 | 隔开。
- public static void first(){
- try {
- BufferedReader reader = new BufferedReader(new FileReader(""));
- Connection con = null;
- Statement stmt = con.createStatement();
- } catch (IOException | SQLException e) {
-
- e.printStackTrace();
- }
- }
而在Java SE6以前,需要这样写
- public static void second() {
- try {
- BufferedReader reader = new BufferedReader(new FileReader(""));
- Connection con = null;
- Statement stmt = con.createStatement();
- } catch (IOException e) {
- e.printStackTrace();
- } catch (SQLException e) {
- e.printStackTrace();
- }
- }
-
注意,如果一个catch处理了多个异常,那么这个catch的参数默认就是final的,你不能在catch块里修改它的值。
另外,用一个catch处理多个异常,比用多个catch每个处理一个异常生成的字节码要更小更高效。
使用一个catch生成的字节码
- public static void first();
- Code:
- 0: new #2
- 3: dup
- 4: new #3
- 7: dup
- 8: ldc #4
- 10: invokespecial #5
- 13: invokespecial #6
- 16: astore_0
- 17: aconst_null
- 18: astore_1
- 19: aload_1
- 20: invokeinterface #7, 1
- 25: astore_2
- 26: goto 34
- 29: astore_0
- 30: aload_0
- 31: invokevirtual #10
- 34: return
- Exception table:
- from to target type
- 0 26 29 Class java/io/IOException
- 0 26 29 Class java/sql/SQLException
使用两个catch生成的字节码
- public static void second();
- Code:
- 0: new #2
- 3: dup
- 4: new #3
- 7: dup
- 8: ldc #4
- 10: invokespecial #5
- 13: invokespecial #6
- 16: astore_0
- 17: aconst_null
- 18: astore_1
- 19: aload_1
- 20: invokeinterface #7, 1
- 25: astore_2
- 26: goto 42
- 29: astore_0
- 30: aload_0
- 31: invokevirtual #11
- 34: goto 42
- 37: astore_0
- 38: aload_0
- 39: invokevirtual #12
- 42: return
- Exception table:
- from to target type
- 0 26 29 Class java/io/IOException
- 0 26 37 Class java/sql/SQLException
switch那里生成的字节码不太明显看出来优化在哪里,这个很明显。首先,字节码长度变少 其次,从最后可以看出,target type都指向29行,两个catch会指向不同的行~
2、用更包容性的类型检查来重新抛出异常
在方法的声明上,使用throws语句时,你可以指定更加详细的异常类型。
- static class FirstException extends Exception { }
- static class SecondException extends Exception { }
-
- public void rethrowException(String exceptionName) throws Exception {
- try {
- if (exceptionName.equals("First")) {
- throw new FirstException();
- } else {
- throw new SecondException();
- }
- } catch (Exception e) {
- throw e;
- }
- }
这个例子,try块中只能抛出两种异常,但是因为catch里的类型是 Exception,在java SE7以前的版本中,在方法声明中throws 只能写Exception,但是在java SE7及以后的版本中,可以在throws后面写 FirstException和SecondException——编译器能判断出throw e语句抛出的异常一定来自try块,并且try块只能抛出FirstException和SecondException。
- public static void reThrowException(String exceptionName)
- throws FirstException, SecondException{
- try {
- if ("first".equals(exceptionName))
- throw new FirstException();
- else
- throw new SecondException();
- } catch (Exception e) {
- throw e;
- }
- }
-
所以尽管catch里的异常类型是Exception,编译器仍然能够知道它是FirstException和 SecondException的实例。怎么样,编译器变得更智能了吧。
但是,如果在catch里对异常重新赋值了,在方法的throws后无法再向上面那样写成FirstException和SecondException了,而需要写成 Exception。
具体来说,在Java SE 7及以后版本中,当你在catch语句里声明了一个或多个异常类型,并且在catch块里重新抛出了这些异常,编译器根据下面几个条件来去核实异常的类型:
- Try块里抛出它
- 前面没有catch块处理它
- 它是catch里一个异常类型的父类或子类。
特性6:创建泛型对象时类型推断
只要编译器可以从上下文中推断出类型参数,你就可以用一对空着的尖括号<>来代替泛型参数。这对括号私下被称为菱形(diamond)。
在Java SE 7之前,你声明泛型对象时要这样
- List<String> list = new ArrayList<String>();
而在Java SE7以后,你可以这样
- List<String> list = new ArrayList<>();
因为编译器可以从前面(List)推断出推断出类型参数,所以后面的ArrayList之后可以不用写泛型参数了,只用一对空着的尖括号就行。当然,你必须带着”菱形”<>,否则会有警告的。
Java SE7 只支持有限的类型推断:只有构造器的参数化类型在上下文中被显著的声明了,你才可以使用类型推断,否则不行。
- List<String> list = new ArrayList<>();
- list.add("A");
-
-
- list.addAll(new ArrayList<>());
-
-
- List<? extends String> list2 = new ArrayList<>();
- list.addAll(list2);
注意:菱形<>主要用在变量声明里。
类里也可以使用类型推断
分享到:
Global site tag (gtag.js) - Google Analytics
相关推荐
该项目为“studyjava-zz”设计源码,深入探索Java编程新视野,共计包含549个文件,涵盖209个Java源代码文件、74个Git忽略文件、70个项目配置文件、68个classpath文件、66个偏好设置文件、25个Markdown文档、16个XML...
### K2980ZZ-TR-E-VB N-Channel沟道SOT23 MOSFET晶体管参数介绍与应用说明 #### 概述 K2980ZZ-TR-E-VB是一款高性能N-Channel沟道MOSFET(金属氧化物半导体场效应晶体管),采用SOT23封装形式。这款MOSFET具有低导...
uni-app实战入门到实战项目之网易云音乐完整资料视频教程提取方式是百度网盘分享地址
根据给定的信息,本文将详细解析“2SK2980ZZ-TR-E-VB”这款SOT23封装N-Channel场效应MOS管的关键技术特性与应用领域。 ### 一、产品概述 2SK2980ZZ-TR-E-VB是一款采用SOT23封装的N-Channel沟道MOSFET(金属氧化物...
【标题】"zz-deprecated-wunder-java2"指的是一个针对官方Wunderlist API的Java库,主要用于帮助开发者在Java环境中与Wunderlist服务进行交互。"deprecated"这个词表明这个库可能已经不再推荐使用,可能有更新的替代...
本篇文章将深入探讨基于`atguigu_springboot2_zz-master`项目的SpringBoot2核心知识点,帮助读者更好地理解和运用这一强大工具。 1. **SpringBoot简介** SpringBoot是Spring框架的扩展,旨在简化Spring应用的初始...
标题中的"Profibus.rar_Profibus-DP-zz_profibus_profibus-dp_profibus上位机_tca"表明这是一个与Profibus通信协议相关的资源压缩包,特别是关于Profibus-DP子系统,以及可能用于上位机监控的工具或库。描述提到的...
### Java常用设计模式—追美眉技术详解 #### 设计模式概述 设计模式是一种软件设计中的通用解决方案,它描述了一类问题以及解决该问题的方法。通过应用这些模式,开发人员可以编写出更易于理解、扩展和维护的代码...
基于国家标准的endnote的输出样式,适用于学生党论文插入文献参考,较为方便。endnote论文神器。
uni-app实战社区交友类app开发&带视频教程提取方式是百度网盘分享地址
Aspose是一个强大的文件处理库,提供了多种编程语言的支持,包括Java。在这个场景中,我们将聚焦于如何利用Aspose.cad 19.5版本在Java环境中将DWG(AutoCAD图形数据格式)文件转换为PDF。 Aspose.cad是一款全面的...
base zz zz zz zz zz base zz zz zz zz zz base zz zz zz zz zz base zz zz zz zz zz
本方法是基于BIOES标注的,如果为其它,请...B-PL E-PL B-ZZ E-ZZ B-SJ I-SJ E-SJ 经过BERT分词器分词后为: 反 复 胸 痛 15 年 这时候label就要重新修复下偏移了,修复后结果如下: B-PL E-PL B-ZZ E-ZZ B-SJ E-SJ
【Java Web设计-小区停车收费系统】是一个基于JSP技术的智能管理解决方案,旨在实现小区停车的规范化、无纸化管理。系统分为三个主要角色:系统管理员、小区固定用户和临时用户,各自拥有不同的权限。 **一、系统...
6. 生物工程对农业的影响:这道题目涉及的是科技进步对产业的影响,虽然不是直接的编程知识,但IT行业经常需要思考新技术带来的变革,例如在农业信息化、精准农业等领域。 7. 法官判断问题:此题考察逻辑推理和判断...
uni-app实战多端企业网盘全栈开发带视频教程提取方式是百度网盘分享地址
《中医大夫助理信息系统 zz-doctor 深度解析》 中医大夫助理信息系统“zz-doctor”是一款基于Android平台的应用程序,旨在为中医医生提供智能化、便捷化的诊疗辅助工具。通过深入剖析这款应用的源码,我们可以了解...
2021年全国职业院校技能大赛参赛选手备赛参照使用。
uni-app实战跨端云开发实战拍照识别垃圾分类精灵&视频教程提取方式是百度网盘分享地址
5. **handler**:拒绝策略,当线程池和工作队列都满时,新提交的任务将被拒绝,Java提供了四种预定义策略:抛出异常、直接忽略、调用系统关机、替换为系统默认策略。 线程池的工作流程大致如下: 1. 当任务提交到...