InvalidCharacterException没有捕获字符

时间:2017-02-18 00:36:01

标签: java exception runtimeexception custom-exceptions

如果用户输入了无效字符,我正在为一个要求我抛出RuntimeException的类进行赋值。此输入将用于将post fix-notation中的表达式转换为中缀。现在,我完成了我的任务,但是我无法正确捕获RuntimeException。我尝试创建一个InvalidCharacterException,但它也没有捕获任何东西。

我问的是为什么我的方法不会捕获字符并抛出异常 以下是我的参考课程

postfixExpression

import javax.swing.*;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.io.*;
import java.util.*;

public class postfixExpression extends JPanel 
{ 
   private JFrame frame;//The frame
   private JPanel panel;//The panel
   private JLabel enterPostfix;
   private JTextField postfixExpression;
   private JButton construct;
   private JButton blank;
   private JLabel results;
   private JTextField resultsDisplay;





   //Builds the GUI
   public postfixExpression()
   {
       frame=new JFrame("Three Address Generator");
       panel=new JPanel();
       enterPostfix=new JLabel("Enter Postfix Expression");
       postfixExpression=new JTextField("");
       construct=new JButton("Construct Tree");
       blank=new JButton();
       results=new JLabel("Infix Expression");
       resultsDisplay=new JTextField("");







       construct.addActionListener(new ActionListener()
       {
           public void actionPerformed(ActionEvent e)
           {
               try
               {
                   String expression=postfixExpression.getText();
                   char[] charArray=expression.toCharArray();
                   treeBuilder et=new treeBuilder();
                   Node root=et.buildTree(charArray);
                   resultsDisplay.setText(treeBuilder.inorder(root));
                   root=et.insertRegisters(charArray);
                   et.writeInstructions(root);
               }
               catch(InvalidCharacterException i)
               {
                   JOptionPane.showMessageDialog(null, "Invalid character");
               }

           }
       });



           //Adding the parts together
       panel.setLayout(new GridLayout(3,2));
       panel.add(enterPostfix);
       panel.add(postfixExpression);
       panel.add(construct);
       panel.add(blank);
       panel.add(results);
       panel.add(resultsDisplay);
       frame.add(panel);
       frame.pack();
       frame.setLocationRelativeTo(null);
       frame.setSize(600,300);
       frame.setBackground(Color.red);
       frame.setVisible(true);;





   }           






   //Main method
   public static void main(String[] args)
   {
       postfixExpression myGUI=new postfixExpression();
   }
 } 

TreeBuilder作为

import java.io.*;
import java.util.*;
public class treeBuilder
{

//Checks if the current character is an operator
public  boolean isOperator(char c)
{
    return Character.isDigit(c);
}

//Checks if the current character is an Integer
public boolean isInteger(char c)
{
    int test=Character.getNumericValue(c);
    Integer test2=(Integer)test;

    if(test2 instanceof Integer)
    {
        return true;
    }
    return false;
}
public static String inorder(Node t)
{
    if(t!=null)
    {
        return "("+inorder(t.getLeft())+t.getValue()+" "+inorder(t.getRight())+")";
    }
    return "";
}

public Node buildTree(char postFix[]) throws RuntimeException
{
    Stack<Node> nodeStack=new Stack<Node>();
    Node tree=null;
    Node t1=null;
    Node t2=null;

    for(int i=0;i<postFix.length;i++)
    {
        if(!isOperator(postFix[i])&&!isInteger(postFix[i]))
        {
            throw new InvalidCharacterException(postFix[i]);

        }
        if(!isOperator(postFix[i]))
        {
            tree=new Node(postFix[i]);
            nodeStack.push(tree);
        }
        else if(isOperator(postFix[i]))
        {
            tree= new Node(postFix[i]);
            t1=nodeStack.pop();
            t2=nodeStack.pop();
            tree.setRight(t1);
            tree.setLeft(t2);
            nodeStack.push(tree);
        }
        else if(!isOperator(postFix[i])&& !isInteger(postFix[i]))
        {
            throw new InvalidCharacterException(postFix[i]);
        }


    }
    tree=nodeStack.pop();
    return tree;
}


public Node insertRegisters(char[] postFix)
{
    Stack<Node> nodeStack=new Stack<Node>();
    Node tree=null;
    Node t1=null;
    Node t2=null;
    int registerCount=0;
    for(int i=0;i<postFix.length;i++)
    {
        if(!isOperator(postFix[i]))
        {
            tree=new Node(postFix[i]);
            nodeStack.push(tree);
        }
        else if(isOperator(postFix[i]))
        {
            tree = new Node(postFix[i], "R" + registerCount++);
            t1 = nodeStack.pop();
            t2 = nodeStack.pop();
            tree.setRight(t1);
            tree.setLeft(t2);
            nodeStack.push(tree);
        }

    }
    return tree;
}


public String writeInstructionsHelper(Node root)
{
    String str="";
    if(root != null)
    {
        if(root.getLeft()!=null && root.getLeft().getRegister() !=null)
        {
            str += writeInstructionsHelper(root.getLeft());
        }
        if(root.getRight()!=null && root.getRight().getRegister() !=null)
        {
            str += writeInstructionsHelper(root.getRight());
        }

        String instructions=null;
        if(root.getValue()=='+')
        {
            instructions="Add";
        }
        else if(root.getValue()=='-')
        {
            instructions="Sub";
        }
        else if(root.getValue()=='*')
        {
            instructions="Mul";
        }
        else if(root.getValue()=='/')
        {
            instructions="Div";
        }

        if(root.getRegister()==null)
        {
            str+=root.getValue();
        }
        else
        {
            str += instructions + " ";
            str += root.getRegisterOrValue() + " ";
            str += root.getLeft().getRegisterOrValue() + " ";
            str += root.getRight().getRegisterOrValue();
        }
    }
    str+="\r\n";
    return str;
}

public void writeInstructions(Node root)
{
    String file="myFile.txt";
    try
    {
        String instructions = writeInstructionsHelper(root);
        PrintWriter outputStream = new PrintWriter(file);
        outputStream.println(instructions);
        outputStream.flush();
        outputStream.close();
    }
    catch(FileNotFoundException e)
    {
        e.printStackTrace();
    }

}   
}

InvalidCharacterException

public class InvalidCharacterException extends RuntimeException
{
private char c;

public InvalidCharacterException(char c)
{
    this.c=c;
}

public char getCharacter()
{
    return c;
}
}

节点类

public class Node
{
private char value;
private String register;
private Node left;
private Node right;

public Node(char value)
{
    this.value=value;
    left=null;
    right=null;
    register=null;
}
public Node(char value, String register)
{
    this.value = value;
    this.register = register;
    left = null;
    right = null;
}
public char getValue() {
    return value;
}

public void setValue(char value) {
    this.value = value;
}

public String getRegister() {
    return register;
}

public void setRegister(String register) {
    this.register = register;
}

public Node getLeft() {
    return left;
}

public void setLeft(Node left) {
    this.left = left;
}

public Node getRight() {
    return right;
}

public void setRight(Node right) {
    this.right = right;
}

public String getRegisterOrValue()
{
    if (register == null)
    {
        return "" + value; // must convert to string
    }
    else
    {
        return register;
    }
}



public String toStringHelper(int indents) {
    String str = "";

    str += "value: " + value + "\n";

    for (int i = 0; i < indents; i++) {
        str += "\t";
    }
    if (left == null)
        str += "LEFT: null\n";
    else
        str += "LEFT: " + left.toStringHelper(indents + 1) + "\n";

    for (int i = 0; i < indents; i++) {
        str += "\t";
    }
    if (right == null)
        str += "RIGHT: null\n";
    else
        str += "RIGHT: " + right.toStringHelper(indents + 1) + "\n";

    return str;
}



}

1 个答案:

答案 0 :(得分:0)

您的isInteger方法始终返回true。因此,您永远不会检测到任何无效字符,因此永远不会抛出异常。

怎么会这样?对于大多数无效字符,Character.getNumericValue(c)将返回-1。您将此数字转换为Integer实例,然后测试它是否为Integer。它是。它甚至被声明为整数,因此测试永远不会失败。所以你的方法返回true。返回buildTree方法,if条件将为false,并且您的throw语句未到达。

如果您从isInteger获得否定结果,我立即想出一个修复方法是使用false方法返回Character.getNumericValue(c)。在做出最终决定之前,您可能希望再次阅读该方法的文档。