• List 中添加多个List集合以及add() 与addAll()的区别


     如果有多个已经被实例化的List 集合,想要把他们组合成一个整体,并且,这里必须直接使用List 自身提供的一个方法List.addAll(),否则使用了List.add()方法,则会输出不正常的信息。

         这里不能简单的使用List.add()方法,如果使用了List.add()方法,程序只能找到相应往List中添加的List 集合个数,而不会返回相应的全部结果集。

        这里就需要明白List.add() 和 List.addAll() 的区别了、、、

        1>List.add() 方法,也是往List 中增加list,但是,它增加的是一个List 实例。如果,往容器中增加的那个List 实例从数据库中查到的结果有5条,不过,如果使用了List.add(list1);程序只会输出一条记录。原因就是上面说的。List.add() 加List 实例,它会把这个看一个实例,而不是把那个看成一个容器。

        例如:List.add(list1),List.add(list2);List.add(list3),  这时,List.size 它的大小是3。

        List.add() 的含义就是:你往这个List 中添加对象,它就把自己当初一个对象,你往这个List中添加容器,它就把自己当成一个容器。

       2>List.addAll()方法,就是规定了,自己的这个List 就是容器,往里面增加的List 实例,增加到里面后,都会被看成对象。

        这时:List.add(list1),List.add(list2);List.add(list3),  这时,List.size 它的大小就是所有list 实例化后的总数和总的记录数。

       

        因此,当需要把多个List 实例放到一起的时候,必须使用List.addAll()方法。

        项目实例:

               String hqlImage = "from ImageMeta where 1=1";

                       //拼SQL

                hqlImage += fillCond(map,adAssetsForm);
                listImage = findByHQL(hqlImage, map);
                //视频
                String hqlVideo ="from VideoMeta where 1=1";

                //拼SQL

                hqlVideo += fillCond(map,adAssetsForm);
                listVideo = findByHQL(hqlVideo, map);
                //文字消息
                String hqlMessage = "from MessageMeta where 1=1";

                //拼SQL

                hqlMessage += fillCond(map,adAssetsForm);
                listMessage = findByHQL(hqlMessage, map);

                //综合

                list.addAll(listImage);
                list.addAll(listVideo);
                list.addAll(listMessage);

                return list;

  • 相关阅读:

    tomcat 和jboss区别
    python好文章
    CUBRID学习笔记 34 net参数化查询 cubrid教程示例
    CUBRID学习笔记 33 net事务 cubrid教程示例
    CUBRID学习笔记 32 对net的datatable的支持 cubrid教程
    CUBRID学习笔记 31 通过select创建表
    CUBRID学习笔记 30 复制表结构 cubrid教程
    CUBRID学习笔记 29 web管理中文语言文件 CUBRID教程
    CUBRID学习笔记 28 执行sql脚本文件
  • 原文地址:https://www.cnblogs.com/littleCode/p/4045329.html
Copyright © 2020-2023  润新知