Java list、map、set、vector集合类型中的null值

在面向对象语言中,空(Empty)、空值(Null)、不存在(Not Exists)分别具有这不同含义。
举个通俗的例子:

空表示这个位置是用来放这个东西的,但是这个东西的数量现在是0Null是一个占位符,表示这个地方我占了,现在没空间给你放东西;
不存在表示根本就没有这里地方,更别说放在这里的东西了;

面向对象是不是很神奇!其实和我们平常对事物的理解是一样的。
因此,空(Empty)、空值(Null)也是一个对象,既然是对象自然就都可以加入到Java的集合当中了。

我们来做个实验,并探讨如何删除集合中的Null。

package com.demo.test;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Map.Entry;
import java.util.Set;
import java.util.Vector;

public class IteratorDemo {
    private static ArrayList<String> list = new ArrayList<String>();
    private static HashMap<Integer, String> map = new HashMap<Integer, String>();
    private static HashSet<String> set = new HashSet<String>();
    private static Vector<String> vector = new Vector<String>();

    static {
        list.add("a");
        list.add(null);
        list.add(null);
        list.add("c");
        list.add(null);

        map.put(1, "a");
        map.put(2, "b");
        map.put(3, null);
        map.put(4, "d");
        map.put(5, "e");

        set.add("a");
        set.add(null);
        set.add("c");
        set.add(null);

        vector.add("a");
        vector.add(null);
        vector.add(null);
        vector.add("d");
    }

    private static void printList() {
        System.out.println("printList");
        for(String str : list) {
            System.out.println(str);
        }
        System.out.println();
    }

    private static void printMap() {
        System.out.println("printMap");
        Set<Entry<Integer, String>> entrySet = map.entrySet();
        Iterator<Entry<Integer, String>> iterator = entrySet.iterator();
        while(iterator.hasNext()) {
            Entry<Integer, String> entry = iterator.next();
            System.out.println(entry.getKey() + " = " + entry.getValue());
        }
        System.out.println();
    }

    private static void printSet() {
        System.out.println("printSet");
        for(String str : set) {
            System.out.println(str);
        }
        System.out.println();
    }

    private static void printVector() {
        System.out.println("printVector");
        for(String str : vector) {
            System.out.println(str);
        }
        System.out.println();
    }

    private static void removeNullAtList() {
        printList();
        System.out.print("removeNullAtList iterator ");
        Iterator<String> iterator = list.iterator();
        while(iterator.hasNext()) {
            if(iterator.next() == null) {
                iterator.remove();
            }
        }
        printList();
    }

    private static void removeNullAtList2() {
        printList();
        System.out.print("removeNullAtList for() sequence ");
        for(int i=0;i<list.size();i++) {
            if(list.get(i) == null) {
                list.remove(i);
            }
        }
        printList();
    }

    private static void removeNullAtList3() {
        printList();
        System.out.print("removeNullAtList while ");
        int i = 0;
        while(i<list.size()) {
            if(list.get(i) == null) {
                list.remove(i);
            } else {
                i++;
            }
        }
        printList();
    }

    private static void removeNullAtList4() {
        printList();
        System.out.print("removeNullAtList for() reverse ");
        for(int i=list.size()-1;i>=0;i--) {
            if(list.get(i) == null) {
                list.remove(i);
            }
        }
        printList();
    }

    private static void removeNullAtMap() {
        System.out.print("removeNullAtMap iterator ");
        Set<Entry<Integer, String>> entrySet = map.entrySet();
        Iterator<Entry<Integer, String>> iterator = entrySet.iterator();
        while(iterator.hasNext()) {
            Entry<Integer, String> entry = iterator.next();
            if(entry.getValue() == null) {
                iterator.remove();
            }
        }
        printMap();
    }

    private static void removeNullAtSet() {
        printSet();
        System.out.print("removeNullAtSet iterator ");
        Iterator<String> iterator = set.iterator();
        while(iterator.hasNext()) {
            if(iterator.next() == null) {
                iterator.remove();
            }
        }
        printSet();
    }

    private static void removeNullAtVector() {
        printVector();
        System.out.print("removeNullAtVector iterator ");
        Iterator<String> iterator = vector.iterator();
        while(iterator.hasNext()) {
            if(iterator.next() == null) {
                iterator.remove();
            }
        }
        printVector();
    }

    private static void removeNullAtVector2() {
        printVector();
        System.out.print("removeNullAtVector for() ");
        for(int i=0;i<vector.size();i++) {
            if(vector.get(i) == null) {
                vector.remove(i);
            }
        }
        printVector();
    }

    public static void main(String[] args) {
        ArrayList<String> cloneList = (ArrayList<String>) list.clone();
        removeNullAtList();

        list = (ArrayList<String>) cloneList.clone();
        removeNullAtList2();

        list = (ArrayList<String>) cloneList.clone();
        removeNullAtList3();

        list = cloneList;
        removeNullAtList3();
        System.out.println("=============");

        printMap();
        System.out.println(6 + " = " + map.get(6) + "\n");
        map.remove(4);
        printMap();
        removeNullAtMap();
        System.out.println("=============");

        removeNullAtSet();
        System.out.println("=============");

        Vector<String> cloneVector = (Vector<String>) vector.clone();
        removeNullAtVector();
        vector = cloneVector;
        removeNullAtVector2();
    }
}

运行截图如下:
这里写图片描述这里写图片描述

结论如下:
(1)list、map、set、vector等集合类型都是可以存放null的。
(2)list是不能简单的用 for() 来删除数据的,因为每次删除一个位,该位后面的数据便会往前移一位。如果非要用 for() 可以考虑逆序删除。
(3)如果要删除集合中的元素可以使用迭代器iterator,iterator是一个接口,每个集合类都实现了该接口。迭代器删除当前元素后位置并不会移动,且它与下一个元素之间的关系也不会改变(有点类似于链表结构)。

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
掌握集合的概念、体系结构、分类及使用场景 2)了解Set接口及主要实现类(HashSet、TreeSet) 3)了解List接口及主要实现类(ArrayList、LinkedListVector) 4)了解Map接口及主要实现类(HashMap、TreeMap、HashTable) 二、实验内容及步骤 1、编写程序练习将以下5个Person类的对象放在一个HashSet。 姓名:张三 身份证号:178880001 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880003 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880004 注意:因为Person类是自定义类,需要重写hashCode()方法和equals()方法,并规定只有姓名和身份证号都相等,则对象相等。 其计算哈希码的算法:(31 + ((name == null) ? 0 : name.hashCode()))*31 + id (注:name:Person对象的姓名,id:Person对象的身份证号) 主方法作如下测试: 1)创建一个可放置Person类对象的HashSet; 2)依次添加上述5个对象到HashSet; 3)把集合的元素打印出来(使用迭代器Iterator) 2、编写程序练习List集合的基本使用: 1) 创建一个只能容纳String对象名为names的ArrayList集合; 2)按顺序往集合添加5个字符串对象:"张三"、"李四"、"王五"、"马六"、"赵七"; 3)对集合进行遍历,分别打印集合的每个元素的位置与内容; 4)打印集合的大小,然后删除集合的第3个元素,并显示删除元素的内容,然后再打印目前集合第3个元素的内容,并再次打印集合的大小。 3、编写程序练习Map集合的基本使用: 1)创建一个只能容纳String对象的person的HashMap集合; 2)往集合添加5个"键-"对象: "id"-"1"; "name"-"张三"; "sex"-"男"; "age"-"25"; "hobby"-"爱学Java" 3)对集合进行遍历,分别打印集合的每个元素的键与; 4)打印集合的大小,然后删除集合的键为age的元素,并显示删除元素的内容,并再次打印集合的大小。 四、思考题 1、集合ListSetMap有哪些不同? 2、为什么使用集合框架,而尽可能少用数组作为存储结构? 3、如何使用TreeSet实现第一题?
Java的数组和集合是用来存储和操作数据的常用数据结构。数组是一种固定大小的数据结构,用于存储同一类的元素。数组声明时需要指定元素的类,并且大小是固定的,不能动态改变。而集合是一种动态大小的数据结构,可以根据需要动态改变大小。集合以object形式来存储元素,因此可以存储不同类的元素。 在Java,集合分为ListSetMap三种主要类List是一种有序的集合,可以存储重复的元素。常见的List实现类有ArrayList、LinkedListVectorSet是一种不允许重复元素的集合,常见的Set实现类有HashSet和TreeSetMap是一种键对的集合,每个元素都包含一个键和一个,键是唯一的。常见的Map实现类有HashMap、HashTable和TreeMap。 数组和集合在功能上有一些区别。数组声明时需要指定元素的类,而集合不需要。数组的大小是固定的,而集合可以动态改变大小。此外,数组是一种可读/可写的数据结构,而集合可以提供只读版本。 总结来说,数组和集合都是用来存储和操作数据的数据结构,但数组是固定大小的,集合是动态大小的。数组声明时需要指定元素的类,而集合不需要。数组比集合更快,但集合提供了更多的功能。在Java,集合分为ListSetMap三种主要类,每种类都有不同的实现类。 #### 引用[.reference_title] - *1* *3* [Java之数组array和集合listsetmap](https://blog.csdn.net/diaolapei9880/article/details/102382030)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Java必要准确区别之数组Array和集合listmapset](https://blog.csdn.net/jagel_95/article/details/83112811)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值