使用外部包时,定义对包含公共成员的结构进行操作的泛型函数可能具有挑战性。本文探讨了一个问题,即尝试创建通用函数来修改两个不同 Firebase 消息结构 Message 和 MulticastMessage 的共享字段。
尽管有与Android配置字段类似,这些结构没有显式关系,尝试直接使用类型参数访问它们的公共属性会导致错误。原因是 Go 1.18 尚不支持访问类型参数的公共字段或方法,如链接线程中所述。
为了解决此问题,有几种解决方案建议:
如果涉及的类型数量有限,可以使用类型切换语句来访问共享字段:
<code class="go">func highPriority[T firebaseMessage](message T) T { switch m := any(message).(type) { case *messaging.Message: setConfig(m.Android) case *messaging.MulticastMessage: setConfig(m.Android) } return message }</code>
此方法涉及使用要在泛型函数中使用的附加方法创建包装器结构:
<code class="go">type MessageWrapper struct { messaging.Message } func (w *MessageWrapper) SetConfig(cfg messaging.Android) { *w.Android = cfg }</code>
然后泛型函数可以访问此通用方法:
<code class="go">func highPriority[T wrappedMessage](message T) T { message.SetConfig(messaging.Android{"some-value"}) return message }</code>
如果结构体数量较多,可以使用反射来动态访问共享字段:
<code class="go">func highPriority[T firebaseMessage](message T) T { cfg := &messaging.Android{} reflect.ValueOf(message).Elem().FieldByName("Android").Set(reflect.ValueOf(cfg)) return message }</code>
需要注意的是,这些解决方案有它们的局限性:
以上是Go中如何使用泛型处理不同结构体中的共享字段?的详细内容。更多信息请关注PHP中文网其他相关文章!