当我阅读docker / distribution源代码的副本时,我发现有声明的变量使我很困惑。
代码是:
var _ FileInfo = FileInfoInternal{}
var _ FileInfo = &FileInfoInternal{}
我不知道声明是什么意思,希望能得到一些帮助。
从常见问题解答:
您可以通过尝试分配,要求编译器检查类型T是否实现了接口I:
type T struct{} var _ I = T{} // Verify that T implements I.
在这种情况下,空白标识符_代表此处不需要的变量名(从而防止出现“已声明但未使用”错误)。
规格中的更一般性:
空白标识符提供了一种忽略分配中右侧值的方法:
_ = x // evaluate x but ignore it x, _ = f() // evaluate f() but ignore second result value
通过测试两者FileInfoInternal{}
和,&FileInfoInternal{}
您可以检查接口是否通过值接收器实现。值接收器将同时接受值和指针,而指针接收器将仅与指针一起使用,并且按值进行的首次分配将失败。
&FileInfoInternal{}
实际不需要进行第二次测试(作者在评论中确认),因为第一次测试将通过值接收器通过,而接收到指针失败。因此,第二项测试是多余的。
这是一篇很棒的文章,解释了值接收器和指针接收器之间的区别以及如何很好地使用它们。
问题内容: 为什么我们要在Java类中声明一个接口? 例如: 问题答案: 当您想在对象中收集一些字段以强调概念时,可以创建一个外部类,也可以创建一个内部类(称为嵌套(静态)或内部)。 如果要强调这个合作类在原始对象使用之外完全没有意义(没有用)的事实,可以将其嵌套/内部。 因此,在处理某些层次结构时,可以描述一个“嵌套” ,它将由包装类的子类实现。 在JDK中,最显著的例子是内部接口中定义的接口,
问题内容: 为什么编译器没有在开关中的每个代码块之后自动放置break语句?是出于历史原因吗?您何时要执行多个代码块? 问题答案: 有时将多个案例与同一代码块关联会很有帮助,例如 等。只是一个例子。 以我的经验,通常“摔倒”并在一种情况下执行多个代码块是不好的风格,但是在某些情况下可能会有用处。
问题内容: Java7的try-with-resources非常好,但是我无法绕开为什么需要在语句中包括资源声明的问题。我的直觉说以下应该是可能的: las,这会导致语法错误(含糊地期待a )。将类型定义/声明移动到语句中是可行的,这当然会将事物移动到相应的范围内。当我想从封闭中获得更多收益时,我可以弄清楚该如何解决,我对 为什么 编译器需要这样的东西很感兴趣。 问题答案: 您的版本未明确定义应关
问题内容: 这可能表明我缺乏Java理解,但是我想知道为什么在大多数MapReduce程序中,映射器和reducer类都声明为静态的? 问题答案: 当将mapper和reducer类声明为另一个类的内部类时,必须将它们声明为静态的,以便它们不依赖于父类。 Hadoop使用反射为每个映射创建该类的实例或减少运行的任务。创建的新实例需要一个零参数构造函数(否则它将如何知道要传递的内容)。 通过声明内部
问题内容: 我读到要使一个类在Java中不可变,我们应该执行以下操作: Do not provide any setters Mark all fields as private Make the class final标记为私有 为什么需要步骤3?我为什么要上课呢? 问题答案: 如果你不标记该类,那么我可能会突然使你看似不变的类真正变得可变。例如,考虑以下代码: 现在,假设我执行以下操作: 注意
问题内容: 我仍在学习python,我对此表示怀疑: 在python 2.6.x中,我通常像这样在文件头中声明编码(如在PEP 0263中 ) 之后,我的字符串照常编写: 但是每次我看到python项目代码时,都不会在标头中声明编码。而是在每个这样的字符串处声明它: 有什么不同?目的是什么?我知道Python 2.6.x默认情况下会设置ASCII编码,但是它可以被标头声明覆盖,那么每个字符串声明有