繁体   English   中英

比较两个arrayList并将结果存储在第三个arrayList中

[英]compare two arrayList and stock the result in a thirth arrayList

我想比较2 arrayList,当我在其中存储telnet的java类的结果时,该类是关于路由器的telnet,并给出该路由器的所有接口,然后将它们存储在arrayList中,因此我将my1中的router1的接口存储第二个在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); 
     }       
}

}

有什么问题 ?? 谢谢

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

list1.retainAll(list2)

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

(没有答案) 将所有内容分开。 使用日志记录并处理异常。

  1. 如果这不是一种字典攻击,请首先执行SQL使用密码检索用户。

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

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

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

我认为您想执行以下操作。 值得推荐的是非循环选择。

// 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));
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM