Java中使用List的add方法后元素相同问题

在JavaWeb开发中遇到一个问题,当从数据库读取数据并使用ArrayList存储时,发现只有最后一个元素被正确保存,其余元素丢失。问题在于User对象在循环外初始化,导致所有添加到列表的都是同一个对象引用。解决方法是将User对象的实例化过程移至循环内,确保每次迭代都创建新的User对象。这样做修复了逻辑错误,使得ArrayList能正确保存所有数据。
摘要由CSDN通过智能技术生成

在写JavaWeb时,我在后端通过JDBC读取了数据后逐个使用List.add()方法添加元素并通过request方法传给jsp页面解析,但是添加以后出现了在列表里有n个(假设添加了n个元素)最后一个元素,前面的数据全部丢失,最后排查到问题出现在JDBC读取时,具体代码如下

    @Nullable
    public static List<User> getAll(){
        List<User> list= new ArrayList<User> ();
        Connection conn = getConn();
        PreparedStatement ps=null;
        ResultSet rs=null;
        String sql="select * from library";
        try {
            ps= (PreparedStatement) conn.prepareStatement(sql);
            rs=ps.executeQuery();
            User user= new User ();
            while(rs.next()){
                user.setId(rs.getString("id"));
                user.setName(rs.getString("name"));
                user.setSex(rs.getString("sex"));
                user.setAge(rs.getInt("age"));
                user.setTelephone(rs.getString("tel"));
                user.setAddress(rs.getString("address"));
                list.add(user);
            }
            for(int    i=0;    i<list.size();    i++) {
                System.out.println ("<tr><td>"+ i +list.get(i).getId()+"</td><td>"+ list.get(i).getName()+"</td><td>"+ list.get(i).getSex()+"</td><td>"+ list.get(i).getAge()+"</td><td>"+ list.get(i).getTelephone()+"</td><td>"+ list.get(i).getAddress()+"</td></tr>");
            }
            ps.close();
            conn.close();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return list;
    }

经过排查最终发现在list.add()部分,考虑到初始化List对象在循环外,List添加的是对象的引用,Test只被new了一次然后不断被赋值,所以最后只能写入最后一个元素,根据我的理解,这一部分应该是编译时候编译器把具体内容放在了实例化全部结束以后以提高运行效率,但是在这里就造成了逻辑性的错误导致最后出现的结果异常(具体原因未知,如果有大佬明白还望不吝赐教原因:ArrayList 的add方法,添加的数据是一个实体对象,那么 他是指向这个对象的内存地址,原先所有每次使用add时,都是添加了同一个对象,即使用了同一个地址,从而导致List中的值都为最后一次修改的值 感谢@ljy04103的分享),最后将实例化过程放在循环内即可解决问题

    @Nullable
    public static List<User> getAll(){
        List<User> list= new ArrayList<User> ();
        Connection conn = getConn();
        PreparedStatement ps=null;
        ResultSet rs=null;
        String sql="select * from library";
        try {
            ps= (PreparedStatement) conn.prepareStatement(sql);
            rs=ps.executeQuery();
            while(rs.next()){
                User user= new User ();
                user.setId(rs.getString("id"));
                user.setName(rs.getString("name"));
                user.setSex(rs.getString("sex"));
                user.setAge(rs.getInt("age"));
                user.setTelephone(rs.getString("tel"));
                user.setAddress(rs.getString("address"));
                list.add(user);
            }
            for(int    i=0;    i<list.size();    i++) {
                System.out.println ("<tr><td>"+ i +list.get(i).getId()+"</td><td>"+ list.get(i).getName()+"</td><td>"+ list.get(i).getSex()+"</td><td>"+ list.get(i).getAge()+"</td><td>"+ list.get(i).getTelephone()+"</td><td>"+ list.get(i).getAddress()+"</td></tr>");
            }
            ps.close();
            conn.close();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return list;
    }
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值