1

我想比较 2 arrayList,当我在其中存储 telnet 的类 java 的结果时,这个类是关于路由器的 telnet,并提供该路由器的所有接口,然后将它们存储在 arrayList 中,所以我将 router1 的接口存储在 myData1和 myData2 中的第二个,我将比较第一个数组的接口是否与第二个相同,只需将其中一个添加到结果 myData 数组中,但它给了我代码

public class Test {

       public static void main(String[] args) {

    Connection conn = null;
     try { 
conn = DriverManager.getConnection("jdbc:mysql://localhost/mohammedia", "root", "123456"); 
String sql = "SELECT * FROM router;"; 
          Telnet_Interface telnet = new Telnet_Interface();
          Telnet_Interface telnet1 = new Telnet_Interface();
          Telnet_Interface telnet2 = new Telnet_Interface();
            PreparedStatement prest = conn.prepareStatement(sql);
            ResultSet res=prest.executeQuery();
            while(res.next()){
telnet1.Config(res.getString(1), "user", "passwd", res.getString(1));
telnet2.Config(res.getString(2), "user", "passwd", res.getString(2));
            }
           ArrayList myData=new ArrayList();
           ArrayList myData1=telnet1.getMyData();
           ArrayList myData2=telnet2.getMyData();
      boolean bool=false;            
  for(int i=0;i<myData1.size();i++)    
  {    
     for(int j=0;j<myData2.size();j++)    
    {
        if (myData2.get(j).equals(myData1.get(i)))
             {                
                bool=true; 
                //System.out.print("sdfsd");
             }

    if(!bool)
        {
            myData.add(myData2.get(j));
            //System.out.print("sdsd");
        }      
  }
  }
  for(int x=0;x<myData.size();x++)
  {
      System.out.print(myData.get(x));
  }

     } catch (SQLException ex) {
            Logger.getLogger(Test.class.getName()).log(Level.SEVERE, null, ex); 
     }       
}

}

有什么问题 ??谢谢你

4

2 回答 2

1

你可以像这样使用ArrayList.retainAll方法

list1.retainAll(list2)

在此方法之后,list1 将仅包含 list2 中可用的数据。

于 2013-06-14T11:24:52.063 回答
0

(不是答案)全部分开。使用日志记录并处理异常。

  1. 如果不是字典攻击,先做 SQL 检索带密码的用户。

    • 关闭结果集、语句和连接。
    • 检查结果。
  2. 然后获取telnet数据。

    • 检查结果。
  3. 然后进行比较。

    • 我希望你能看到@StinePike 删除的答案;他基本上建议list1.retainAll(list2)删除list1中出现在list2中的所有元素。

我认为您想要执行以下操作。Outcommented 是非循环的替代方案。

// Add all myData2 and myData1 elements but not twice to myData.

// (1) Add myData2

myData.addAll(myData2);

// (2) Add myData1 when not in myData2

//myData1.removeAll(myData1);
//myData.addAll(myData1);
for (int i = 0; i < myData1.size(); i++)    
{    
    boolean found = false;
    for (int j = 0; j < myData2.size(); j++)    
    {
        if (myData2.get(j).equals(myData1.get(i)))
        {   
            found = true;
            break;             
        }
    }
    if (!found)
    {      
        myData.add(myData1.get(i));
    }
}
于 2013-06-14T11:36:54.180 回答