内容简介:根据我在阅读D时的理解,当在变量上使用immutable关键字时,变量的值必须在编译时知道,而C#的readonly不需要,并且readonly字段可以在类构造函数中使用non分配 – 静态价值观.这可能在D?翻译自:https://stackoverflow.com/questions/6036807/equivalent-of-c-sharp-readonly-keyword-in-d
根据我在阅读D时的理解,当在变量上使用immutable关键字时,变量的值必须在编译时知道,而C#的readonly不需要,并且readonly字段可以在类构造函数中使用non分配 – 静态价值观.这可能在D?
由于似乎存在一些关于不可变的混淆(来自原始问题和he_the_great的评论),我想我会补充一下.
当你说immutable int i = 42时,你说我不会被修改,而不是在编译时知道它的值. immutable实际上是一个类型修饰符,并创建一个新类型. immutable T是不可变(T)的简写. immutable(T)创建一个永远不会变异的T,也就是说,如果你读取了值,然后调用一个函数,则值将是相同的.将此与const(T)进行比较,它提供了较弱的保证,即该类型的实例不会被修改,但有人可能对其他地方有可变的访问权限,所以如果你读取该值然后调用一个函数,你就不能假设价值会是一样的.
通常,不可变(T)!= T.但是在某些情况下,它们可以隐式地相互转换.例如,如果T是一种据说没有“可变间接”的类型.也就是说,如果我传递一个函数一个不可变(int),它们会收到一个副本 – 如果类型系统不允许,那么该函数无法修改我传递的值,因为它被复制了它只会令人烦恼而没有额外的保证,所以D型系统允许它.但是,如果我传递一个immutable(int *),那么可以通过调用函数进行更改.在结构的情况下,如果任何成员具有可变间接,那么结构也被认为具有它.
因此,为了摆脱理论并回到更实际的问题,在编译时必须知道不可变值,并且没有好的方法来创建它们.但是,唯一的突变可能发生在构造函数内部.对于简单的标量类型,这很明显:
immutable(int) i = rand();
但是像物体一样呢?好吧,构建我们使用的类型T.
auto t = new T();
所以要构造我们使用的类型immutable(T)
auto t = new immutable(T)();
这是一个更完整的小例子
class Useless { int i; this(int i) { this.i = i; } } int main(string[] args) { auto o = new immutable(Useless)(cast(int) args.length); //o.i = 17; error return o.i; // fine }
如您所见,构造函数内部可能发生变异.您可以读取成员变量,但不能写它们(不可变是传递的;也就是说,如果父进程,每个成员(以及成员的每个成员)都变为不可变.只有当它们被标记为const时才能调用方法.
我为偏离话题的漫无边际道歉,但我看到很多人似乎对这个话题感到困惑.
翻译自:https://stackoverflow.com/questions/6036807/equivalent-of-c-sharp-readonly-keyword-in-d
以上所述就是小编给大家介绍的《D中C#`readonly`关键字的等价物?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- P1003 等价表达式
- Python列表推导式一则:等价类划分
- 数据中心网络等价多路径ECMP技术
- 正则表达式 \D 元字符(等价于"[^0-9]")
- 技术盛宴 | 数据中心网络等价多路径(ECMP)技术应用研究
- 等价加密算法组并不是 HTTPS 性能调优的利器
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。