zoukankan      html  css  js  c++  java
  • .NET中Flags枚举

    .NET中Flags枚举

     .NET中的枚举我们一般有两种用法,一是表示唯一的元素序列,例如一周里的各天;还有就是用来表示多种复合的状态。这个时候一般需要为枚举加上[Flags]特性标记为位域,例如:

    1 [Flags] 
    2 enum Styles
    3 { 
    4 ShowBorder = 1,
    5 ShowCaption = 2,
    6 ShowToolbox = 4
    7 } 

      这样我们就可以用"或"运算符组合多个状态,例如:

    1 myControl.Style = Styles.ShowBorder | Styles.ShowCaption; 

      这时myControl.Style枚举的值将变成 1+2=3,它的ToString()将变成"Styles.ShowBorder , Styles.ShowCaption" 

    这里我们可以解释为什么第三个值ShowToolbox可以为4,5..而不能为3。也就是说它的值不应该是前几项值的复合值。有一个比较简单的方法就是用2的n次方来依次为每一项赋值,例如 1,2,4,8,16,32,64..... 

    现在举个常见的Flags应用例子。例如一个简单的权限系统,有"Admin"和"User"两种角色,我们可以在表中放一个 varchar()字段,以文本形式存放权限字"Admin,User"。但是用Flags型枚举的话,我们就可以直接将 Roles.Admin | Roles.User 的值放在一个int字段里。 

    以下是关于枚举的一些常见操作: 
    将枚举的值变回枚举对象: 
    Styles style = (Styles) Enum.Parse(typeof(Styles), 4 );    // -> style = Styles.Toolbox; 
      检查枚举是否包含某个元素: 
    bool hasFlag = ((style & Styles.ShowBorder) != 0); 
    其实我们还会碰到一种情况,就是需要从组合状态中去掉一个元素。用"^"运算符可以做到:

    1 Styles style = Styles.ShowBorder | Styles.ShowCaption; 
    2 style = style ^ Styles.ShowBorder; 

      这个时候style的值就会变成 Styles.ShowCaption 

    但这里有一个很严重的问题,再执行一次 

    style = style ^ Styles.ShowBorder; 

     style 的值却又变成了 Styles.ShowBorder | Styles.ShowCaption !! 再执行一遍,又会去掉这个元素,周而复始。 
    当然我们可以在去掉某个元素前做一番检查,如果枚举包含这个元素,再去掉它:

    1 if ((style & Styles.ShowBorder) != 0)
    2 { 
    3     style = style ^ Styles.ShowBorder; 
    4 } 

      其它方法方便地从Flags枚举状态中去掉一个元素

    1 style = style & (~Styles.ShowBorder) 

    参考博客地址:https://www.cnblogs.com/sunShineJing/articles/2814619.html

  • 相关阅读:
    python测试开发django-43.xadmin添加小组件报错解决
    python测试开发django-42.xadmin自定义菜单项
    python测试开发django-41.crispy-forms设计标签式导航菜单(TabHolder)
    python测试开发django-40.模型(model)中choices使用
    python测试开发django-39.xadmin详情页面布局form_layout
    python测试开发django-45.xadmin添加小组件报错解决
    django后台xadmin如下配置(小结)
    禅道环境一键安装搭建指南
    Centos6.9部署ORTS5.0.22
    Linux 进程管理之四大名捕
  • 原文地址:https://www.cnblogs.com/VueDi/p/14260773.html
Copyright © 2011-2022 走看看