0

try/catch ブロックを使用してエラー トラップの基本を把握していますが、トラップの方法では、無効な文字が入力された後にユーザーがプログラムを再起動する必要があります。

プログラムの実行を許可しながら効果的なエラートラップを作成する方法を誰かが示すことができますか?

コード :

import java.io.*; //Input/Output command; this part is ESSENTIAL

class FindingTheSurfaceAreaOfAPyramid2
{
    public static void main (String[] args) throws IOException
    {
        BufferedReader myInput = new BufferedReader (new InputStreamReader (System.in));   //Loading the Text Box

        //Defining variables and string 'nicknames'
        String stringBaseLength, stringBaseWidth, stringTriangleHeight;  //named strings for organization's sake
        double convertToNumL, convertToNumW, convertToNumH, total1, total2, total3;   //'double' is nessesary for decimal answers as they commonly happen, using 'int' will round the result; inaccurate!
        //used in 'if' statements
        boolean realNumber = true;
        boolean realNumber2 = true;
        boolean realNumber3 = true;

        //First message and notice
        System.out.println ("Note: This program is compatible with ONLY rectangular based pyramids.");

        //Question 1: Units
        System.out.println ("First off, what unit is this pyramid in? (ex. cm, mm, in, ft. etc.)");
        String Units = myInput.readLine ();

        //Question 2: Length
        System.out.println ("1) Please enter the length of the base.");
        stringBaseLength = myInput.readLine ();
        try
        {
            Integer.parseInt (stringBaseLength);
            System.out.println ("Your base length is " + stringBaseLength + " " + Units + ".");  //this line is restating the the input as well as the unit of measurement
        }
        catch (NumberFormatException e)
        {
            //If they catch anything other than numbers, it would tell the user
            System.out.println ("That was either a smart remark, a negative number or jibberish.");
            System.out.println ("As a consequence, you have to restart the program.");
            realNumber = false;


        }
        if (realNumber)
        {
            //Question 3: Width
            System.out.println ("2) Please enter the width of the base");
            stringBaseWidth = myInput.readLine ();


            try
            {
                Integer.parseInt (stringBaseWidth);
                System.out.println ("Your base width is " + stringBaseWidth + " " + Units + ".");

            }
            catch (Exception e)
            {
                System.out.println ("That was either a smart remark, a negative number or jibberish.");
                System.out.println ("As a consequence, you have to restart the program.");
                realNumber2 = false;

            }
            if (realNumber2)
            {
                //Question 4: Height
                System.out.println ("3) Please enter the height of the triangle face.");
                stringTriangleHeight = myInput.readLine ();

                try
                {
                    Integer.parseInt (stringTriangleHeight);
                    System.out.println ("Your triangle height is " + stringTriangleHeight + " " + Units + ".");
                }
                catch (Exception e)
                {
                    System.out.println ("That was either a smart remark, a negative number or jibberish.");
                    System.out.println ("As a consequence, you have to restart the program.");
                    realNumber3 = false;
                }
                if (realNumber3)
                {

                    //Converting the input to 'double' to express the answer(s) in decimal format
                    convertToNumH = Double.parseDouble (stringTriangleHeight);
                    convertToNumL = Double.parseDouble (stringBaseLength);
                    convertToNumW = Double.parseDouble (stringBaseWidth);
                    total1 = convertToNumL * convertToNumW;         //base area, length x width
                    total2 = convertToNumL * convertToNumH / 2;     //triangle area using sidelength 'length', base x height / 2
                    total3 = convertToNumW * convertToNumH / 2;     //triangle area using sidelength 'width  ,  base x height / 2

                    //Calculations and concluding sentences
                    System.out.println ("The area of the triangle with base length " + convertToNumL + " cm is " + total2 + Units + "^2.");
                    System.out.println ("The area of the triangle with base length " + convertToNumW + " cm is " + total3 + Units + "^2.");
                    System.out.println ("The base area is " + total1 + " " + Units + "^2.");
                    System.out.println ("The total surface area is " + (total1 + total2 + total2 + total3 + total3) + " " + Units + "^2.");
                }
            }
        }
    }
} //end
4

3 に答える 3

4

多くのコードを投稿しましたが、エラー後に続行するための 1 つのパターンは非常に単純です。擬似コード:

boolean validInput = false;
while (!validInput) {
    // Read some input from the user
    // If it's of the right format, set validInput to true
    // Else print an error message, and don't change validInput
}

ループは、ユーザーが有効な何かを入力する (またはプログラムを強制終了する) まで実行を続けます。

于 2013-02-26T19:42:20.720 に答える
0

コードをリファクタリングして重複を削除する必要があります。以下と比較すると、コードは非常に乱雑で、エラーが発生しやすくなっています。必要なものと再利用できるものとして機能を切り詰めます。再利用を最優先する必要があります。どうすれば不要な手順を排除できますか?

 public class Test{

 static String Units=null;
 static BufferReader myInput 
 public static void main (String[] args){
 //Your Main function
 //Initialize the BufferReader and Read the UNITS
 // Sysouts with your questions
  convertToNumL=readDimension();
 // Sysouts with your questions
  convertToNumW=readDimension();
 // Sysouts with your questions
  convertToNumH=readDimension();

  //Your Calculations 

  }

  public static Double readDimension()
  {
      String temp=null;
      while(true) {

          temp=myInput.readLine();
          while(verifyDimension(temp)){

             return Double.parseDouble(temp);

          }

      } 


  }       

  public static boolean verifyDimension(String temp){

     boolean verify=true;

      try{

      Double.parseDouble(temp) ;

      }catch(NumberFormatException e){

        verify=false;

         //Your Statements
      }
       return verify;

  }            


 }
于 2013-02-27T04:12:02.273 に答える
0

ユーザーが実数を入力するまでループバックする必要があります

boolean realNumber = false;
        while(!realNumber)
        {

    BufferedReader myInput = new BufferedReader (new InputStreamReader (System.in));   //Loading the Text Box

            //Defining variables and string 'nicknames'
            String stringBaseLength, stringBaseWidth, stringTriangleHeight;  //named strings for organization's sake
            double convertToNumL, convertToNumW, convertToNumH, total1, total2, total3;   //'double' is nessesary for decimal answers as they commonly happen, using 'int' will round the result; inaccurate!
            //used in 'if' statements

            boolean realNumber2 = true;
            boolean realNumber3 = true;

            //First message and notice
            System.out.println ("Note: This program is compatible with ONLY rectangular based pyramids.");

            //Question 1: Units
            System.out.println ("First off, what unit is this pyramid in? (ex. cm, mm, in, ft. etc.)");
            String Units = myInput.readLine ();

            //Question 2: Length
            System.out.println ("1) Please enter the length of the base.");
             try
                    {
                        Integer.parseInt (stringBaseLength);
                        System.out.println ("Your base length is " + stringBaseLength + " " + Units + ".");  //this line is restating the the input as well as the unit of measurement
realNumber = true;
                    }
                    catch (NumberFormatException e)
                    {
                        //If they catch anything other than numbers, it would tell the user
                        System.out.println ("That was either a smart remark, a negative number or jibberish.");
                        System.out.println ("As a consequence, you have to restart the program.");
                        realNumber = false;


                    }
        }
于 2013-02-26T19:40:03.423 に答える