java中的HashMap存入效率测试与初始化容量大小之间的关系

1.这里是我做的测试代码

    public static void main(String[] args) {
    int initialSize = 10000000;
    //HashMap存入效率测试
    Long start1 = System.currentTimeMillis();
    Map<Integer,Integer> map = new HashMap<>();
    for (int i = 0; i < initialSize; i++) {
        map.put(i, i);
    }

    Long end1 = System.currentTimeMillis();
    logger.info("未初始化HashMap大小,存入一千万条数据耗时:" + (end1 - start1) + "毫秒");


    Long start2 = System.currentTimeMillis();
    Map map1 = new HashMap<>(initialSize / 2);
    for (int i = 0; i < initialSize; i++) {
        map1.put(i, i);
    }

    Long end2 = System.currentTimeMillis();
    logger.info("初始化HashMap为500W,存入一千万条数据耗时:" + (end2 - start2) + "毫秒");


    Long start3 = System.currentTimeMillis();
    Map map3 = new HashMap<>(initialSize);
    for (int i = 0; i &
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用Java的Stream API来实现,示例代码如下:List list = Arrays.asList("a", "b", "c", "d", "a", "e");List indices = list.stream() .map(element -> list.indexOf(element)) .collect(Collectors.toList());System.out.println("Indices of elements with same value in the list: " + indices); ### 回答2: 要筛选出List数组相同值的数据下标,可以使用Java的循环和条件语句来实现。 首先,我们定义一个List数组,并初始化一些数据。 ```java List<Integer> list = new ArrayList<>(); list.add(1); list.add(2); list.add(3); list.add(2); list.add(4); ``` 接下来,我们使用一个for循环来遍历数组,依次比较每个元素与其他元素的值是否相同。为了避免重复比较和重复记录下标,我们可以设置一个标志位isDuplicate来判断是否已经找到重复值。 ```java List<Integer> indexList = new ArrayList<>(); boolean isDuplicate = false; for (int i = 0; i < list.size(); i++) { isDuplicate = false; for (int j = i + 1; j < list.size(); j++) { if (list.get(i).equals(list.get(j))) { if (!isDuplicate) { indexList.add(i); isDuplicate = true; } indexList.add(j); } } } ``` 最后,我们可以打印出重复值的下标。 ```java System.out.println("重复值的下标为:" + indexList); ``` 以上代码旨在筛选出List数组相同值的数据下标,只需运行即可得到结果。 ### 回答3: 要筛选出list数组相同值的数据下标,可以使用Java的List和Map来实现。首先,我们可以创建一个空的Map对象来存储数组的元素和它们的下标。然后,使用for循环遍历数组,将数组元素作为键,将对应的下标作为值存入Map。如果遇到相同的元素,我们可以使用List来存储它们的下标。 以下是实现该功能的示例代码: ```java import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; public class Main { public static void main(String[] args) { List<Integer> list = new ArrayList<>(); list.add(1); list.add(2); list.add(2); list.add(3); list.add(4); list.add(4); Map<Integer, List<Integer>> indexMap = new HashMap<>(); for (int i = 0; i < list.size(); i++) { int num = list.get(i); if (indexMap.containsKey(num)) { List<Integer> indexes = indexMap.get(num); indexes.add(i); } else { List<Integer> indexes = new ArrayList<>(); indexes.add(i); indexMap.put(num, indexes); } } for (Map.Entry<Integer, List<Integer>> entry : indexMap.entrySet()) { int num = entry.getKey(); List<Integer> indexes = entry.getValue(); if (indexes.size() > 1) { System.out.print(num + "出现的下标为:"); for (int index : indexes) { System.out.print(index + " "); } System.out.println(); } } } } ``` 运行以上代码,输出为: ``` 2出现的下标为:1 2 4出现的下标为:4 5 ``` 以上代码会筛选出list数组所有相同值的数据下标,并将结果输出。这样,我们就实现了筛选出list数组相同值数据下标的功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值