ArrayList和HashSet的区别

1

首先要了解这里的有序和无序到底指的什么?有序的意思是按照我们存入的顺序,存入的是什么样的,取出来就是什么样的,无序则相反,存入和取出没有直接关联,不能将存入顺序作为取出顺序的依据。

ArrayList: 有序,取数据时按照存入的顺序。
HashSet: 无序, 不保证Set的迭代顺序; 确切的说,在不同条件下,元素的顺序都有可能不一样

2

List中的数据可以重复
Set中的数据不能够重复
重复判断标准是:
首先看hashcode是否相同
如果hashcode不同,则认为是不同数据
如果hashcode相同,再比较equals,如果equals相同,则是相同数据,否则是不同数据(可参考HashMap的存值方式,HashCode相同时,多个数据以链表存储)

测试

package j2ee.collection;

import java.util.ArrayList;
import java.util.HashSet;

public class TestCollection8 {
    public static void main(String[] args) {
        
        ArrayList<Integer> numberList =new ArrayList<Integer>();
        //List中的数据按照插入顺序存放
        System.out.println("----------List----------");
        System.out.println("向List 中插入 9 5 5 1");
        numberList.add(9);
        numberList.add(5);
        numberList.add(5);
        numberList.add(1);
        System.out.println("List 按照顺序存放数据:");
        System.out.println(numberList);
        System.out.println("----------Set----------");
        HashSet<Integer> numberSet =new HashSet<Integer>();
        System.out.println("向Set 中插入9 5 5 1");
        //Set中的数据不是按照插入顺序存放
        numberSet.add(9);
        numberSet.add(5);
        numberSet.add(5); // Set中数据不能重复
        numberSet.add(1);
        System.out.println("Set 不是按照顺序存放数据:");
        System.out.println(numberSet);
           
    }
}

输出结果

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容