- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我想创建一组在我的应用程序中使用的 gorm 类型。所以我想用我的类型定义一个 map
gorm.DB
作为键和空的结构{}
作为标志:
var (
autoMigrations map[gorm.DB]struct{}
)
但是编译器不允许我这样做并出现错误:invalid map key type gorm.DB
。我可以使用指向 gorm.DB
的指针来欺骗它,例如:
map[*gorm.DB]struct{}
但这不是解决方案,因为我需要使它独一无二,如果我的 map 像 db.AutoMigrate(&Chat{})
一样填充,我可以获得许多具有不同地址的相似对象。
另一个解决方案是制作一片gorm.DB
:
autoMigrations []gorm.DB
但我必须在添加时手动过滤元素,这看起来有点疯狂。
最佳答案
您只能将类型用作映射中的键 comparable . Spec: Map types:
The comparison operators == and != must be fully defined for operands of the key type; thus the key type must not be a function, map, or slice.
gorm.DB
是一个结构,只有当所有字段都可比较时,结构值才可比较:
Struct values are comparable if all their fields are comparable. Two struct values are equal if their corresponding non-blank fields are equal.
但是 gorm.DB
有例如一个 DB.values
字段,它是一个 map 类型, map 是不可比较的,因此 gorm.DB
值也不可比较,所以你不能使用它作为 map 键。
如果你想创建一组类型,你应该使用reflect.Type
作为 map 键,您可以使用 reflect.TypeOf()
获取它们来自该类型的值。
一个小技巧,如果你想要一个 reflect.Type
而不必创建一个有问题的类型的值,你可以从那个类型的指针值开始(可能是 nil
),并使用 Type.Elem()
获取指向类型的 reflect.Type
描述符。
例如,获取结构类型Point struct{ X, Y int }
的reflect.Type
描述符,而无需实际创建/拥有Point
:
type Point struct{ X, Y int }
tpoint := reflect.TypeOf((*Point)(nil)).Elem()
fmt.Println(tpoint)
打印 main.Point
。在 Go Playground 上试用.
查看相关问题:
How can I prevent a type being used as a map key?
Why can't Go slice be used as keys in Go maps pretty much the same way arrays can be used as keys?
关于dictionary - map[gorm.DB]struct{}{} 给出无效的映射键类型 gorm.DB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47175474/
我正在用 Python (2.6) 编写一个应用程序,需要我使用字典作为数据存储。 我很好奇拥有一个大字典是否更节省内存,或者将其分解为许多(很多)较小的字典,然后拥有一个包含对所有较小字典的引用的“
Convert this [ "Cat" : ["A" : 1, "B": 2], "Mat" : ["C" : 3, "D": 4] ] Into [ "A" : 1,
有什么很酷的快速方法可以让两个字典创建第三个字典,以内连接方式将第一个字典的键映射到第二个字典的值? Dictionary dic1 = new Dictionary {{a1,b1},{a2,b2}
我希望将字典相互嵌套,以便容纳 block 的 xy 坐标。所以我会 IDictionary, IDictionary> 键 Dictionary 包含列、行组合,而值 Dictionary 包含 x
在 C# 中,我需要将数据保存在字典对象中,如下所示: Dictionary> MyDict = new Dictionary>(); 现在我意识到,在某些情况下我需要一些其他(不是字典类的)
第一个Dictionary就像 Dictionary ParentDict = new Dictionary(); ParentDict.Add("A_1", "1")
我似乎无法理解这个问题。我需要使用 LINQ 按内部字典的值对字典进行排序。有什么想法吗? 最佳答案 你的意思是你想要所有的值,按内部值排序? from outerPair in outer from
我想建模一个模式,其中响应是字典: { 'id1': { 'type': 'type1', 'active': true, }, 'id2': { 'type':
我有以下代码要添加或更新(如果已经存在)dict()-dict 中的值: if id not in self.steps: self.steps[ id ] = step else:
我有一个包含字典的 Swift 字典,我想使用存储的属性来访问键值: var json = [NSObject:AnyObject]() var title: String { get
我想创建一个 Dictionary>结构,我想提供一个 IEqualityComparer在包含 APerson 的second 字典中作为关键 如果我只有内部字典,那就是 var f = new D
我有一个集合,其中包含如下文档:文档 1: { "company": "ABC" "application": { "app-1": {"earning_from_src_A": 50,
我正在快速学习。 我发现 dictionary 就像 hash 用于 PHP 或其他一些语言。 那我怎么制作dictionary的dictionary呢?? 我有这样的数据 key:J name:jh
这个问题在这里已经有了答案: Explode a dict - Get all combinations of the values in a dictionary (2 个答案) 关闭 5 个月前
我是编程新手,所以如果我的问题看起来很愚蠢,我很抱歉。我想问一下有没有办法从 Multi.Dictionary 返回key当我有值(value)? 这是我的代码: Dim myDict Set myD
我试图找出标准 Ada 库是否配备了“字典”类型(我的意思是:一种以 格式存储值的数据结构,我可以从中检索 value 使用相应的唯一 key)。 这样的数据结构存在吗?如果是这样,有人可以提供一个
我究竟做错了什么?根据我的测试,objDic.exists 永远不会给出 False! dim objDic set objDic = createobject("scripting.
我想创建一个复合类型,其中包含一个字典作为其命名字段之一。但是明显的语法不起作用。我敢肯定有一些我不明白的基本原理。下面是一个例子: type myType x::Dict() end Jul
julia> hotcell2vocab = Dict([(cell, i-1+vocab_start) for (i,cell) in enumerate(h
我有一个简单的问题:我对 Dictionary.Value 集合进行了很多次迭代,这让我很烦,我必须调用 .ToList() 然后才能调用 .ForEach(),因为它似乎没有可枚举的Dictiona
我是一名优秀的程序员,十分优秀!