zoukankan      html  css  js  c++  java
  • C#枚举类型解析

    枚举是开发者可以定义的一个类型。枚举的关键特征是它标识了一个在编译时定义的所有可能值得集合,每个值都由一个名称来引用,这就使得代码更加的易读。我们采用与类相似的语法来定义一个枚举(枚举类型的声明必须跟类是平级的),如:

    enum ConnectionState
        {
            Disconnected,
            Connecting,
            Connected,
            Disconnecting
        }


    布尔类型的参数也适合使用枚举。例如:像SetState(DeviceState.On)这样的方法调用要比SetState(true)更易读。

    要引用一个枚举值,需要为其附加枚举名称前缀。例如,要引用Connected的值,需要使用ConnectionState.Connected。在枚举值名称中,不允许使用枚举名称,根据约定,枚举名称本身应该使用单数形式,除非枚举是为标志。

    默认情况下,第一个枚举值是0(技术上说,是0显式转型为基础枚举类型),后续每一项都递增1,然而可以显式的为枚举赋值,代码如下:

    //显式的为枚举值赋值
        enum ConnectionState : short
        {
            Disconnected,
            Connecting=10,
            Connected,
            Joined=Connected,
            Disconnecting
        }


    Disconnected任然具有默认值0,Connection被赋值为10,后面Connected的值为11,随后Joined也被赋值为11也就是有Connected引用的值(将Connected引用的值赋给Joined时,不需要为Connected附加枚举名称前缀,因为目前正处在枚举的作用域内)。Disconnecting自动递增1,值为12.

    枚举总是具有一个基础类型,这可能是int,uint,long和ulong,但不能使char。

    事实上,枚举类型的性能完全取决于基础类型的性能。默认的基础类型为int,但是可以使用继承的语法来指定一个不同的类型。

    在上面的代码中,使用的是short,而不是int。为了保持一致性,这里使用了继承的语法,但没有建立真正的继承关系。

    枚举之间的类型兼容性

    C#不支持两个不同的枚举数组之间的直接转型。但是可以使用强制的转换,就是先转型为一个数组,在转型为第二个枚举。这里要求两个枚举具有相同的基础类型,而且必须先转型为System.Array,代码如下:

    static void Main(string[] args)
            {
                ConnectionState1[] states = (ConnectionState1[])(Array)new ConnectionState2[42];
            }
    //枚举数组之间的转型
        enum ConnectionState1
        {
            Disconnected,
            Connecting,
            Connected,
            Disconnecting
        }
    
        enum ConnectionState2
        {
            Disconnected,
            Connecting,
            Connected,
            Disconnecting
        }


    这个技巧利用了ClR的赋值兼容性比C#宽松这一事实。(还可以同样的技巧进行非法转换,比如int[]转换为uint[])。然而,使用时必须谨慎,C#规范没有说不同的CLR实现中,这个技巧都应该正常的发挥作用。

  • 相关阅读:
    el-table背景色透明
    判断数组对象里的属性值是否重复
    :Duplicate keys detected: 'xxx'. This may cause an update error.
    钉钉微应用附件下载方案
    探索JS引擎工作原理
    js深度优先遍历和广度优先遍历实现
    微前端qiankun从搭建到部署的实践
    浏览器与Node的事件循环(Event Loop)有何区别?
    JS
    微信小程序预览Word文档
  • 原文地址:https://www.cnblogs.com/yisuowushinian/p/2498428.html
Copyright © 2011-2022 走看看