EffectiveC#2--为你的常量选择readonly而不是const

1.对于常量,C#里有两个不同的版本:

编译时常量--效率相比更高些,但可维护性不好,保留的目的是为了性能。const关键字申明

public const int _Millennium = 2000;

运行时常量--效率稍低些,可维护性好。readonlyc关键字声明,也叫只读变量。

public static readonly int _ThisYear = 2007

2.两者的区别;

编译时常量只能是基本类型,枚举或者是字符串。编译时常量会被目标代码中的值直接取代

运行时常量可以是任何类型的数据。运行时常量动态取值(动态指运行时确定值)。

注意:运行时常量可以在定义变量时设定值或在构造函数中初始化,其他地方不可以再修改。

举例:private const DateTime _classCreation = new DateTime(2000,1,1,0,0,0);  //ERROR 值编译时不确定

private readonly DateTime _classCreation = new DateTime(2000,1,1,0,0,0);//PASS

另外:运行时常量可以是一个类的实例成员,也可以是一个类型的静态成员,而编译时常量只能是静态成员

3.对可维护性的解释

例子:一个类库中定义一个编译时常量,类库被客户端引用,当类库中常量值需更改时,客户端需要重新编译,否则取出的

值有问题,而对于运行时常量不存在这样的问题。

4.  const应该用于定义一个值且该值不能在不同的版本发布时发生改变的常量

时间: 2024-10-11 12:40:31

EffectiveC#2--为你的常量选择readonly而不是const的相关文章

in C#,编译型常量(const)和运行时常量(readonly)

readonly 关键字与 const 关键字不同. const 字段只能在该字段的声明中初始化. readonly 字段可以在声明或构造函数中初始化. 因此,根据所使用的构造函数, readonly 字段可能具有不同的值. 另外, const 字段是编译时常量,readonly 字段为运行时常量. 你应该尽量使用运行时常量.原因是变异性常量虽然性能稍微快一些.但是却没有 运行时常量那么灵活.就像第一段中所说,使用readonly时,根据使用的构造函数, readonly字段可能具有不同的值.

优先选择nullptr而不是0和NULL

我们知道:0是一个int,而不是一个指针.如果C++在一个只有指针才能够使用的上下文中发现它只有一个0,那么它会勉强将0解释成空指针,但那时一种倒退行为.C++的主要方针是0就是一个int,而不是指针. 实际上来说,对于NULL也是一样.关于NULL还有一些不确定因素,因为其实现允许给NULL一个整型而不必是int(比如说long).这并不常见,但是也无关紧要,因为这里的问题并不是NULL的确切类型是什么,而是0和NULL都不是指针类型. 在C++98中,主要的启示就是对指针和整型分别进行重载可

PHP常量定义之define与const对比

简要归纳PHP中两个常量定义关键字的区别: 1.define是函数,const是语言结构,PHP编译时const速度快.2.define只能用在类外,const类内类外皆可.3.define定义的常量是全局的,const定义的常量受命名空间限制.4.define可用在条件语句中,const不能.5.define可用表达式作为名称,const只可采用普通常量名称.6.const只能接受静态的标量,而define可以采用任何表达式.7.const定义的常量时大小写敏感,而define可以通过第三个参

两种常量类型-readonly和const

C#中有两种常量类型,分别为readonly(运行时常量)与const(编译时常量),本文将就这两种类型的不同特性进行比较并说明各自的适用场景.工作原理 readonly为运行时常量,程序运行时进行赋值,赋值完成后便无法更改,因此也有人称其为只读变量. const为编译时常量,程序编译时将对常量值进行解析,并将所有常量引用替换为相应值. 下面声明两个常量: public static readonly int A = 2; //A为运行时常量public const int B = 3; //B

为什么很多人使用#define而不是const定义常量

众所周知,C语言一开始只有#define,C程序员用#define定义符号常量.但后来ANSI C加入了const限定符,而const应该比#define更好,为什么现在的C程序员还在大量使用#define来定义常量呢? 这并不是我没有根据地乱说的.这样的例子有很多,例如<limits.h>,例如Windows API,例如OpenGL-- <limits.h>是C标准头文件,发明C语言的人为什么不知道const吗? Windows是Microsoft开发的,难道Microsoft

常量函数(函数后加const)

const用在成员函数后 主要是针对类的const 对象 如: class Text{ public:     void printconst(void)const{cout<<"hello"<<endl;}     void print(void){cout<<"hello"<<endl;} private:     int k; }; const Text a; //上面定义了类Text的一常量对象 int mai

宏常量,宏替换,const常量

(1)宏常量也称为符号常量,是指用一个标识符号来表示的常量,宏常量是由宏定义编译预处理命令来定义的,宏定义的一般形式:#define 标识符 字符串 宏定义中的标识符被称为宏名,将程序中出现的宏名替换成字符串的过程称为宏替换,宏替换时是不做任何语法检查的,因此,只有在对已经被宏展开后的源程序进行编译时才会发现语法错误 (2)const常量:使用宏常量的最大问题是,宏常量没有数据类型.那么是否可以声明具有某种数据类型的常量呢?这就是const常量 const常量被编译器放在只读存储区,不允许在程序

大型数据中心内部路由选择:为何选择BGP而不是OSPF

大型数据中心fabric往往把BGP作为内部路由协议的原因:1.BGP比IGP具有更简单的状态机和数据库:2.BGP交换的是路由,直接命令,不需要运行算法(比如SPF)来计算路径:3.BGP支持逐跳流量工程:4.路由传播来说,BGP范围更小(对等体传播,OSPF需要链路状态泛洪),因此更稳定. IBGP和EBGP的选择:1.EBGP会话一般建立在BGP对等体的链路上,IBGP一般建立在BGP对等体的环回接口上:2.EBGP使用AS-path防止环路,IBGP在同一AS内,使用水平分割原则:默认从

我们为什么在移动端项目中选择jQuery而不是Zepto

1.文件大小比较 首先从cnd上(http://www.bootcdn.cn/)下载jquery和zepto. jquery下载的是2.2.4版本压缩: zepto下载的是是1.20压缩版本: 二个文件大小比较: jquery.min.js 大小为:83.5k zepto.min.js大小为:25.7k 总结:zepto文件确实小,但是由于目前网民移动设备网络带宽好.流量多,浏览器都会都会缓存js,并且网站一般都会使用gzip对js文件进一步压缩,所以文件大小只会影响用户第一次加载网页. 2.j