码农Z先生 2017-06-12 06:44 采纳率: 100%
浏览 4539
已采纳

使用HashSet()实现Set集合,foreach输出结果一直固定的,不是应该每次结果都不同吗?

package test;

import java.util.HashSet;
import java.util.LinkedHashSet;
import java.util.Set;
import java.util.TreeSet;

public class Test24 {

public static void main(String[] args) {
    Set<String> s = new HashSet<>();
    s.add("王小明");
    s.add("李四");
    s.add("赵七");
    s.add("何六");
    s.add("方三");
    //使用foreach对set集合s进行循环遍历
    for (String name : s) {
        System.out.println(name);
    }
}

}

  • 写回答

6条回答 默认 最新

  • a350062174 2017-06-12 18:18
    关注

    HashSet() 其实是有序的, 但不是元素的添加顺序. 它的顺序和元素hashcode 有关.

    Set集合里元素没变,hashcode也不变(String 的hashcode 由里面的"字符串"算出来,因此hashcode值是国定不变的) 所以集合 顺序就不会变

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部