关于 List 当做引用形参数的时候取不到值的问题

先看我的测试方法

 @Test
    public void fun() throws SQLException {

        OrderDAO orderDAO = new OrderDAOImpl();
        List<Order> list =  new ArrayList<Order>();
        orderDAO.getPage(1, 2, list);
        System.out.println(list.toString());

    }

调用的方法

/**
     * 订单分页
     *
     * @param page   页数
     * @param rows   每页行数
     * @param orders list集合
     * @return 返回多少条数据
     */
    public long getPage(int page, int rows, List<Order> orders ) throws SQLException {
        //1、获得session
        Session session = hibernateUtils.opeanSession();
        //2、书写hql
        String hql = "from Order ";
        //3、创建Query
        Query query = session.createQuery(hql);
        //4、添加参数
        query.setFirstResult((page-1)*rows);
        query.setMaxResults(rows);
        //5、执行语句获得返回值
        orders= query.list();
        System.out.println(orders);
//        orders.addAll(list);
        String  hql1 = "select count(*) from Order";
        Query qe = session.createQuery(hql1);
        Long count = (Long) qe.uniqueResult();
        return count;
    }

在fun方法中调用getPage方法list集合接收不到值

原因是地址的问题 在fun中list的引用地址是@849

然而在他当做引用参数传给getPage这个方法的时候getPage方法又新创建了一个list他的地址是@4913

 

在数据库中查询到的内容传赋值到地址为@4913的集合中了

因为作用域的问题在fun这个方法中找不到

解决办法是新建一个list用来接收查询到的值 然后再把新建的这个list通过addAll()方法添加到你的参数list中

这样当做参数的那个list的集合的地址就不会变化了

猜你喜欢

转载自blog.csdn.net/weixin_38482723/article/details/81111912