<p>Let say I have:</p>
<pre><code>type A interface { doAishAction() }
type B interface { doBishAction() }
func doABStuff(thing ???) {
thing.doAishAction()
thing.doBishAction()
}
</code></pre>
<p>How should the type of <strong>thing</strong> be defined? I just want it to be something that complies <em>both</em> to <strong>A</strong> and <strong>B</strong> interfaces.</p>
<hr/>**评论:**<br/><br/>usernameliteral: <pre><p>Define a third interface that implements A and B.</p>
<pre><code>type C interface {
A
B
}
</code></pre></pre>svetlyo: <pre><p>Thanks!</p>
<p>I wanted to define the interface type on the fly, anonymously and this works:</p>
<pre><code>func doABStuff(thing interface{A; B}) {
thing.doAishAction()
thing.doBishAction()
}
</code></pre></pre>izuriel: <pre><p>You keep saying "on the fly" and I don't think it means what you think it means. Doing what your doing anonymously makes it harder to modify in the future if you do this in multiple places. If you "predefine" or name the interface in a single location it would be very easy to make modifications later on. </p>
<p>Neither approach is "dynamic" or "on the fly" as they are compiled during the build phase. Unlike an interpreted language where this may actually be useful and may be dynamic or "on the fly" in Go I'd say it would be a lot easier for long term maintenance to just define the joint interface with a name in one place. </p></pre>svetlyo: <pre><p>Named interface types represent a reusable abstraction - we want to express some well defined notion by giving a name to a set of logically related methods. But you don't have to name everything, every possible combination of your named interfaces just because at some places you need that particular combination - otherwise you'll end up with an exponential explosion of names that you have to remember (and come up with in the first place) whereas it is pretty clear what 'interface {Stack; Serializable}' is for example (if you already know what Stack and Serializable are)</p></pre>izuriel: <pre><p>I specifically advocated for reusability over embedding anonymous types everywhere. Names are easy to remember, run 'go doc' from your terminal on a package and get an incredibly easy and accessible method to see names. </p>
<p>It seems pointless to sacrifice clarity because "naming" is perceived as a potentially difficult task. Having the need to constantly switch between anonymous types to avoid memorizing names smells of a potentially larger problem. At what point would a method need to know its serializing a stack? The point of a Serializer interface should be sufficient. Your methods will ultimately become very specific and less reusable as this pattern grows.</p></pre>djherbis: <pre><p><a href="https://www.youtube.com/watch?v=G2y8Sx4B2Sk" rel="nofollow">https://www.youtube.com/watch?v=G2y8Sx4B2Sk</a> :)</p></pre>613style: <pre><p>Just think of this as Reader, Writer, and ReadWriter:</p>
<pre><code>type Reader interface {
Read(p []byte) (n int, err error)
}
type Writer interface {
Write(p []byte) (n int, err error)
}
type ReadWriter interface {
Reader
Writer
}
</code></pre></pre>
Is it possible define an interface type on the fly that accepts only values with types that comply to multiple given interfaces at the same time?
blov · · 399 次点击这是一个分享于 的资源,其中的信息可能已经有所发展或是发生改变。
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
0 回复
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码`
- 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传