performance - 如何让这段代码更高效?

标签 performance go hashmap

我有一段代码可以遍历 map 并根据关系类型过滤一些字段,我必须运行两个循环并且感觉它对于大 map 来说会很慢。有什么方法可以让我通过技术/重构来提高这段代码的性能。

func getFields(filter map[string]map[string]bool, msg *Message) (fs []Field) {

    for k, _ := range filter {
        if relationString(msg) == k {
            if fieldFilter, ok := filter[k]; ok {
                for _, f := range msg.Fields {
                    if _, ok := fieldFilter[f.Name]; ok {
                        fs = append(fs, f)
                    }
                }
            }
        }
    }
    return
}

最佳答案

你不需要外循环作为一项改进:

func getFields(filter map[string]map[string]bool, msg *Message) (fs []Field) {
  if fieldFilter, ok := filter[relationString(msg)]; ok {
    for _, f := range msg.Fields {
        if _, ok := fieldFilter[f.Name]; ok {
            fs = append(fs, f)
        }
      }
    }
  }

  return
}

关于performance - 如何让这段代码更高效?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30849122/

相关文章:

android - 使用观察者来监控 Android View

c# - 为什么拆箱比装箱快 100 倍

http - 什么是 http 请求多路复用器?

java - Hashmap方法求和

java - 使用java更改HashMap中的部分值

java - 增强了删除运行的效率

mongodb - 使用 FindAndModify 在官方 Mongo Go 驱动程序中运行查询

go - 检查golang中的空 float 或整数值

java - HashMap 困惑。读取/写入文件。 java

performance - Oracle SQL Developer 结果网格按需加载