C#/C# 문법
[C#] 구글 C# 코딩 스타일
범범조조
2023. 2. 25. 07:04
참조
Formatting guidelines(서식 지침)
이름 규칙
코드
- 클래스, 메서드, 열거형, 공용 필드, 공용 속성, 네임스페이스 이름 : Pascal Case
- 지역 변수 이름, 매개 변수 : Camel Case
- private, internal, protected, internal field 그리고 properties : Camel Case
- 명명 규칙은 const, static, readonly 등과 같은 한정자의 영향을 받지 않습니다.
- 인터페이스 이름은 'I' 로 시작합니다.
파일
- 파일 이름과 디렉토리 이름은 Pascal Case 사용합니다. (e.g. MyFile.cs)
- 가능한 경우 파일 이름은 파일의 기본 클래스 이름과 동일해야 합니다.(e.g. MyClass.cs)
- 일반적으로 파일 당 하나의 코어 클래스를 선호합니다.
조직
- 수정은 다음과 같은 순서로 발생 합니다. : public protected internal private new abstract virtual override sealed static readonly extern unsafe volatile async.
- using namespace는 맨 위에 선언합니다. System.* 네임스페이스 제외한 나머지 네임스페이스는 알파벳 순서로 정렬합니다.
- 클래스 멤버 순서
- 클래스 멤버들은 다음 순서로 그룹화 합니다.
- 중첩 된 클래스, 열거형, 대리자 및 이벤트
- 정적, const 및 읽기 전용 필드
- 필드 및 속성
- Constructors and finalizers
- 메서드
- 각 그룹 내에서 elements는 다음 순서로 진행되어야 합니다.
- Public
- Internal
- Protected internal
- Protected
- Private
- 가능한 경우 인터페이스 구현을 함께 그룹화 합니다.
- 클래스 멤버들은 다음 순서로 그룹화 합니다.
C# 코딩 가이드라인
상수
- const로 만들 수 있는 변수와 필드는 항상 const로 만들어야 합니다.
- const를 사용할 수 없는 경우 readonly를 사용합니다.
- magic number(아무 설명없이 쓰는 숫자) 보다 명명된 상수를 선호합니다.
IEnumerable vs IList vs IReadOnlyList
- 입력의 경우 가능한 가장 제한적인 Collection type을 사용합니다.
- IReadOnlyCollection/IReadOnlyList/IEnumerable 입력은 불변해야 하는 메서드에 대한 입력으로 사용합니다.
- 출력의 경우 반환된 컨테이너의 소유권을 소유자에게 전단하는 경우 IEnumerable 보다 IList를 선호합니다.
Property styles
- 단일 줄 읽기 전용의 속성의 경우 가능하면 식 본문 속성(=>) 을 사용합니다.
- 다른 모든 경우에는 { get; set; } 구문을 사용합니다.
Field initializers
- 일반적으로 필드 초기화를 하는것이 좋습니다.
Extension methods
- 원본 클래스의 소스를 사용할 수 없거나 원본 변경을 수행할 수 없는 경우에만 확장 메서드를 사용합니다.
- 추가할 기능이 원래 클래스의 소스에 추가하는데 적합한 '핵심' 일반 기능인 경우에만 확장 메서드를 사용합니다.
- 확장 메서드는 어디서나 사용할 수 있는 코어 라이브러리에만 추가합니다.
- 일부 코드에서만 사용할 수 있는 확장 기능은 가동성을 해칩니다.
- 확장 메서드를 사용하면 코드가 복잡해지므로, 사용하지 않는 편이 좋습니다.
ref and out
- out 키워드는 보통 input 이 아닌 return 으로 사용합니다.
- 메서드 정의에서 보든 매개 변수 뒤에 'out' 키워드를 배치합니다.
- 입력 내용이 변경되는 경우에는 'ref' 키워드 사용하지 않습니다.
- 구조체 전달을 위한 최적화 작업으로 'ref' 키워드 사용하지 않습니다.
- 수정 가능한 컨테이너를 메서드에 전달하기 위해 'ref' 키워드를 사용하지 않습니다.
- 'ref' 키워드는 제공된 컨테이너를 완전히 다른 컨테이너 인스턴스로 교체해야 하는 경우에만 사용합니다.
LINQ
- 일반적으로 LINQ는 긴 체인보다는 한 줄의 LINQ 호출과 명령혈 코드를 선호합니다.
- 명령형 코드와 심하게 연결된 LINQ를 혼합하면 가독성이 매우 복잡해 집니다.
- SQL 스타일 LINQ 보단 메스드 방식의 LINQ 선호합니다.
- 단일문보다 긴 항목에 대해 'Container.ForEach(...)' 구문을 피합니다.
Array vs List
- 일반적으로 Array 보다 List<> 사용을 선호합니다.
- 사이즈 변화가 자주 있는 경우, List<> 사용을 선호합니다.
- 컨테이너의 사이즈가 고정되어 있으면 Array 사용을 선호합니다.
Folders and file locations
- 프로젝트에 일관성을 유지합니다.
- 가능하면 평평한 구조를 선호합니다.
Use of tuple as a return type
- 일반적으로, 복잡한 유형을 반환할때 Tuple<> 보다 명명된 클래스 형식을 선호합니다.
Object Initializer syntax
- 객체 초기화는 다음과 같이 간편 구문으로 사용합니다.
```csharp
var x = new SomeClass {
Property1 = value1,
Property2 = value2,
};
728x90