Проблемы JComboBox.setSelectedItem()
Мой столбец jTable 8 - это столбец Штат США. Это мой код для установки jComboBox с соответствующим элементом для отображения состояния.
Когда я использовал Buffered Reader для заполнения Jtable, приведенный ниже код работал очень хорошо для установки элемента комбинированного списка.
Из-за проблем с анализом я решил использовать библиотеку CSVReader по умолчанию вместо того, чтобы переписывать ее самостоятельно. Мои проблемы с заполнением jTable были решены, но теперь по какой-то причине этот код теперь работает дольше. Я что-то пропустил?
jComboBox (0) это "-".
java.lang.Object state = jTable1.getValueAt(jTable1.getSelectedRow(),8);
String g = state.toString();
if (g == "") {
jComboBox1.setSelectedIndex(0);
} else if (g == "AK") {
jComboBox1.setSelectedIndex(1);
} else if (g == "AL") {
jComboBox1.setSelectedIndex(2);
} else if (g == "AR") {
jComboBox1.setSelectedIndex(3);
}else if (g == "AZ") {
jComboBox1.setSelectedIndex(4);
}else if (g == "CA") {
jComboBox1.setSelectedIndex(5);
}else if (g == "CO") {
jComboBox1.setSelectedIndex(6);
}else if (g == "CT") {
jComboBox1.setSelectedIndex(7);
}else if (g == "DE") {
jComboBox1.setSelectedIndex(8);
}else if (g == "FL") {
jComboBox1.setSelectedIndex(9);
}else if (g == "GA") {
jComboBox1.setSelectedIndex(10);
}else if (g == "HI") {
jComboBox1.setSelectedIndex(11);
}else if (g == "IA") {
jComboBox1.setSelectedIndex(12);
}else if (g == "ID") {
jComboBox1.setSelectedIndex(13);
}else if (g == "IL") {
jComboBox1.setSelectedIndex(14);
}else if (g == "IN") {
jComboBox1.setSelectedIndex(15);
}else if (g == "KS") {
jComboBox1.setSelectedIndex(16);
}else if (g == "KY") {
jComboBox1.setSelectedIndex(17);
}else if (g == "LA") {
jComboBox1.setSelectedIndex(18);
}else if (g == "MA") {
jComboBox1.setSelectedIndex(19);
}else if (g == "MD") {
jComboBox1.setSelectedIndex(20);
}else if (g == "ME") {
jComboBox1.setSelectedIndex(21);
}else if (g == "MI") {
jComboBox1.setSelectedIndex(22);
}else if (g == "MN") {
jComboBox1.setSelectedIndex(23);
}else if (g == "MO") {
jComboBox1.setSelectedIndex(24);
}else if (g == "MS") {
jComboBox1.setSelectedIndex(25);
}else if (g == "MT") {
jComboBox1.setSelectedIndex(26);
}else if (g == "NC") {
jComboBox1.setSelectedIndex(27);
}else if (g == "ND") {
jComboBox1.setSelectedIndex(28);
}else if (g == "NE") {
jComboBox1.setSelectedIndex(29);
}else if (g == "NH") {
jComboBox1.setSelectedIndex(30);
}else if (g == "NJ") {
jComboBox1.setSelectedIndex(31);
}else if (g == "NM") {
jComboBox1.setSelectedIndex(32);
}else if (g == "NV") {
jComboBox1.setSelectedIndex(33);
}else if (g == "NY") {
jComboBox1.setSelectedIndex(34);
}else if (g == "OH") {
jComboBox1.setSelectedIndex(35);
}else if (g == "OK") {
jComboBox1.setSelectedIndex(36);
}else if (g == "OR") {
jComboBox1.setSelectedIndex(37);
}else if (g == "PA") {
jComboBox1.setSelectedIndex(38);
}else if (g == "RI") {
jComboBox1.setSelectedIndex(39);
}else if (g == "SC") {
jComboBox1.setSelectedIndex(40);
}else if (g == "SD") {
jComboBox1.setSelectedIndex(41);
}else if (g == "TN") {
jComboBox1.setSelectedIndex(42);
}else if (g == "TX") {
jComboBox1.setSelectedIndex(43);
}else if (g == "UT") {
jComboBox1.setSelectedIndex(44);
}else if (g == "VA") {
jComboBox1.setSelectedIndex(45);
}else if (g == "VT") {
jComboBox1.setSelectedIndex(46);
}else if (g == "WA") {
jComboBox1.setSelectedIndex(47);
}else if (g == "WI") {
jComboBox1.setSelectedIndex(48);
}else if (g == "WV") {
jComboBox1.setSelectedIndex(49);
}else if (g == "WY") {
jComboBox1.setSelectedIndex(50);
}
Спасибо за помощь. JB
1 ответ
Не сравнивайте строки, используя ==
, Использовать equals(...)
или equalsIgnoreCase(...)
метод вместо. Поймите, что == проверяет, являются ли два объекта одинаковыми, а это не то, что вас интересует. С другой стороны, методы проверяют, имеют ли две строки одинаковые символы в одинаковом порядке, и вот что здесь важно. Так что вместо
if (fu == "bar") {
// do something
}
делать,
if ("bar".equals(fu)) {
// do something
}
или же,
if ("bar".equalsIgnoreCase(fu)) {
// do something
}
редактировать
By the way, your program design could be greatly improved. Why the use of magic numbers? Consider instead using enums for this purpose.