AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / Perguntas / 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

Agora que existe correspondência de padrões no Dart, é melhor usá-lo para iterar mapas?

  • 772

Tradicionalmente, para iterar sobre as chaves e valores de a Mapvocê pode escrever isto:

  map.forEach((key, value) {

  });

Mas com a introdução de padrões no Dart 3.0 você poderia realmente escrevê-lo como

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

  }

Na verdade, tal construção é dada como exemplo na documentação de padrões na seção For e loops for-in .

Suponho que seja um estilo de código melhor é subjetivo, mas uma maneira é melhor que a outra em termos de desempenho/memória?

dart
  • 1 1 respostas
  • 28 Views

1 respostas

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

    O desempenho pode ser estimado com um benchmark:

    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';
        }
      });
    }
    

    Pontuações de referência para tamanho de mapa 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)
    

    Pontuações de referência para tamanho de mapa 100.000:

    [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
    

    Pontuações de referência para tamanho de mapa 1.000.000:

    [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
    

    Conclusão: as pontuações do benchmark mostram um desempenho ligeiramente melhor ao usar forEachpara iterar mapas. No entanto, para tamanhos de mapas moderados, o ganho de desempenho é muito pequeno para recomendar um estilo em detrimento de outro.

    Nota: Os benchmarks foram realizados em uma CPU i5-6260U a 1,80 GHz com 32 GB de RAM.

    • 2

relate perguntas

  • Tipo de retorno covariante para subclasses

  • Existe uma maneira de negar uma correspondência de padrão dentro de uma condição if?

  • Dart null safety me bloqueia mesmo sem dependências

  • Como resolvo o conflito de diretórios de documentos de páginas do Dart Pub vs github?

  • Como posso criar um typedef representando um registro Dart com campos nomeados?

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Por que esse código Java simples e pequeno roda 30x mais rápido em todas as JVMs Graal, mas não em nenhuma JVM Oracle?

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Quando devo usar um std::inplace_vector em vez de um std::vector?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Marko Smith

    Estou tentando fazer o jogo pacman usando apenas o módulo Turtle Random e Math

    • 1 respostas
  • Martin Hope
    Aleksandr Dubinsky Por que a correspondência de padrões com o switch no InetAddress falha com 'não cobre todos os valores de entrada possíveis'? 2024-12-23 06:56:21 +0800 CST
  • Martin Hope
    Phillip Borge Por que esse código Java simples e pequeno roda 30x mais rápido em todas as JVMs Graal, mas não em nenhuma JVM Oracle? 2024-12-12 20:46:46 +0800 CST
  • Martin Hope
    Oodini Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores? 2024-12-12 06:27:11 +0800 CST
  • Martin Hope
    sleeptightAnsiC `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso? 2024-11-09 07:18:53 +0800 CST
  • Martin Hope
    The Mad Gamer Quando devo usar um std::inplace_vector em vez de um std::vector? 2024-10-29 23:01:00 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST
  • Martin Hope
    MarkB Por que o GCC gera código que executa condicionalmente uma implementação SIMD? 2024-02-17 06:17:14 +0800 CST

Hot tag

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

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve