标签:har 对象 else 必须 not 解决 orm 其他 代码
本次PTA作业题集异常
结合题集题目7-1回答
答:最常出现的一定是NullPointerExceptin
了,它属于Unchecked Exception
,可以不用捕获。避免的话,编写代码的时候多考虑对象有可能为null,其它的话就需要检查代码,修改代码来解决异常。
答:除Error
与RuntimeException
以外,其它都是Checked Exception
,都需要用try catch
来捕获
题集题目7-2
int value = Integer.parseInt(line);
这个语句,如果输入的line不是整型,就会出现NumberFormatException
的异常,需要对其进行try catch
。Checked Exception
,那么我们对其进行处理之后程序就会更加健壮。题集题目7-3
阅读Integer.parsetInt源代码
答:
源代码:
public static int parseInt(String s) throws NumberFormatException {
return parseInt(s,10);
}
public static int parseInt(String s, int radix)
throws NumberFormatException
{
/*
* WARNING: This method may be invoked early during VM initialization
* before IntegerCache is initialized. Care must be taken to not use
* the valueOf method.
*/
if (s == null) {
throw new NumberFormatException("null");
}
if (radix < Character.MIN_RADIX) {
throw new NumberFormatException("radix " + radix +
" less than Character.MIN_RADIX");
}
if (radix > Character.MAX_RADIX) {
throw new NumberFormatException("radix " + radix +
" greater than Character.MAX_RADIX");
}
int result = 0;
boolean negative = false;
int i = 0, len = s.length();
int limit = -Integer.MAX_VALUE;
int multmin;
int digit;
if (len > 0) {
char firstChar = s.charAt(0);
if (firstChar < ‘0‘) { // Possible leading "+" or "-"
if (firstChar == ‘-‘) {
negative = true;
limit = Integer.MIN_VALUE;
} else if (firstChar != ‘+‘)
throw NumberFormatException.forInputString(s);
if (len == 1)
throw NumberFormatException.forInputString(s);
i++;
}
multmin = limit / radix;
while (i < len) {
// Accumulating negatively avoids surprises near MAX_VALUE
digit = Character.digit(s.charAt(i++),radix);
if (digit < 0) {
throw NumberFormatException.forInputString(s);
}
if (result < multmin) {
throw NumberFormatException.forInputString(s);
}
result *= radix;
if (result < limit + digit) {
throw NumberFormatException.forInputString(s);
}
result -= digit;
}
} else {
throw NumberFormatException.forInputString(s);
}
return negative ? result : -result;
}
这样可以使Integer.parsetInt
这个方法提供更多的检验异常,会使这个方法更健全。
答:传递给调用者的信息除了根据不同异常有各种不同对应的Exception之外,还会根据实际情况提醒一些信息。
结合题集题目7-3:if(begin>=end)....IllegalArgumentException("begin:"+begin+" >= end:"+end);
、if(begin<0)....IllegalArgumentException("begin:"+begin+" < 0");
虽然都是IllegalArgumentException
,但是根据实际情况是会给传递者不同的信息的。
结合3.1中的:传入null的时候throw new NumberFormatException("null")
;给定的转化进制数超过规定的范围则throw new NumberFormatException("radix " + radix +" greater than Character.MAX_RADIX");
。虽然都是NumberFormatException
,但是根据实际情况是会给传递者不同的信息的。
题集题目6-3
答:对于单纯的返回null代表出错或者返回错误值来说,使用抛出异常的方式,可以让程序使用者更直观清晰的感受到具体出错的原因是什么,像在题6-3中throws FullStackException
和throws EmptyStackException
,栈满和栈空的情况显得更加直观了。
答:throws
是可以成功抛出这个异常的。好处是调用者能知道它是因为Runtime异常而不是其他类别的异常,更直观一些吧。
题集题目6-1
答:一个try块中如果可能抛出多种异常,我们可以对每个异常都提供一个catch块进行处理,捕获时一定要注意让异常的范围按从小到大排列,子类异常在父类异常前。如果子类异常放在父类异常的后面,会导致子类异常的catch块不会被执行。在题目6-1中catch(NumberFormatException e)
和catch(IllegalArgumentException e)
放在前面,catch(Exception e)
应放在最后。
答:java8的多重异常捕获比使用多个catch块方便一些,只需要一个catch块,例如在题6-1中就可以为catch(NumberFormatException | IllegalArgumentException | Exception e)
,但是和多个catch块的逻辑一样,子类还是必须放在父类的前面才可以。
byte[] content = null;
FileInputStream fis = new FileInputStream("testfis.txt");
int bytesAvailabe = fis.available();//获得该文件可用的字节数
if(bytesAvailabe>0){
content = new byte[bytesAvailabe];//创建可容纳文件大小的数组
fis.read(content);//将文件内容读入数组
}
System.out.println(Arrays.toString(content));//打印数组内容
注1:里面有多个方法均可能抛出异常。
功能2:需要添加finally关闭文件。无论上面的代码是否产生异常,总要提示关闭文件ing。如果关闭文件失败,提示关闭文件失败!
代码如下:
byte[] content = null;
FileInputStream fis = null;
int bytesAvailabe = 0;
try {
fis = new FileInputStream("testfis.txt");
bytesAvailabe = fis.available();//获得该文件可用的字节数
if(bytesAvailabe>0){
content = new byte[bytesAvailabe];//创建可容纳文件大小的数组
fis.read(content);
}
System.out.println(Arrays.toString(content));//打印数组内容
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally{
if(fis!=null){
try {
fis.close();
}
catch (IOException e) {
e.printStackTrace();
}
}
else{
System.out.println("file dosen‘t close!!");
}
}
答:
resource.close();
放在finally里面。System.exit(0)
,finally语句就不会执行了,所以关闭资源时,finally之前不能出现System.exit(0)
。try-with-resources
来改写上述代码实现自动关闭资源。简述这种方法有何好处?好处:try-with-resources
的作用是自动调用资源的close()函数,它实现资源的自动回收处理,这样子写代码就很便利很高效了。
public static void main(String[] args) throws IOException {
byte[] content = null;
try (FileInputStream fis = new FileInputStream("testfis.txt");){
int bytesAvailabe = fis.available();//获得该文件可用的字节数
if(bytesAvailabe>0){
content = new byte[bytesAvailabe];//创建可容纳文件大小的数组
fis.read(content);//将文件内容读入数组
}
System.out.println(Arrays.toString(content));//打印数组内容
} catch (IOException e) {
e.printStackTrace();
}
}
登录lib.jmu.edu.cn,对图书进行搜索。然后登录图书馆信息系统,查看我的图书馆。如果让你实现一个图书借阅系统,尝试使用面向对象建模。
分组:
黄子颖 201621123045
翁华辉 201621123042
答:学生以及管理员。
学生:
学生注册
学生登录
查看书籍
借阅书籍
归还书籍
管理员:
查看书籍
添加书籍
删除书籍
存储图书的信息使用Map键值对,key值放图书,value值放图书的数量数量。
借阅的信息也使用Map键值对存储
读者的信息使用Set集合存储
题目集:异常
在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图
需要有两张图(1. 排名图。2.PTA提交列表图)
需要将每周的代码统计情况融合到一张表中。
周次 | 行数 | 新增行数 | 文件数 | 新增文件数 |
---|---|---|---|---|
1 | 115 | 115 | 17 | 17 |
2 | 421 | 306 | 24 | 7 |
3 | 698 | 277 | 30 | 6 |
5 | 1085 | 387 | 38 | 8 |
6 | 1497 | 412 | 48 | 10 |
7 | 2033 | 536 | 57 | 9 |
8 | 2265 | 232 | 60 | 3 |
9 | 2728 | 522 | 65 | 5 |
10 | 3360 | 632 | 73 | 8 |
11 | 3958 | 598 | 83 | 10 |
标签:har 对象 else 必须 not 解决 orm 其他 代码
原文地址:http://www.cnblogs.com/yellower/p/7896045.html