AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题 / 78510114
Accepted
Ivo
Ivo
Asked: 2024-05-21 14:58:24 +0800 CST2024-05-21 14:58:24 +0800 CST 2024-05-21 14:58:24 +0800 CST

既然 Dart 中有模式匹配,最好用它来迭代映射吗?

  • 772

传统上,要迭代 a 的键和值,Map您可以这样写:

  map.forEach((key, value) {

  });

但是随着Dart 3.0 中模式的引入,你实际上可以将其写为

  for (var MapEntry(:key, :value) in map.entries) {

  }

事实上,For 和 for-in 循环部分的模式文档中给出了这样的构造作为示例。

我想这是否是一种更好的代码风格是主观的,但在性能/内存方面,一种方法比另一种方法更好吗?

dart
  • 1 1 个回答
  • 28 Views

1 个回答

  • Voted
  1. Best Answer
    Dan R
    2024-05-21T16:49:06+08:002024-05-21T16:49:06+08:00

    可以使用基准来估计性能:

    import 'package:benchmark_runner/benchmark_runner.dart';
    
    void main(List<String> args) {
      final mapSize = 100000;
      final list = List<int>.generate(mapSize, (index) => index);
      final map = {for (var element in list) element: element.toString()};
      final result = <int, String>{};
    
      benchmark('Iterating using forEach: map size $mapSize', () {
        map.forEach((key, value) {
          result[key] = '$value-new';
        });
      });
      result.clear();
      benchmark('Iterating over map keys: map size $mapSize', () {
        for (final key in map.keys) {
          result[key] = '${map[key]!}-new';
        }
      });
      result.clear();
      benchmark('Pattern for loop: map size $mapSize', () {
        for (final MapEntry(:key, :value) in map.entries) {
          result[key] = '$value-new';
        }
      });
    }
    

    地图大小 100 的基准分数:

    [244ms:881us] Iterating using forEach: map size 100
        mean: 7.24 ± 1.030 us, median: 7.032 ± 0.66 us
        ▆▉▂▂____________ sample size: 40 (averaged over 131 runs)
      
    [242ms:617us] Iterating over map keys: map size 100
        mean: 7.50 ± 0.42 us, median: 7.51 ± 0.49 us
        ▆▄▉▁___ sample size: 41 (averaged over 124 runs)
      
    [236ms:322us] Pattern for loop: map size 100
        mean: 9.12 ± 0.48 us, median: 9.11 ± 0.69 us
        ▇▉▄▁_ sample size: 30 (averaged over 115 runs)
    

    地图大小 100000 的基准分数:

    [811ms:165us] Iterating using forEach: map size 100000
        mean: 10.47 ± 1.97 ms, median: 9.60 ± 1.66 ms
        ▉▁▃________ sample size: 49
      
    [890ms:338us] Iterating over map keys: map size 100000
        mean: 12.18 ± 2.013 ms, median: 11.20 ± 2.31 ms
        ▉▁▅______ sample size: 48
      
    [01s:004ms] Pattern for loop: map size 100000
        mean: 14.47 ± 2.63 ms, median: 13.97 ± 2.51 ms
        ▉▃▇_________ sample size: 47
    

    地图大小 1000000 的基准分数:

    [04s:144ms] Iterating using forEach: map size 1000000
        mean: 217.80 ± 12.30 ms, median: 214.88 ± 18.029 ms
        ▉▇▂▄ sample size: 10
      
    [06s:004ms] Iterating over map keys: map size 1000000
        mean: 353.59 ± 28.75 ms, median: 358.84 ± 57.83 ms
        ▇▄▂▉ sample size: 10
      
    [06s:947ms] Pattern for loop: map size 1000000
        mean: 413.17 ± 10.85 ms, median: 413.095 ± 16.46 ms
        ▄▉▄▄ sample size: 10
    

    forEach结论:当使用迭代映射时,基准分数显示出稍微更好的性能。然而,对于中等大小的地图,性能增益太小,无法推荐一种风格而不是另一种风格。

    注意:基准测试是在 i5-6260U CPU @ 1.80GHz、32GB RAM 上执行的。

    • 2

相关问题

  • 子类的协变返回类型

  • 有没有办法在 if 条件内否定模式大小写匹配?

  • 即使没有依赖项,Dart null 安全也会阻止我

  • 如何解决 dart pub 发布与 github 页面文档目录冲突?

  • 如何创建一个 typedef 来表示具有命名字段的 Dart 记录?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    为什么这个简单而小的 Java 代码在所有 Graal JVM 上的运行速度都快 30 倍,但在任何 Oracle JVM 上却不行?

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    何时应使用 std::inplace_vector 而不是 std::vector?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Marko Smith

    我正在尝试仅使用海龟随机和数学模块来制作吃豆人游戏

    • 1 个回答
  • Martin Hope
    Aleksandr Dubinsky 为什么 InetAddress 上的 switch 模式匹配会失败,并出现“未涵盖所有可能的输入值”? 2024-12-23 06:56:21 +0800 CST
  • Martin Hope
    Phillip Borge 为什么这个简单而小的 Java 代码在所有 Graal JVM 上的运行速度都快 30 倍,但在任何 Oracle JVM 上却不行? 2024-12-12 20:46:46 +0800 CST
  • Martin Hope
    Oodini 具有指定基础类型但没有枚举器的“枚举类”的用途是什么? 2024-12-12 06:27:11 +0800 CST
  • Martin Hope
    sleeptightAnsiC `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它? 2024-11-09 07:18:53 +0800 CST
  • Martin Hope
    The Mad Gamer 何时应使用 std::inplace_vector 而不是 std::vector? 2024-10-29 23:01:00 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST
  • Martin Hope
    MarkB 为什么 GCC 生成有条件执行 SIMD 实现的代码? 2024-02-17 06:17:14 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve