【C#】字段总结

前沿:

  字段(field)是一种数据成员,其中容纳了一个值类型的实例或者一个引用类型的引用。

正文:

  CLR支持类型(静态)字段和实例(非静态)字段。对于类型字段,用于容纳字段数据的动态内存是在类型对象中分配的,而类型对象是在类型记载到一个AppDomain时创建的。那么,什么时候要将类型加载到一个AppDomain中呢?这通常是在引用了该类型的任何方法首次进行JIT编译的时候。对于实例字段,用于容纳字段数据的内存则是在构造类型的一个实例时分配的。

  由于字段存储在动态内存中,所以他们的值在运行时才能获取。字段还解决了常量存在的版本控制问题。此外,字段可以是任何数据类型,不必像常量那样仅仅局限于编译器内置的基元类型。那什么是基元类型呢(int 、unit等等)?

  基元类型:编译器直接支持的数据类型。如果没有基元类型,我们在声明一个整数的时候应该是这样子的

Int32 a=new Int32;

  幸运的是有了基元类型,我们可以直接用下面的方法,也就是我们在编程的时候经常用到的:

int a=0;

  再比如string和String,刚开始我对这两个类型很困惑,到底什么时候用哪一个呢,但是看了基元类型的讲解,你就会明白,由于C#的string直接映射到String(FCL类型),所以两者没有区别,都可以使用。

  CLR支持readonly字段和read、write字段。大多数字段都是read和write字段,这意味着在代码执行过程中,字段值可以多次改变。但是readonly字段只能在一个构造器方法中写入。(这个构造器方法只能调用一次,也就是对象首次被创建时),编译器和验证机制确保readonly字段不会被构造器以外的方法写入。但是可以利用反射来修改。

  现在我们使用一个静态readonly字段来修正版本控制问题:

1 public sealed class someType
2 {
3       public static readonly int MaxList=50;
4 }

  这是唯一需要修改的,应用程序的代码不必修改。但是们为了观察新的行为,必须重新生成他,当应用程序的Main方法运行时,CLR将加载到DLL程序集,并从分配给他的动态内存中提取MaxList字段的值50.

  假设DLL程序集的开发人员将50改为100,并重新生成程序集。当应用程序代码重新执行时,他将自动提取字段的新值100,在这种情况下,程序不需要重新生成,他可以直接运行。要注意的是,当前假定的是DLL程序集的新版本没有进行强命名。

  下面这个演示了如何定义一个与类型本身关联的readonly静态字段和读写字段。另外还定义了read/write静态字段。

 class ServiceLocator
    {
        //静态只读字段,在运行时对这个类进行初始化时,他的值被存到内存中
        public static readonly Random random = new Random();

        private static int numberwrites = 0;

        public readonly string PathName = "Unity";

        private FileStream fs;

        public ServiceLocator(string pathname)
        {
            //在构造器中可以修改只读字段
            this.PathName = pathname;
        }

        public string Do()
        {
            numberwrites += 1;
            return PathName;
        }
    }

  在上述代码中,许多字段都是内联初始化的(就是直接在代码中直接赋值来初始化,而不是通过构造函数),C#允许使用这种方法来初始化类的常量、读写字段、只读字段。C#实际上是在构造函数中对字段进行初始化的,字段的内联初始化只是一种语法上的简化。

  注意,当某个字段是引用类型,并且该字段被声明为只读时,那么不可改变的是引用本身,而不是引用的对象(也就是分配在堆中的值)。

  

  public static readonly char[] Inva = new char[] { ‘a‘,‘B‘,‘C‘};

        public void Test()
        {
            Inva[0]=‘v‘;//我们可以改变引用的对象,也就是改变引用指向的地址
            Inva = new char[] { ‘x‘,‘y‘,‘z‘};//无法改变引用本身
        }

【C#】字段总结,布布扣,bubuko.com

时间: 2025-01-05 00:03:43

【C#】字段总结的相关文章

SQL查询字段添加括号报错:Operand should contain 1 column(s)

SQL语句:查询连个字段的信息 SELECT (menu_id,menu_captions) FROM bsdb.menulist a WHERE a.menu_id like ('2_'); 然后,因为这是在存储过程中的一个语句所以,在执行存储过程的时候编译不会报错,但是执行的时候却汇报错:Operand should contain 1 column(s):原因不好解释: 下面是官方发解释(MYSQL):https://dev.mysql.com/doc/refman/5.0/en/row-

SqlServer给一个表增加多个字段语法

添加字段语法 alter table table_name add column_name +字段类型+ 约束条件 给一个表增加多个字段: use NatureData go alter table XunHu add MaleCount varchar(50) null, FemaleCount varchar(50) null, SubadultCount varchar(50) null, LarvaeCount varchar(50) null, TraceType varchar(50

查询字段描述sql-postgresql

查询字段描述sql SELECT 'comment on column ' || n.nspname ||'.'|| c.relname || '.' || a.attname ||' is '''|| col_description(a.attrelid,a.attnum) ||''';' FROM pg_class as c join pg_attribute as a on a.attrelid = c.oid join pg_namespace n on c.relnamespace=n

passwd、shadow、group结构及各字段含义

/etc/password结构 sample:root:x:0:0:root:/root:/bin/bash 账号名称 密码 UID GID 用户信息说明 家目录 Shell root x 0 0 root /root /bin/bash /etc/shadow结构: sample:root:$1$/30QpE5e$y9N/D0bh6rAACBEz.hqo00:14126:0:99999:7::: 账号名称 密码 最近更动密码的日期 密码不可被更动的天(0代表随时可以变动) 密码需要重新变更的天

快学Scala 第二十一课 (初始化trait的抽象字段)

初始化trait的抽象字段: trait Logged { println("Logged constructor") def log(msg: String){ println("Logged")} } trait FileLogger extends Logged { var filename: String override def log(msg: String) { println("filename:" + filename) } }

Sql Server将一列字段拼接成字符串方法

最近在项目中遇到个问题,需要将表中某列字段合并成字符串输出,如果直接通过代码全部读取出来,再遍历进行拼接显然不是最好的方法,所以想着能否在数据读取的时候直接拼接好返回,网上搜了可通过for xml来实现. 首先,准备好需要的数据,脚本如下: if exists (select * from sysObjects where id=object_id('Student')) drop table Student go create table Student ( Id int, Name varc

MySQL指定模糊查询范围 或 获取或者查询数据库字段的特定几位

SUBSTR 函数 正常的: select * from sky_user WHERE name LIKE "%name%" 现在我需要匹配name的前五位 select * from sky_user WHERE SUBSTR(name,1,5) LIKE "%name%" SQL 中的 substring 函数是用来抓出一个栏位资料中的其中一部分.这个函数的名称在不同的资料库中不完全一样: MySQL: SUBSTR( ), SUBSTRING( ) Oracl

Oracle 增加修改删除字段

添加字段的语法:alter table tablename add (column datatype [default value][null/not null],-.); 修改字段的语法:alter table tablename modify (column datatype [default value][null/not null],-.); 删除字段的语法:alter table tablename drop (column); 添加.修改.删除多列的话,用逗号隔开. 使用alter

[Elasticsearch] 关于字段重复值的常用查询和操作总结

1. 取得某个索引中某个字段中的所有出现过的值 这种操作类似于使用SQL的SELECT UNIQUE语句.当需要获取某个字段上的所有可用值时,可以使用terms聚合查询完成: GET /index_streets/_search?search_type=count { "aggs": { "street_values": { "terms": { "field": "name.raw", "siz

MySQL字段属性介绍

这次Qi号分享MySQL字段属性简介.下面资料是Qi号搜集大量资料与个人理解的整理.看到最后有福利哦基友们 前言 MySQL提供了一组可以赋给表中各个列的数据类型,每个类型都强制数据满足为该数据类型预先确定的一组规则,例如大小.类型及格式. 这里先总结数据类型.MySQL中的数据类型大的方面来分,可以分为:日期和时间.数值,以及字符串.下面就分开来进行总结. 日期和时间数据类型 MySQL数据类型   含义 date 3字节,日期,格式:2014-09-18 time 3字节,时间,格式:08: