SCJP笔记整理(五)

2024-01-03 08:18
文章标签 整理 笔记 scjp

本文主要是介绍SCJP笔记整理(五),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

说明:这是2007年复习SCJP期间的学习笔记(JavaSE 5.0),有部分遗失。现在整理一下发到Blog上,一方面做个备份,另一方面分享出来,希望对需要的人有用。

------------------------------

第五部分 流程控制、异常和断言

1switch表达式结果必为char\byte\short\int,使用其它任何类型都不能编译。

   Case必须是编译时常量,否则编译时错误:

fianl int a; a=10; //不是编译时常量,改为fianl int a=10;

switch(x){case a: break;} //报错

   包装器和final包装器都不认为是编译时常量:

       final static Integer x=1; 

…… case x: break;  //编译失败。      

2、注意switch—case的范围:

byte g=2;

switch(g){

  case 128:  //编译失败,byte范围到127

}

3switch块中的直落:

   如果case中省略break,那么将继续执行case下面的case.

   default如果放在最后,那么 default执行后也将继续直落。

4try块中一旦出现异常,则其余代码将不再执行,一旦跳转到catch,永远不能返回try内的其余代码。

   finally总会执行,即使try块中有returnfinally也能在遇到return之前执行。

   可以只有try-finally没有catch块。

   异常总是java.lang.Exception的某个子类。两个子类派生于Throwable—ExceptionErrorError不必被处理,它不是异常,不继承Exception类。RuntimeExcepion代表异常的一种特例,表示程序错误等少见且难以处理的异常。

   Exception\Error\RuntimeExceptoin\Throwable都能够通过throws关键字抛出和捕获。

5、具体异常的处理需要放在一般异常的上面,否则编译失败。

6、如果方法声明了抛出检查异常,在方法内部就不需要捕捉该异常,但调用该方法的代码需要用try-catch捕捉异常或者也抛出异常。

   运行时异常称为非检查异常,及从RuntimeException继承而来的异常。运行时异常无须捕获。

   ErrorError子类可以抛出,但它是非检查的,无须捕获,但可以捕获到。

7、如果从catch中再重新抛出捕获的异常,则必须在方法上声明该异常。

8、常见异常:

ArrayIndexOutOfBoundsException数组越界访问异常。

ClassCastException引用变量类型转换异常。

NumberFormatExceptionString转换为数值时String格式异常。

AssertionException布尔测试返回false时抛出。

9、断言:assert(y>x):”y>x”;  //测试为真时什么也不发生,测试为假抛出AssertionException.

  合法断言:

  assert true;

  assert (x==1):x;   //int x=1;

  assert (x==1): returnOne();

  assert (x==1): new ValidAssert();

  不合法断言:

  assert (x=1); //必须为布尔表达式

  assert 1;  //true != 1 ,this isn’t C

assert (x==1): 

  assert (x==1):returnNo(); //must return.

assert (x==1):ValidAssert va; //must a Object;

10Java1.3版断言可以作为变量声明,但不可以作为关键字,assert true将编译失败。

Java1.4版以上断言成为关键字,但不能声明为变量名称。

11、重写方法可以声明:相同异常、更加有限的异常、不声明异常、非检查(运行时)异常。

12void doStuff() throws Exception{

   throw new Exception();  //不需要try-catch.

}

13、被重写方法声明异常,虽然重写方法不声明异常,但默认为声明和重写方法相同的异常。

14break\continue只与循环上的标签协同工作,否则编译失败。

15、嵌套try-catch-finally使用同常规一样。

16javac  A.java  //编译A.java文件

    java  A  1  2 //执行A程序,不是java A.java,带两个参数:12A不算参数。

这篇关于SCJP笔记整理(五)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/565044

相关文章

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Python变量与数据类型全解析(最新整理)

《Python变量与数据类型全解析(最新整理)》文章介绍Python变量作为数据载体,命名需遵循字母数字下划线规则,不可数字开头,大小写敏感,避免关键字,本文给大家介绍Python变量与数据类型全解析... 目录1、变量变量命名规范python数据类型1、基本数据类型数值类型(Number):布尔类型(bo

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)

《MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)》掌握多表联查(INNERJOIN,LEFTJOIN,RIGHTJOIN,FULLJOIN)和子查询(标量、列、行、表子查询、相关/非相关、... 目录第一部分:多表联查 (JOIN Operations)1. 连接的类型 (JOIN Types)

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

Spring Boot 常用注解整理(最全收藏版)

《SpringBoot常用注解整理(最全收藏版)》本文系统整理了常用的Spring/SpringBoot注解,按照功能分类进行介绍,每个注解都会涵盖其含义、提供来源、应用场景以及代码示例,帮助开发... 目录Spring & Spring Boot 常用注解整理一、Spring Boot 核心注解二、Spr

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

Mysql中深分页的五种常用方法整理

《Mysql中深分页的五种常用方法整理》在数据量非常大的情况下,深分页查询则变得很常见,这篇文章为大家整理了5个常用的方法,文中的示例代码讲解详细,大家可以根据自己的需求进行选择... 目录方案一:延迟关联 (Deferred Join)方案二:有序唯一键分页 (Cursor-based Paginatio

Mysql中InnoDB与MyISAM索引差异详解(最新整理)

《Mysql中InnoDB与MyISAM索引差异详解(最新整理)》InnoDB和MyISAM在索引实现和特性上有差异,包括聚集索引、非聚集索引、事务支持、并发控制、覆盖索引、主键约束、外键支持和物理存... 目录1. 索引类型与数据存储方式InnoDBMyISAM2. 事务与并发控制InnoDBMyISAM