Enum을 쓰면서 Enum안에 있는 값들을 쭉 돌면서 확인하고 싶을때가 있었는데.... 그 방법을 찾지 못했었는데요... (멍청하게도..)
Enum.GetValues(EnumType)  << 요론넘이 있었군요.. 

State라는 이름의 Enum이 있을때
Enum.GetValues(Typeof(State)) 이렇게 하면 Array로 안에 애들이 나오는군요..
 
저작자 표시 비영리
신고
by 피요히코~ 2011.08.16 11:34
이거 때문에 꽤나 골치 아팠었는데
해결방법이 있었네여....

Productivity Power Tools

이 애드온을 설치하면 되는거네요..(아직 해보진 않았지만..)

도구-확정관리자 에서 검색해서 설치하면 되네요..
후훗

출처 : 맨날맑음님 블로그
저작자 표시 비영리
신고
by 피요히코~ 2010.12.10 17:14
어떤 형식을 List로 만들어서 관리할때 sort를 해야 할 경우도 생깁니다. (당연..;;;)

List의 Sort는 기본적으로 4개의 오버로드가 존재합니다.
1. List.Sort()
2. List.Sort(제네릭 Comparison)
3. List.Sort(제네릭 IComparer)
4. List.Sort(Int32, Int32, 제네릭 IComparer)

아무런 파라미터를 받지 않는 기본 Sort도 있고
특정 파라미터를 받는 Sort도 있는데
그 사용법을 간단히 정리해 보면

일단 리스트가 있어야 하니..
List myList = new List();
myList.Add("Daum");
myList.Add("Google");
myList.Add("Bing");
myList.Add("Naver");

이런 리스트가 있다고 할때
2번의 Sort를 쓰려면

public int compare(string x, string y)
{
return x.CompareTo(y);
}

요런 메서드를 하나 만들어서 (물론 구현내용은 자유롭겠져. 반환값만 -1,0,1 이면 뭐)

myList.Sort(compare);

이렇게 써주면 됩니다.

3번 Sort를 쓰려면
IComparer 을 구현한 클래스를 만들어야 합니다.

public class StringCompare : IComparer
{
public int Compare(string x, string y)
{
return x.CompareTo(y);
}
}

요런 클래스를 만든 후에

StringCompare sc = new StringCompare();
myList.Sort(sc);

요렇게 쓰면 되져. 
 4번 방법이야 sort할 index를 정해주는거니 별 차이 없구여

근데 sort를 무명메서드를 이용해서 코드를 만들수도 있습니다.
무명메서드는 delegate로 해도 되고 람다식을 써도 됩니다.

delegate를 쓰면
myList.Sort(delegate(string x, string y)
{
return x.CompareTo(y);
});

람다식을 쓰면
myList.Sort((string x, string y) => x.CompareTo(y));

이렇게 쓰면 됩니다.
취향따라 쓰면 되겠네요.

참고로 MSDN을 보면
Sort의 정렬방식에 대해 이렇게 써 있어요

 

이 메서드는 QuickSort 알고리즘을 사용하는 System.Array.Sort를 사용합니다. 이 구현에서는 불안정한 정렬을 수행합니다. 즉, 두 개의 같은 요소가 있을 경우 이들 요소의 순서가 유지되지 않을 수 있습니다. 이와 반대로 안정된 정렬은 동일한 요소의 순서를 그대로 유지합니다.

평균적으로 이 메서드는 O(n log n) 연산이며, 여기서 nCount입니다. 최악의 경우 이 메서드는 O(n ^ 2) 연산입니다.

저작자 표시 비영리
신고
by 피요히코~ 2010.12.10 17:07