我几分钟前发了一个问题,并要求我发布一个“SSCCE”来证明我的问题。我已经大量压缩了我的程序,所以如果一些构造没有任何意义,或者看起来比新手的工作更加低效,那应该只是那个操作的产物。
现在,我的程序基本上用于将俄语动词变种数组复制到集中式数组 oneRay 。在此处的设置中,提示显示在空白行上方,在该空行中,一个是键入适当的共轭。按“提交”按钮是假设来检查对阵阵列的答案,但由于我自己的错误或缺乏理解,即使直接复制我知道的内容,我也会看到“失败”的消息正确答案。通过这一行,我得到了输入:
build1 = new StringBuilder(ssfield1.getText());
并以此为基础检查元素:
if(build1.equals(oneRay[pick][1].toLowerCase().replaceAll("\\s","")))ssfield1.setText("CORRECT");
else{ssfield1.setText("FAIL");}
我觉得这可能是一个简单的问题,就错误的输入文本字段检查错误的元素,但它可能不是,所以这里是我的浓缩“SSCCE”的所有代码:
不久我希望,而且肯定是自足的(也很简单): 如果您还需要其他任何内容,或者如果这些问题为时已晚,请告诉我们!
package wbh;
import java.awt.Font;
import java.awt.GridLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.Random;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JTextField;
import javax.swing.SwingUtilities;
public class SwingImplementation_RUS extends JFrame{
String [] [] oneRay;Random random = new Random();
JPanel panel; JTextField field,sfield1,sfield2,ssfield1,ssfield2; JButton buton;
int pick, hold;StringBuilder build1,build2;
public SwingImplementation_RUS(final int subj){
super("To be updated");
final String RUS_1[][]={
{"знать","знаю","знаешь","знает","знает","знает","знаем","знаете","знают",}};
new Thread(new Runnable() {
public void run() {
buton = new JButton("Submit");
setLayout(new GridLayout(3,1,3,3));
panel = new JPanel();panel.setLayout(new GridLayout(5,2,3,3));
field = new JTextField();
sfield1 = new JTextField("Я");sfield2 = new JTextField("Ты");
ssfield1 = new JTextField("");ssfield2 = new JTextField("");
buton.addActionListener(new ActionListener(){
public void actionPerformed(ActionEvent m) {
System.out.println("CHECKED");
build1 = new StringBuilder(ssfield1.getText());
build2 = new StringBuilder(ssfield2.getText());
called2();}});
Font f = new Font("Arial", Font.BOLD, 75);
field.setFont(f);
add(field);
add(panel);
panel.add(sfield1);panel.add(ssfield1);
panel.add(sfield2);panel.add(ssfield2);
add(buton);
setLocation(500,0);setSize(865, 700);
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);setVisible(true);
}}).start();
oneRay = new String[RUS_1.length][9];
for(int i = 0; (RUS_1.length) > i; i++){
oneRay[i][0] = RUS_1[i][0];oneRay[i][1] = RUS_1[i][1];
oneRay[i][2] = RUS_1[i][2];}
try {Thread.sleep(100);} catch (InterruptedException e) {e.printStackTrace();}
hold = oneRay.length;pick = random.nextInt(hold);
field.setText(" "+oneRay[pick][0]);
}
private void called2(){
if(build1.equals(oneRay[pick][1].toLowerCase().replaceAll("\\s","")))ssfield1.setText("CORRECT");
else{ssfield1.setText("FAIL");}
if(build2.equals(oneRay[pick][2].toLowerCase().replaceAll("\\s","")))ssfield2.setText("CORRECT");
else{ssfield2.setText("FAIL");}
}
public static void main (String [] args){
SwingUtilities.invokeLater(new Runnable(){
public void run() {
new SwingImplementation_RUS(1);
}
});
}
}
答案 0 :(得分:3)
我认为问题在于您使用StringBuilder#equals
并期望它像String#equals
一样工作。
StringBuilder
的等号实现看起来像......
public boolean equals(Object obj) {
return (this == obj);
}
只是比较对象引用,而不是内容。
相反,尝试使用类似......
的东西if (build1.toString().equals(oneRay[pick][1].toLowerCase().replaceAll("\\s", ""))) ...
作为建议,您还应该在{}
条件下使用if-else
,例如
if (build1.toString().equals(oneRay[pick][1].toLowerCase().replaceAll("\\s", ""))) {
ssfield1.setText("CORRECT");
} else {
ssfield1.setText("FAIL");
}
if (build2.toString().equals(oneRay[pick][2].toLowerCase().replaceAll("\\s", ""))) {
ssfield2.setText("CORRECT");
} else {
ssfield2.setText("FAIL");
}
这将使您更容易阅读(通常)并确保您不会意外地执行您对条件不期望的功能...