Naming Guidelines - MSDN

Download as pdf or txt
Download as pdf or txt
You are on page 1of 18

MSDNNamingGuidelinesShahramVafadar@Gmail.

Com
.NET Framework General Reference

Naming Guidelines
A consistent naming pattern is one of the most important elements of predictability and discoverability in a managed class library. Widespread use and understanding of these naming guidelines should eliminate many of the most common user questions. This topic provides naming guidelines for the .NET Framework types. For each type, you should also take note of some general rules with respect to capitalization styles, case sensitivity and word choice. In This Section Capitalization Styles Describes the Pascal case, camel case, and uppercase capitalization styles to use to name identifiers in class libraries. Case Sensitivity Describes the case sensitivity guidelines to follow when naming identifiers in class libraries. Abbreviations Describes the guidelines for using abbreviations in type names. Word Choice Lists the keywords to avoid using in type names. Avoiding Type Name Confusion Describes how to avoid using language-specific terminology in order to avoid type name confusion. Namespace Naming Guidelines Describes the guidelines to follow when naming namespaces. Class Naming Guidelines Describes the guidelines to follow when naming classes. Interface Naming Guidelines Describes the guidelines to follow when naming interfaces. Attribute Naming Guidelines Describes the correct way to name an attribute using the Attribute suffix. Enumeration Type Naming Guidelines Describes the guidelines to follow when naming enumerations. Static Field Naming Guidelines Describes the guidelines to follow when naming static fields. Parameter Naming Guidelines Describes the guidelines to follow when naming parameters. Method Naming Guidelines Describes the guidelines to follow when naming methods. Property Naming Guidelines Describes the guidelines to follow when naming properties. Event Naming Guidelines Describes the guidelines to follow when naming events.

Related Sections Class Member Usage Guidelines Describes the guidelines for using properties, events, methods, constructors, fields, and parameters in class libraries. Type Usage Guidelines Describes the guidelines for using classes, value types, delegates, attributes, and nested types in class libraries. Design Guidelines for Class Library Developers Provides naming and usage guidelines for types in the .NET Framework as well as guidelines for implementing common design patterns.

[email protected]
.NET Framework General Reference

Capitalization Styles
Use the following three conventions for capitalizing identifiers. Pascal case The first letter in the identifier and the first letter of each subsequent concatenated word are capitalized. You can use Pascal case for identifiers of three or more characters. For example: BackColor Camel case The first letter of an identifier is lowercase and the first letter of each subsequent concatenated word is capitalized. For example: backColor Uppercase All letters in the identifier are capitalized. Use this convention only for identifiers that consist of two or fewer letters. For example: System.IO System.Web.UI You might also have to capitalize identifiers to maintain compatibility with existing, unmanaged symbol schemes, where all uppercase characters are often used for enumerations and constant values. In general, these symbols should not be visible outside of the assembly that uses them. The following table summarizes the capitalization rules and provides examples for the different types of identifiers. Identifier Class Enum type Enum values Event Exception class Read-only Static field Interface Method Namespace Parameter Property Protected instance field Case Pascal Pascal Pascal Pascal Pascal Pascal Pascal Pascal Pascal Camel Pascal Camel Example AppDomain ErrorLevel FatalError ValueChange WebException Note Always ends with the suffix Exception. RedValue IDisposable Note Always begins with the prefix I. ToString System.Drawing typeName BackColor redValue Note Rarely used. A property is preferable to using a protected instance field. RedValue Note Rarely used. A property is preferable to using a public instance field.

Public instance field

Pascal

See Also Design Guidelines for Class Library Developers | Naming Guidelines

[email protected]
.NET Framework General Reference

Case Sensitivity
To avoid confusion and guarantee cross-language interoperation, follow these rules regarding the use of case sensitivity:

Do not use names that require case sensitivity. Components must be fully usable from both case-sensitive and case-insensitive languages. Case-insensitive languages cannot distinguish between two names within the same context that differ only by case. Therefore, you must avoid this situation in the components or classes that you create. Do not create two namespaces with names that differ only by case. For example, a case insensitive language cannot distinguish between the following two namespace declarations.

namespace ee.cummings; namespace Ee.Cummings;


Do not create a function with parameter names that differ only by case. The following example is incorrect.

void MyFunction(string a, string A)


Do not create a namespace with type names that differ only by case. In the following example, and POINT p are inappropriate type names because they differ only by case.

Point p

System.Windows.Forms.Point p System.Windows.Forms.POINT p
Do not create a type with property names that differ only by case. In the following example, and int COLOR are inappropriate property names because they differ only by case.

int Color

int Color {get, set} int COLOR {get, set}


Do not create a type with method names that differ only by case. In the following example, and Calculate are inappropriate method names because they differ only by case.

calculate

void calculate() void Calculate()

See Also Design Guidelines for Class Library Developers | Naming Guidelines

[email protected]
.NET Framework General Reference

Abbreviations
To avoid confusion and guarantee cross-language interoperation, follow these rules regarding the use of abbreviations:

Do not use abbreviations or contractions as parts of identifier names. For example, use of GetWin. Do not use acronyms that are not generally accepted in the computing field.

GetWindow instead

Where appropriate, use well-known acronyms to replace lengthy phrase names. For example, use Interface and OLAP for On-line Analytical Processing.

UI for User

When using acronyms, use Pascal case or camel case for acronyms more than two characters long. For example, use HtmlButton or htmlButton. However, you should capitalize acronyms that consist of only two characters, such as System.IO instead of System.Io. Do not use abbreviations in identifiers or parameter names. If you must use abbreviations, use camel case for abbreviations that consist of more than two characters, even if this contradicts the standard abbreviation of the word.

See Also Design Guidelines for Class Library Developers | Naming Guidelines

[email protected]
.NET Framework General Reference

Word Choice
Avoid using class names that duplicate commonly used .NET Framework namespaces. For example, do not use any of the following names as a class name: System, Collections, Forms, or UI. See the Class Library for a list of .NET Framework namespaces. In addition, avoid using identifiers that conflict with the following keywords. AddHandler As ByRef Catch CDec CLng CStr Default Each Erase False Friend Handles Inherits Lib Mod MyClass Nothing Option Overrides Protected Region Select Single Structure To Until WithEvents instanceof AddressOf Assembly Byte CBool CDbl CObj CType Delegate Else Error Finalize Function If Integer Like Module Namespace NotInheritable Optional ParamArray Public REM Set Static Sub True volatile WriteOnly package Alias Auto ByVal CByte Char Const Date Dim ElseIf Event Finally Get Implements Interface Long MustInherit New NotOverridable Or Preserve RaiseEvent RemoveHandler Shadows Step SyncLock Try When Xor var And Base Call CChar CInt CShort Decimal Do End Exit Float GetType Imports Is Loop MustOverride Next Object Overloads Private ReadOnly Resume Shared Stop Then TypeOf While eval Ansi Boolean Case CDate Class CSng Declare Double Enum ExternalSource For Goto In Let Me MyBase Not On Overridable Property ReDim Return Short String Throw Unicode With extends

See Also Design Guidelines for Class Library Developers | Naming Guidelines

[email protected]
.NET Framework General Reference

Avoiding Type Name Confusion


Different programming languages use different terms to identify the fundamental managed types. Class library designers must avoid using language-specific terminology. Follow the rules described in this section to avoid type name confusion. Use names that describe a type's meaning rather than names that describe the type. In the rare case that a parameter has no semantic meaning beyond its type, use a generic name. For example, a class that supports writing a variety of data types into a stream might have the following methods. [Visual Basic]

Sub Sub Sub Sub Sub

Write(value Write(value Write(value Write(value Write(value

As As As As As

Double); Single); Long); Integer); Short);

[C#] void void void void void

Write(double value); Write(float value); Write(long value); Write(int value); Write(short value);

Do not create language-specific method names, as in the following example. [Visual Basic]

Sub Sub Sub Sub Sub

Write(doubleValue As Double); Write(singleValue As Single); Write(longValue As Long); Write(integerValue As Integer); Write(shortValue As Short);

[C#] void void void void void

Write(double doubleValue); Write(float floatValue); Write(long longValue); Write(int intValue); Write(short shortValue);

In the extremely rare case that it is necessary to create a uniquely named method for each fundamental data type, use a universal type name. The following table lists fundamental data type names and their universal substitutions. C# type name sbyte byte short ushort int uint long ulong float double bool char string object Visual Basic type name SByte Byte Short UInt16 Integer UInt32 Long UInt64 Single Double Boolean Char String Object JScript type name sByte byte short ushort int uint long ulong float double boolean char string object Visual C++ type name char unsigned char short unsigned short int unsigned int __int64 unsigned __int64 float double bool wchar_t String Object Ilasm.exe representation int8 unsigned int16 unsigned int32 unsigned int64 unsigned float32 float64 bool char string object int8 int16 int32 int64 Universal type name SByte Byte Int16 UInt16 Int32 UInt32 Int64 UInt64 Single Double Boolean Char String Object

[email protected]
For example, a class that supports reading a variety of data types from a stream might have the following methods. [Visual Basic]

ReadDouble()As Double ReadSingle()As Single ReadInt64()As Long ReadInt32()As Integer ReadInt16()As Short [C#] double ReadDouble(); float ReadSingle(); long ReadInt64(); int ReadInt32(); short ReadInt16();

The preceding example is preferable to the following language-specific alternative. [Visual Basic]

ReadDouble()As Double ReadSingle()As Single ReadLong()As Long ReadInteger()As Integer ReadShort()As Short [C#] double ReadDouble(); float ReadFloat(); long ReadLong(); int ReadInt(); short ReadShort();

See Also Design Guidelines for Class Library Developers | Common Type System

[email protected]
.NET Framework General Reference

Namespace Naming Guidelines


The general rule for naming namespaces is to use the company name followed by the technology name and optionally the feature and design as follows.

CompanyName.TechnologyName[.Feature][.Design]
For example:

Microsoft.Media Microsoft.Media.Design
Prefixing namespace names with a company name or other well-established brand avoids the possibility of two published namespaces having the same name. For example, Microsoft.Office is an appropriate prefix for the Office Automation Classes provided by Microsoft. Use a stable, recognized technology name at the second level of a hierarchical name. Use organizational hierarchies as the basis for namespace hierarchies. Name a namespace that contains types that provide design-time functionality for a base namespace with the .Design suffix. For example, the System.Windows.Forms.Design Namespace contains designers and related classes used to design System.Windows.Forms based applications. A nested namespace should have a dependency on types in the containing namespace. For example, the classes in the System.Web.UI.Design depend on the classes in System.Web.UI. However, the classes in System.Web.UI do not depend on the classes in System.Web.UI.Design. You should use Pascal case for namespaces, and separate logical components with periods, as in Microsoft.Office.PowerPoint. If your brand employs nontraditional casing, follow the casing defined by your brand, even if it deviates from the prescribed Pascal case. For example, the namespaces NeXT.WebObjects and ee.cummings illustrate appropriate deviations from the Pascal case rule. Use plural namespace names if it is semantically appropriate. For example, use System.Collections rather than System.Collection. Exceptions to this rule are brand names and abbreviations. For example, use System.IO rather than System.IOs. Do not use the same name for a namespace and a class. For example, do not provide both a class.

Debug namespace and a

Debug

Finally, note that a namespace name does not have to parallel an assembly name. For example, if you name an assembly MyCompany.MyTechnology.dll, it does not have to contain a MyCompany.MyTechnology namespace.

See Also Design Guidelines for Class Library Developers | Introduction to the .NET Framework Class Library

[email protected]
.NET Framework General Reference

Class Naming Guidelines


The following rules outline the guidelines for naming classes:

Use a noun or noun phrase to name a class. Use Pascal case. Use abbreviations sparingly. Do not use a type prefix, such as C for class, on a class name. For example, use the class name FileStream rather than CFileStream. Do not use the underscore character (_). Occasionally, it is necessary to provide a class name that begins with the letter I, even though the class is not an interface. This is appropriate as long as I is the first letter of an entire word that is a part of the class name. For example, the class name IdentityStore is appropriate. Where appropriate, use a compound word to name a derived class. The second part of the derived class's name should be the name of the base class. For example, ApplicationException is an appropriate name for a class derived from a class named Exception, because ApplicationException is a kind of Exception. Use reasonable judgment in applying this rule. For example, Button is an appropriate name for a class derived from Control. Although a button is a kind of control, making Control a part of the class name would lengthen the name unnecessarily.

The following are examples of correctly named classes. [Visual Basic]

Public Class FileStream Public Class Button Public Class String [C#] public class FileStream public class Button public class String

See Also Design Guidelines for Class Library Developers | Base Class Usage Guidelines

[email protected]
.NET Framework General Reference

Interface Naming Guidelines


The following rules outline the naming guidelines for interfaces:

Name interfaces with nouns or noun phrases, or adjectives that describe behavior. For example, the interface name IComponent uses a descriptive noun. The interface name ICustomAttributeProvider uses a noun phrase. The name IPersistable uses an adjective. Use Pascal case. Use abbreviations sparingly. Prefix interface names with the letter

I, to indicate that the type is an interface.

Use similar names when you define a class/interface pair where the class is a standard implementation of the interface. The names should differ only by the letter I prefix on the interface name.

Do not use the underscore character (_). The following are examples of correctly named interfaces.
[Visual Basic]

Public Interface IServiceProvider Public Interface Iformatable [C#] public interface IServiceProvider public interface IFormatable
The following code example illustrates how to define the interface IComponent and its standard implementation, the class Component.

[Visual Basic]

Public Interface IComponent ' Implementation code goes here. End Interface Public Class Component Implements IComponent ' Implementation code goes here. End Class

[C#] public interface IComponent { // Implementation code goes here. } public class Component: IComponent { // Implementation code goes here. }

See Also Design Guidelines for Class Library Developers | Base Class Usage Guidelines

[email protected]
.NET Framework General Reference

Attribute Naming Guidelines


You should always add the suffix named attribute class. [Visual Basic]

Attribute to custom attribute classes. The following is an example of a correctly

Public Class ObsoleteAttribute [C#] public class ObsoleteAttribute{}

See Also Design Guidelines for Class Library Developers

[email protected]
.NET Framework General Reference

Enumeration Type Naming Guidelines


The enumeration (Enum) value type inherits from the Enum Class. The following rules outline the naming guidelines for enumerations:

Use Pascal case for Enum types and value names. Use abbreviations sparingly. Do not use an

Enum suffix on Enum type names.

Use a singular name for most Enum types, but use a plural name for Enum types that are bit fields. Always add the FlagsAttribute to a bit field Enum type.

See Also Design Guidelines for Class Library Developers | Value Type Usage Guidelines | Enum Class

[email protected]
.NET Framework General Reference

Static Field Naming Guidelines


The following rules outline the naming guidelines for static fields:

Use nouns, noun phrases, or abbreviations of nouns to name static fields. Use Pascal case. Do not use a Hungarian notation prefix on static field names. It is recommended that you use static properties instead of public static fields whenever possible.

See Also Design Guidelines for Class Library Developers | Field Usage Guidelines

[email protected]
.NET Framework General Reference

Parameter Naming Guidelines


It is important to carefully follow these parameter naming guidelines because visual design tools that provide context sensitive help and class browsing functionality display method parameter names to users in the designer. The following rules outline the naming guidelines for parameters:

Use camel case for parameter names. Use descriptive parameter names. Parameter names should be descriptive enough that the name of the parameter and its type can be used to determine its meaning in most scenarios. For example, visual design tools that provide context sensitive help display method parameters to the developer as they type. The parameter names should be descriptive enough in this scenario to allow the developer to supply the correct parameters. Use names that describe a parameter's meaning rather than names that describe a parameter's type. Development tools should provide meaningful information about a parameter's type. Therefore, a parameter's name can be put to better use by describing meaning. Use type-based parameter names sparingly and only where it is appropriate. Do not use reserved parameters. Reserved parameters are private parameters that might be exposed in a future version if they are needed. Instead, if more data is needed in a future version of your class library, add a new overload for a method. Do not prefix parameter names with Hungarian type notation.

The following are examples of correctly named parameters. [Visual Basic]

GetType(typeName As String)As Type Format(format As String, args() As object)As String

[C#] Type GetType(string typeName) string Format(string format, object[] args)

See Also Design Guidelines for Class Library Developers | Parameter Usage Guidelines

[email protected]
.NET Framework General Reference

Method Naming Guidelines


The following rules outline the naming guidelines for methods:

Use verbs or verb phrases to name methods. Use Pascal case.

The following are examples of correctly named methods.

RemoveAll() GetCharArray() Invoke()

See Also Design Guidelines for Class Library Developers | Method Usage Guidelines

[email protected]
.NET Framework General Reference

Property Naming Guidelines


The following rules outline the naming guidelines for properties:

Use a noun or noun phrase to name properties. Use Pascal case. Do not use Hungarian notation. Consider creating a property with the same name as its underlying type. For example, if you declare a property named Color, the type of the property should likewise be Color. See the example later in this topic.

The following code example illustrates correct property naming. [Visual Basic]

Public Class SampleClass Public Property BackColor As Color ' Code for Get and Set accessors goes here. End Property End Class

[C#] public class SampleClass { public Color BackColor { // Code for Get and Set accessors goes here. } }

The following code example illustrates providing a property with the same name as a type. [Visual Basic]

Public Enum Color ' Insert code for Enum here. End Enum Public Class Control Public Property Color As Color Get ' Insert code here. End Get Set ' Insert code here. End Set End Property End Class

[C#] public enum Color { // Insert code for Enum here. } public class Control { public Color Color { get {// Insert code here.} set {// Insert code here.} } }

[email protected]
The following code example is incorrect because the property Color is of type Integer. [Visual Basic]

Public Enum Color ' Insert code for Enum here. End Enum Public Class Control Public Property Color As Integer Get ' Insert code here. End Get Set ' Insert code here. End Set End Property End Class

[C#] public enum Color {// Insert code for Enum here.} public class Control { public int Color { get {// Insert code here.} set {// Insert code here.} } }
In the incorrect example, it is not possible to refer to the members of the Color enumeration. Color.Xxx will be interpreted as accessing a member that first gets the value of the Color property (type Integer in Visual Basic or type int in C#) and then accesses a member of that value (which would have to be an instance member of System.Int32).

See Also Design Guidelines for Class Library Developers | Property Usage Guidelines

[email protected]
.NET Framework General Reference

Event Naming Guidelines


The following rules outline the naming guidelines for events:

Use Pascal case. Do not use Hungarian notation. Use an

EventHandler suffix on event handler names.

Specify two parameters named sender and e. The sender parameter represents the object that raised the event. The sender parameter is always of type object, even if it is possible to use a more specific type. The state associated with the event is encapsulated in an instance of an event class named e. Use an appropriate and specific event class for the e parameter type. Name an event argument class with the

EventArgs suffix.

Consider naming events with a verb. For example, correctly named event names include Clicked, Painting, and DroppedDown. Use a gerund (the "ing" form of a verb) to create an event name that expresses the concept of pre-event, and a past-tense verb to represent post-event. For example, a Close event that can be canceled should have a Closing event and a Closed event. Do not use the BeforeXxx/AfterXxx naming pattern. Do not use a prefix or suffix on the event declaration on the type. For example, use OnClose.

Close instead of

In general, you should provide a protected method called OnXxx on types with events that can be overridden in a derived class. This method should only have the event parameter e, because the sender is always the instance of the type. The following example illustrates an event handler with an appropriate name and parameters.

[Visual Basic] Public Delegate Sub MouseEventHandler(sender As Object, e As MouseEventArgs) [C#] public delegate void MouseEventHandler(object sender, MouseEventArgs e); The following example illustrates a correctly named event argument class. [Visual Basic] Public Class MouseEventArgs Inherits EventArgs Dim x As Integer Dim y As Integer Public Sub New MouseEventArgs(x As Integer, y As Integer) me.x = x me.y = y End Sub Public Property X As Integer Get Return x End Get End Property Public Property Y As Integer Get Return y End Get End Property End Class [C#] public class MouseEventArgs : EventArgs { int x; int y; public MouseEventArgs(int x, int y) { this.x = x; this.y = y; } public int X { get { return x; } } public int Y { get { return y; } } }
See Also Design Guidelines for Class Library Developers | Event Usage Guidelines

You might also like