关于 java Mysql的一个小问题,求帮忙解答

package ceshiJDBC;

import java.util.Properties;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.security.KeyStore.ProtectionParameter;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
//object数组存储
public class ORMDemo {

static Properties pro=null;
static Connection con=null;
static PreparedStatement ps=null;
static ResultSet rs=null;
static Object[] obj=null;
static List<Object[]> list=new ArrayList<Object[]>();

static {
    try {
        pro=new Properties();
        pro.load(new FileReader("D:\\JavaEEeclipse\\ceshiJDBC\\src\\ceshiJDBC\\JDBC.properties"));
    } catch (FileNotFoundException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }
}
public static void main(String[] args) {


    try {
        Class.forName(pro.getProperty("mysqlDriver"));
    } catch (ClassNotFoundException e) {
        e.printStackTrace();
    }

    try {
        con=new JDBCUtil().getCon();
        ps=con.prepareStatement("select username,regTime from t_user where id>?");
        ps.setInt(1, 2);
        rs=ps.executeQuery();
         obj=new Object[2];
        while(rs.next()) {
            obj[0]=rs.getString(1);
            obj[1]=rs.getDate(2);
            list.add(obj);
            System.out.println(rs.getString(1)+"--"+rs.getDate(2));
        }
    } catch (ClassNotFoundException e) {
        e.printStackTrace();
    } catch (SQLException e) {
        e.printStackTrace();
    }
    for(Object[] lists:list) {

            System.out.println(""+lists[0]+lists[1]);

    }

}

}
输出结果:
nam--2017-11-27
??--2017-11-27
gerg--2017-11-27
rg--2017-11-27
rg2017-11-27
rg2017-11-27
rg2017-11-27
rg2017-11-27

为什么数据存到集合中时正常,而最后都被覆盖了?
就是说,为什么最后结果都是rg2017-11-27??

3个回答

= = 在java内部实际上是有指针概念的。你想,使用具有指针概念的cpu写出来的java解释器哪能离开指针概念?再说就像代词一样,你哪能少了指向其它变量的变量啊。
解释你的问题:你的obj指向一个数组对象,你每次是在把同一个数组对象add到了list里,也即list里每一个坑指向的都是同一个数组对象。

qq_40711213
qq_40711213 多谢
2 年多之前 回复

都是指向的obj同一个引用


        while(rs.next()) {
                 obj=new Object[2];
            obj[0]=rs.getString(1);
            obj[1]=rs.getDate(2);
            list.add(obj);
            System.out.println(rs.getString(1)+"--"+rs.getDate(2));
        }
qq_40711213
qq_40711213 多谢!
2 年多之前 回复

obj=new Object[2] 换成Object[] obj=new Object[2] 不要做全局变量,因为这样最后每次写入都是写到同一个对象里面了,所以每次都是后面的覆盖前面的

qq_40711213
qq_40711213 多谢
2 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐