8

このトライアンドキャッチが機能しない理由を教えてください。期待するメッセージを出力する代わりに、スキャナー例外をスローします。

import java.util.*;
import java.io.*;
import java.math.*;
import javax.swing.*;

public class Main {
    public static void main(String[] args) {
        Boolean test = true;
        while (test == true) {
            try {
                double x, y;
                String operator;
                Scanner scan = new Scanner(System.in);
                Scanner scan_2 = new Scanner(System.in);
                Scanner ScanOperator = new Scanner(System.in);
                System.out.println(" Enter a double value: ");
                x = scan.nextDouble();
                System.out.println(" Enter another double value: ");
                y = scan_2.nextDouble();
                System.out.println(" Enter a operator for the operation you want to execute, or X if you want to quit: ");
                operator = ScanOperator.nextLine();
                if (operator.equals("x") || operator.equals("X")) {
                    test = false;
                    System.out.println("No calculation was made!!!");
                }
                System.out.println(Calculation(operator, x, y));
            } catch (NumberFormatException nfe) {
               JOptionPane.showMessageDialog(null,"Input must be a number.");
            }
        }
    }

    public static double Calculation(String operator, double x, double y) {
        double result = 0;
        double myAdd = 0;
        double mySub = 0;
        double myMult = 0;
        double myDiv = 0;
        double myPower = 0;
        double myMod = 0;

        if (operator.equals("+")) {
            myAdd = x + y;
            result = myAdd;
        } else if (operator.equals("-")) {
            mySub = x - y;
            result = mySub;
        } else if (operator.equals("*")) {
            myMult = x * y;
            result = myMult;
        } else if (operator.equals("/")) {
            myDiv = x / y;
            result = myDiv;
        } else if (operator.equals("^")) {
            myPower = Math.pow(x, y);
            result = myPower;
        } else if (operator.equals("%")) {
            myMod = x % y;
            result = myMod;
        } else {
        }

        return result;
    }
}
4

7 に答える 7

21

簡単です。プログラムは ScannerException をスローしますが、try catch は NumberFormatException しかキャッチできません。ScannerException をキャッチするために別の catch 句を追加するか、一般的な例外のみをキャッチする必要があります。

たとえば、次のように言います。

 } catch (NumberFormatException nfe) {     
     JOptionPane.showMessageDialog(null,"Input must be a number.");
 }

これは、NumberFormatException をキャッチする方法を指定しているだけです。
すべての例外をキャッチするには、次のようにする必要があります。

 } catch (NumberFormatException nfe) {     
     JOptionPane.showMessageDialog(null,"Input must be a number.");
 }catch (Exception e){
     JOptionPane.showMessageDialog(null,"Generic exception caught");
 }

この場合、2 番目の catch は最初の catch でキャッチされなかったすべてのものを取得します。これは、すべての例外が Exception クラスを拡張するためです。そのステートメントですべての派生クラスをキャッチできます。

ただし、例外を単独でキャッチすることは嫌われているため、次のこともできます。

 } catch (NumberFormatException, ScannerException e) {     
     JOptionPane.showMessageDialog(null,"Input must be a number.");
 }

同じブロックで両方の例外をキャッチします。

于 2010-01-14T23:04:46.353 に答える
4

NumberFormatException をキャッチしようとしています。NumberFormatException とは異なるため、ScannerException の catch ステートメントを追加する必要があります。

于 2010-01-14T23:03:55.667 に答える
2

ScannerExceptionなどをキャッチする必要があります。

このコードでは、NumberFormatExceptionのみをキャッチしています。

次のようなものを試してください:

    try {
       ...
    } catch (NumberFormatException, ScannerException exception) {
       JOptionPane.showMessageDialog(null,"Input must be a number.");
    }
于 2010-01-14T23:04:43.153 に答える
1

間違った例外をキャッチしています。

于 2010-01-14T23:03:30.710 に答える
0

なぜそうしないのですか:

String input = scan.nextLine();
if(!input.matches("\\d+")) { // regex for 1 or more digits
    System.err.println("Input must be at least 1 digit!");
    continue; // goes back to the top of the loop
}
double dbl = Double.valueOf(input);

参考までに、倍精度の実際の正規表現は [digit][.][digit] で、[.][digit] はオプションです。

于 2010-01-15T01:21:12.180 に答える
0

あなたのコードはNumberFormatException. 代わりにをキャッチする必要がありInputMismatchExceptionます。

の を見るとnextDouble、コードが を処理してから、別の種類の例外をスローしScannerているように見えます。ScannerNumberFormatException

からjava.util.Scanner:

public double nextDouble() {
    // Check cached result
    if ((typeCache != null) && (typeCache instanceof Double)) {
        double val = ((Double)typeCache).doubleValue();
        useTypeCache();
        return val;
    }
    setRadix(10);
    clearCaches();
    // Search for next float
    try {
        return Double.parseDouble(processFloatToken(next(floatPattern())));
    } catch (NumberFormatException nfe) {
        position = matcher.start(); // don't skip bad token
        throw new InputMismatchException(nfe.getMessage());
    }
} 

このような問題が発生した場合は、最初に Java ソースに目を通すことをお勧めします。それは素晴らしいリソースです。

ScannerExceptionまた、JDKにはないことに注意してください。

于 2010-01-14T23:09:36.143 に答える
0

InputMismatchException代わりにキャッチするだけでNumberFormatException、すべて正常に動作します。

于 2010-01-14T23:09:55.287 に答える