zoukankan      html  css  js  c++  java
  • C#编码标准--命名约定和风格

    1. 使用Pascal的命名规范命名类型和方法的名字。
    public class SomeClass
    {
        public SomeMethod(){}
    }
    2. 使用camel命名规范命名局部变量和方法的参数。
    int number;
    void MyMethod(int someNumber)
    {}
    3. 在命名接口的时候使用I作为前缀。
    interface IMyInterface
    {...}
    4. 私有成员变量使用m_作为前缀。
    public class SomeClass
    {
       private int m_Number;
    }
    5. 自定义的属性类使用Attribute作为其后缀。
    6. 自定义的异常类使用Exception作为其后缀。
    7. 在命名方法的时候使用动宾结构的短语,比如:ShowDialog()。
    8. 有返回值的方法应该有一个可以描述其返回值的名字,比如:GetObjectState()。
    9. 使用有意义的变量名称。
    10. 使用C#的预定义的类型而不使用System命名空间中其别名来申明变量。
    使用object 而不是 Object
    使用string 而不是 String
    使用 int 而不是 Int32
    11. 通常情况下,类型使用大写字母。当处理.NET的类型的时候使用Type作为其后缀。
    //正确的是:
    public class LinkedList<K,T>
    {…}
    //避免使用:
    public class LinkedList<KeyType,DataType>
    {…}
    12. 使用有意义的命名空间,比如使用公司的名称以及产品的名称。
    13. 避免使用完全限定名。而使用using语句替换之。
    14. 避免将using语句写在命名空间的内部。
    15. 将所有的框架定义的命名空间为一组,自定义的和第三方的命名空间放在另一组。
    using System;
    using System.Collections.
    using System.ComponentModel;
    using System.Data;
    using MyCompany.
    using MyControls;
    16. 使用委托的引用替换显式的委托实例。
    delegate void SomeDelegate();
    public void SomeMethod()
    {…}
    SomeDelegate someDelegate = SomeMethod;
    17. 保持严格的缩进风格。
    a. 使用3个空格缩进
    b. 不要使用tabs或者其他不标准的缩进,比如1、2、4个空格。
    18. 在编写注释的时候注释的缩进和编码的缩进必须是相同级别的。
    19. 所有的注释都要通过拼写检查,错误的拼写是粗糙的开发。(针对汉语则要语句通顺易于理解)
    20. 所有的成员变量都应该声明在顶部,同时使用一个空行来将他们和属性以及方法分开。
    public class MyClass
    {
       int m_Number;
       string m_Name;
      
       public void SomeMethod1()
    {}
       public void SomeMethod2()
    {}
    }
    21. 尽可能在第一次使用局部变量的时候申明它。
    22. 文件名称应该可以反映出它所包含的类。
    23. 当使用不完整的类并且将部分分配到每个文件中,用P+序数作为后缀命名文件。
    // in myClassP1.cs
    public partial class MyClass
    {…}
    // in myClassP2.cs
    public partial class MyClass
    {…}
    24. 总是将大括号放在一个新行上。
    25. 匿名方法和一般(正规)的方法代码使用相似的代码布局
    a. 规定:大括号(方法体的括号)必须使用新行
    delegate void SomeDelegate(string someString);
    // 正确的是:
    public void InvokeMethod()
    {
       SomeDelegate someDelegate = delegate(string name)
    {
       MessageBox.Show(name);
    };
       someDelegate(“Juval”);
    }
    // 避免使用:
    public void InvokeMethod()
    {
       SomeDelegate someDelegate = delegate(string name){ MessageBox.Show(name);};
       someDelegate(“Juval”);
    }
    26. 在匿名无参方法中要使用空的括号。
    a. 如果匿名方法有可能被使用在任何委托中那么可以省略括号。
    delegate void SomeDelegate();
    // 正确的方法是:
    SomeDelegate someDelegate1 = delegate()
             {
                                  MessageBox.Show(“Hello”);
    }
     // 避免使用:
     SomeDelegate someDelegate1 = delegate
              {
                                   MessageBox.Show(“Hello”);
    }

  • 相关阅读:
    Vocabulary Recitation 2020/05/06
    java set TreeSet详解
    vue快速入门~必备基础知识(一)下~过滤器
    vue快速入门~必备基础知识(一)上
    vue入门(二)基于前面的基础的一个小Demo
    Annotation注释详解~
    泛型~详解~
    Collections工具类详解
    TreeMap实现类和SortMap接口
    Map集合-主要HashMap和Hashtable
  • 原文地址:https://www.cnblogs.com/SoulStore/p/824906.html
Copyright © 2011-2022 走看看