c# 常量和字段
- 作者: 听说好名字都起不了了
- 来源: 51数据库
- 2021-08-20
它的值是在编译时确定的。编译器将常量保存到程序集的元数据中,所有只能是编译器认识的基元类型作为常量。
常量被看成类的一部分,是看出静态成员。
代码引用一个常量符号,会在定义常量的元数据中查找该符号,提取之,并嵌入代码,生成的il中是值本身。
在c#中使用的是const关键字。
字段:已一种数据成员,可以容纳任何的数据类型,不仅仅想常量一样只能存储基元类型。
clr支持类型字段和实例字段
类型字段:用于容纳字段数据的动态内存是在类型对象中分配的,
而类对象是在类型加载到一个appdomain中创建的。
通常是在引用该类型的任何方法首次进行jit编译的时候。
实例字段:用于容纳字段数据的动态内存是在构造类型的实例时分配的。
由于字段存储在动态内存中,所以它们的值在运行时才获取,字段解决了常量存在版本控制的问题。
clr支持readonly 字段 和 read/write字段
read、write字段可以在代码中多次改变。
readonly字段只能在构造器方法中写入,也就是在对象首次创建的时候。
编译器和验证机制会确保readonly字段不会在构造器以外的地方写入。
在c#中允许内联初始化语法来初始化类的字段。c#实际是在构造器中对字段进行初始化的,内联代码只是语法糖。
常量被看成类的一部分,是看出静态成员。
代码引用一个常量符号,会在定义常量的元数据中查找该符号,提取之,并嵌入代码,生成的il中是值本身。
在c#中使用的是const关键字。
字段:已一种数据成员,可以容纳任何的数据类型,不仅仅想常量一样只能存储基元类型。
clr支持类型字段和实例字段
类型字段:用于容纳字段数据的动态内存是在类型对象中分配的,
而类对象是在类型加载到一个appdomain中创建的。
通常是在引用该类型的任何方法首次进行jit编译的时候。
实例字段:用于容纳字段数据的动态内存是在构造类型的实例时分配的。
由于字段存储在动态内存中,所以它们的值在运行时才获取,字段解决了常量存在版本控制的问题。
clr支持readonly 字段 和 read/write字段
read、write字段可以在代码中多次改变。
readonly字段只能在构造器方法中写入,也就是在对象首次创建的时候。
编译器和验证机制会确保readonly字段不会在构造器以外的地方写入。
在c#中允许内联初始化语法来初始化类的字段。c#实际是在构造器中对字段进行初始化的,内联代码只是语法糖。
推荐阅读
- C#通过fleck实现wss协议的WebSocket多人Web实时聊天(附源码)
- 团队城市未满足要求:MSBuildTools12.0_x86_Path 存在
- 使用 MSBuild.exe 在发布模式下构建 C# 解决方案
- 当我发布 Web 应用程序时,AfterPublish 脚本不运行
- 构建时 T4 转换的产品仅在下一个构建中使用
- ASP.NET Core Application (.NET Framework) for Windows x64 only error in project.assets.json
- 新的 .csproj 格式 - 如何将整个目录指定为“链接文件"到子目录?
- 如何将条件编译符号(DefineConstants)传递给 msbuild
- MSBuild 支持 Visual Studio 2017 RTM 中的 T4 模板
- NuGet 包还原找不到包,没有源
热点文章
团队城市未满足要求:MSBuildTools12.0_x86_Path 存在
0
使用 MSBuild.exe 在发布模式下构建 C# 解决方案
0
当我发布 Web 应用程序时,AfterPublish 脚本不运行
0
构建时 T4 转换的产品仅在下一个构建中使用
0
ASP.NET Core Application (.NET Framework) for Windows x64 only error in project.assets.json
0
新的 .csproj 格式 - 如何将整个目录指定为“链接文件"到子目录?
0
如何将条件编译符号(DefineConstants)传递给 msbuild
0
MSBuild 支持 Visual Studio 2017 RTM 中的 T4 模板
0
NuGet 包还原找不到包,没有源
0
使用 C# 6.0 功能运行 TFS 构建
0
