博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Readonly与const初识
阅读量:6174 次
发布时间:2019-06-21

本文共 2447 字,大约阅读时间需要 8 分钟。

对于readonly和const,很多人无法具体区分,不清楚它们的具体使用场合;现在我们分析它们之间的区别和使用场合。

const是一个编译期常量;const只能用于修饰基元类型、枚举类型或者字符串类型,具有局限性;

因为const是编译期常量,所以const天然就是static的,不用手动的为其增加static修饰符,例如:

static const int ConstValue = 100;

编译时,将会提示“常量 ConstValue不能标记为static”;

const最大的优点在于 “效率”,这也是使用const的理由,之所以说const效率高,是因为它在经过编译器编译后,我们在代码中引用const变量的地方会用const变量所对应的实际的值来代替,例如:

Console.WriteLine(ConstValue);

其实代码生成的IL代码则为

Console。WriteLine(100);

此时程序将不再通过变量来寻找对应的值。

然而readonly是一个运行时常量,并且readonly可以修饰任何类型,没有限制,其赋值行为发生在运行时,readonly的全部意义在于,它在运行时第一次被赋值后将不可以改变,当然了,这个可以分为两个意思

1.对于值类型变量,值本身不可改变

2.对于引用类型变量,引用本身不可改变(指针不可改变)

先说说值类型,例如:

class Employee {        public readonly int ReadOnlyNumber;        public Employee(int value) {            ReadOnlyNumber = value;        }    }
View Code

Employee的实例ReadOnlyNumber在构造方法中被赋值,之后将不可改变,例如

Employee emp = new Employee(100);            emp.ReadOnlyNumber = 20;

此代码将无法通过编译,提示“无法对只读字段赋值(构造函数或者变量初始值指定项中除外)”;

针对于引用类型变量,我们可以做如下的修改

class Boss {        public string Name { get; set; }    }    class Employee2    {        public readonly Boss ReadOnlyBoss;        public Employee2(Boss value)        {            ReadOnlyBoss = value;        }    }

Employee2的ReadOnlyBoss是一个引用类型变量,在其被赋值后,变量不能再指向任何其他的Boss实例;例如

Employee2 emp2 = new Employee2(new Boss() { Name="Witt"});            emp2.ReadOnlyBoss = new Boss() { Name = "Witt2" };

这段代码将无法编译成功,因为ReadOnlyBoss不能在赋值后再指向任何其他的实例。

但是呢,之前我们说过,引用本身不可改变,但是引用所指向的实例的属性值却可以随意修改,例如下面这段代码将可以通过

Employee2 emp2 = new Employee2(new Boss() { Name="Witt"});            //emp2.ReadOnlyBoss = new Boss() { Name = "Witt2" };            emp2.ReadOnlyBoss.Name = "Witt2";

readonly所代表的运行时含义有一个重要的作用,就是可以为每一个类的实例指定一个readonly的变量,我们以前面的Employee来举例说明;

Employee e1 = new Employee(10);            Employee e2 = new Employee(100);            Employee e3 = new Employee(200);            Employee e4 = new Employee(300);            Employee e5 = new Employee(400);

在这里,每个实例都生成了自己的readonly变量,这也就是readonly的优点。

好了,说了这么多,相信大家也都明白了,const的优点在于效率,但却没有readonly灵活,在程序对效率的要求并不高时(效率的地位不高),readonly则成为你更好的选择,因为readonly没有更多的灵活性。

现在说一下注意点,之前我说过readonly在赋值之后将不能被再次赋值,这是错误的,下面这个例子将很好的说明这一点

class Employee {        public readonly int ReadOnlyNumber = 50;        public Employee(int value) {            ReadOnlyNumber = value;            ReadOnlyNumber += 20;            ReadOnlyNumber *= 2;        }    }

ReadOnlyNumber在初始化器中被赋值为50,后来,在构造中又被多次赋值;实际上,我们可以将初始化器理解成构造方法的一部分,在构造方法中,我们确实可以多次对ReadOnlyNumber赋值。

 

转载于:https://www.cnblogs.com/xufei/p/3530431.html

你可能感兴趣的文章
通过Docker进程pid获取容器id
查看>>
L15.2 zabbix基础(2)组件说明介绍
查看>>
impdp 常见问题 10g/11g/12c 问题解决 ERIKXUE
查看>>
2013年1月工作小结 -- 上线后的懈怠
查看>>
敏捷宣言
查看>>
php Yii: 出现undefined offset 或者 undefined index解决方案
查看>>
Bash编程入门
查看>>
org.tinygroup.binarytree-二叉树
查看>>
5.6-全栈Java笔记:内部类的四种实现方式
查看>>
Linux微职位学习笔记-终端
查看>>
自己写了一个友盟推送的util
查看>>
Mapreduce 扫描hbase表建立solr索引
查看>>
RHEL 5.8 yum本地源
查看>>
Teams 新功能更新【五月底】Busy on Busy 忙线音
查看>>
orzdba安装与使用
查看>>
二叉搜索树的插入叶子结点的递归实现方法
查看>>
通过nginx配置不同二级域名代理多个系统
查看>>
linux基础篇-23,文件系统管理
查看>>
keepalived+nginx高可用配置
查看>>
node.js爬虫爬取电影天堂,实现电视剧批量下载。
查看>>