.NET(C#)开发漫谈:关于变量的命名和属性

 我来答
舒适还明净的海鸥i
2022-11-27 · TA获得超过1.7万个赞
知道小有建树答主
回答量:380
采纳率:0%
帮助的人:70.5万
展开全部

  static readonly与const的变量 作用是一样的 无论访问修饰符是不是public 还是其它(private protected internal) 变量名称一般为大写 中间以下划线

  public static readonly int MAX_HEIGHT;  public const int MIN_HEIGHT = ;

  有些程序员对大写不敏感 上例中 MAX_HEIGHT用Max_Height代替也未尝不可 甚至MaxHeight也可以 在 Net类库中 int MaxValue与int MinValue便是这样定义的

  const常量更确切的说是编译时常量 因为它在运行时是不存在的 在编译中所有变量引用将被实际值替掉 而static readonly则不然 它在运行时也是存在的 从原理上讲 论效率const优于static readonly 但是在一个比较在的项目中 在dll局部升级时 如果改变了某个const变量的值 而未升级的dll如果也有这个const变量的话 显而易见这时候问题将是产生 如果因此而升级全部dll 反而不值 所以在大型 多变应用中 建议使用static readonly代替const 其微乎其微的效率的减损对比升级布置可能出现的问题还是可以接受的

  除了以上两种静态只读和常量变量之外 其它变量命名均以下划线开始 访问修改符为private(不建议命名为internal protected 更不建议命名为public)

  private static int _maxHeight;  private int _minHeight; 如果其命名不前置下划线 易与参数变量混淆

  对于下面这种定义

  private int _minHeight = default(int);  public int MinHeight  {   set{    _minHeight = value;   }   get{    return _minHeight;   }  }

  初学者可能觉得有点画蛇添足 不如直接命名为

  public int MinHeight; 这样岂不简单 干吗还要用getter和setter封装起来 额外的函数调用也使效率有损

  有时候在开发项目时 开始时我们要画的可能只是一条蛇 但是项目后期需求变了 改画一条龙了 所以在项目初期画蛇的时候添上一对足还是很有远见的

  getter与setter(属性存取器)可以像方法一样封装逻辑并且像变量一样使用 建议所有非静态只读和常量 定义为private 然后给其添加相应属性存取器 用于赋值与读取 在其它方法体内(包涵类外与类内) 不建议直接读写变量 即使它目前可以被直接读写 我们也要通过调用属性存取器也调用 这一点有点麻烦 但很重要 很高老手有时也会犯错误 如下所示

  private int _minHeight = int MinValue;  public int MinHeight//或者是protected internal 甚至是private  {   set{    _minHeight = value;    //即使这里目前没有其它处理逻辑   }   get{    return _minHeight;   }  }  public void Method (int minHeight)  {   this MinHeight = minHeight;//在这里不要使用this _minHeight直接读写   //  }

  即使变量的访问是受保护的或者或者是私有的 也要使用属性存取器

lishixinzhi/Article/program/net/201311/15697

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式