qq_40711213 2017-11-30 02:26 采纳率: 100%
浏览 1203
已采纳

关于 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条回答 默认 最新

  • hanbingxzy 2017-11-30 02:34
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置