在List的add方法添加对象时都是最后的一条记录的重复

论坛 期权论坛 脚本     
匿名技术用户   2020-12-28 16:46   11   0

在做项目的时候,遇到过一个很容易忽略的问题。就是自己感觉逻辑明明没错的,但是为什么输出结果跟自己想象的有点出入呢?比如下面的代码:(先自己考虑会输出什么,再试试代码会输出什么)


[java] view plain copy
  1. public class ListTest {
  2. public static void main(String[] arg0){
  3. List<User> userList=new ArrayList<User>();
  4. User user=new User();
  5. for(int i=0;i<10;i++){
  6. user.setUserName(i+" ");
  7. userList.add(user);
  8. }
  9. System.out.println(userList.size());
  10. for(int i=0;i<10;i++){
  11. System.out.println(userList.get(i).getUserName());
  12. }
  13. }
  14. }
  15. class User{
  16. private String userName;
  17. public User(){
  18. }
  19. public User(String userName){
  20. this.userName=userName;
  21. }
  22. public String getUserName() {
  23. return userName;
  24. }
  25. public void setUserName(String userName) {
  26. this.userName = userName;
  27. }
  28. }


输出结果如下:



你会发现所有的结果怎么都是最后一个数的重复呢?

我们回去看上面的代码:我们new了一个User对象,就只是new了一个唯一的ID,我们将对象放入list时,list就只是添加了一个对象的引用而已,而我们只是简单的set对象进行对对象的值的改变,但是其ID还是唯一的,list又只是对于对象唯一ID的引用。所以结果就显而易见的。

要改正这个代码,只需在循环中不断new一个User对象就可以了,使其ID不唯一。

下面是改进的代码:

[java] view plain copy
  1. public class ListTest {
  2. public static void main(String[] arg0){
  3. List<User> userList=new ArrayList<User>();
  4. for(int i=0;i<10;i++){
  5. User user=new User();
  6. user.setUserName(i+" ");
  7. userList.add(user);
  8. }
  9. System.out.println(userList.size());
  10. for(int i=0;i<10;i++){
  11. System.out.println(userList.get(i).getUserName());
  12. }
  13. }
  14. }
  15. class User{
  16. private String userName;
  17. public User(){
  18. }
  19. public User(String userName){
  20. this.userName=userName;
  21. }
  22. public String getUserName() {
  23. return userName;
  24. }
  25. public void setUserName(String userName) {
  26. this.userName = userName;
  27. }
  28. }
分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:7942463
帖子:1588486
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP