假设我有一个类,要求是“如果”den“为0,则更改以下代码以抛出已检查的异常,并更改函数以捕获该异常”。
public class divide {
void divide(int num, int den){
System.out.println(""+(num/den));
}
void fun(){
divide(4,2);
}
}
以下哪一项是抛出异常的正确方法?
选项1:
void divide(int num, int den) throws Exception{
if(den==0){
throw new Exception("Dividebyzero");
}
System.out.println(""+(num/den));
}
void fun(){
try {
divide(4,2);
} catch (Exception e) {
}
}
选项2://我认为这个是正确的
void divide(int num, int den){
if(den==0){
throw new RuntimeException("Dividebyzero");
}
System.out.println(""+(num/den));
}
void fun(){
try {
divide(4,2);
} catch (RuntimeException e) {
}
}
选项3:
void divide(int num, int den) throws Exception{
if(den==0){
throw new RuntimeException;
}
System.out.println(""+(num/den));
}
void fun(){
try {
divide(4,2);
} catch (Exception, RuntimeException) {
}
}
这个问题来自其中一个Java练习。我已经学习了几年Java,但我对try catch有点困惑。就个人而言,我认为选项2是正确的,因为我们只抛出一次异常,或者我错了?
答案 0 :(得分:3)
以下哪一项是抛出异常的正确方法?
我不会使代码复杂化,而是会使用它已抛出的异常。
void printDivide(int num, int den) throws ArithmeticException {
System.out.println(num / den);
}
使用不同的例外不仅更复杂,而且令人困惑。
让我们设置它是一个不同的例子,然后IllagelArgumentException是非法参数的一个很好的选择,比如创建一个数组
void createArray(int size) {
if (size < 0)
throw IllegalArgumentException("Size must be non-negative " + size);
this.array = new int[size];
}