import java.util.Scanner;
class Operation {
double add(double a, double b){
double c;
c = a+b;
return c;
}
double sub(double a, double b){
double c;
c = a-b;
return c;
}
double mul(double a, double b){
double c;
c = a*b;
return c;
}
double div(double a, double b){
double c;
c = a/b;
return c;
}
}
class Selection{
static double x,y;
void func(int a){
Scanner sc = new Scanner(System.in);
char b;
if(a==1)
b='+';
else if(a==2)
b='-';
else if(a==3)
b='*';
else
b='/';
System.out.println(">>You have selected "+b+" operator");
System.out.println(">>Please enter the first operand.");
x = sc.nextDouble();
System.out.println(">>Please enter the second operand.");
y = sc.nextDouble();
sc.close(); //line 44, this statement gave me a problem.
}
}
public class Calculator {
static int select;
@SuppressWarnings("static-access")
public static void main(String [] args){
Operation op = new Operation();
Selection sel = new Selection();
Scanner sc = new Scanner(System.in);
boolean run = true;
while(run){
System.out.printf(">>Select Operator\n>>1: + 2: - 3: * 4: /\n");
select = sc.nextInt();
double a = sel.x;
double b = sel.y;
double result;
switch(select){
case 1:
sel.func(1);
a = sel.x;
b = sel.y;
result = op.add(a, b);
System.out.println(">>The result of "+a+" + "+b+" is "+result);
break;
case 2:
sel.func(2);
a = sel.x;
b = sel.y;
result = op.sub(a,b);
System.out.println(">>The result of "+a+" - "+b+" is "+result);
break;
case 3:
sel.func(3);
a = sel.x;
b = sel.y;
result = op.mul(a,b);
System.out.println(">>The result of "+a+" * "+b+" is "+result);
break;
case 4:
sel.func(4);
a = sel.x;
b = sel.y;
result = op.div(a,b);
System.out.println(">>The result of "+a+" / "+b+" is "+result);
break;
default:
System.out.println(">>Your number is not available, please try again!");
System.out.println();
System.out.println();
continue;
}
System.out.println(">>Do you want to exit the program(y)?");
String startOver = sc.next();
if(startOver.equals("y")){
run = false;
System.out.println(">>Thank you for using my program!");
}else{
System.out.println();
continue;
}
sc.close(); //line 111, this works fine i think.
}
}
}
我是Java编程的初学者,这是我作业的一个简单的“计算器”代码。我希望我的代码简单而有效,并且非常努力。检查代码后,弹出一条警告消息,说“资源泄漏:'sc'永远不会关闭”。我知道如果没有添加“sc.close();”它仍然可以正常运行,但我希望我的程序完美并添加“sc.close();”第44行和第111行的语句。添加语句后,关于资源泄漏的警告消失了,但是当我运行代码时,有一段时间程序要求进行另一次计算,就在那里,弹出一个调试控制台。
我不确定为什么会弹出调试控制台,您认为问题是什么?
答案 0 :(得分:0)
你应该看到'潜在的资源泄漏......'警告,如果没有,请打开一个错误。 这里的主要问题是编译器不知道'close(..)'方法的作用。它可能会也可能不会关闭资源。 (注意,编译器不执行过程间分析) 您可以选择忽略“潜在资源泄漏”警告。 ('资源泄漏'警告保证是正确的,但'潜在......'警告不是正确的) 有关资源泄漏分析的更多详细信息,请参阅此处 - http://help.eclipse.org/juno/index.jsp?topic=%2Forg.eclipse.jdt.doc.user%2Ftasks%2Ftask-avoiding_resource_leaks.htm&cp=1_3_9_1
编辑:关于'资源泄漏'与'潜在资源泄漏'的说法
这个想法是所有报告的“资源泄漏”警告都保证是正确的,但可能不是“全部”代码库中的资源泄漏。 “潜在的资源泄漏”是......潜在的问题。一些开发人员在知道出现问题但他们不知道在哪里时会发出“潜在......”警告。在这种情况下,潜在的警告有助于缩小搜索范围。其他一些开发人员不时会仔细检查潜在的警告,看看那里是否存在真正的问题。 理想情况下,我们希望编译器为我们提供完整且正确的问题集,但在实现这一目标方面存在限制: - )