C\#Lambda 와 의뢰 로 템 플 릿 구현 방법

1 문제 설명 아래 코드 보기:

int[] a = [1,2,3];

for (int i =0; i<a.length; i++)
  {
    a[i] = a[i] * 2;
  }

for (int i =0; i<a.length; i++)
  {
    Console.WriteLine(a[i]);
  }

상기 코드 에는 for 순환 의 중복 코드 가 존재 한 다 는 것 이 분명 합 니 다.
2 해결 방안 은 어떻게 중복 을 없 앨 수 있 습 니까?사용 의뢰.
•정의 의뢰

delegate int mapfun(int x);//
•템 플 릿 방법

//
void map(mapfun fn, int[] a)
{
  for (int i = 0; i < a.Length; ++i)
    {
      a[i] = fn(a[i]);
    }
}
•클 라 이언 트 코드

int[] a = {1, 2, 3};
map(delegate(int x) { return x * 2; }, a);  //.Net 2.0
map(x => { Console.WriteLine(x); return x; }, a); //.Net 3.0 lambda
3.전체 코드 예제

class Program
{
  static void Main(string[] args)
  {
    int[] a = {1, 2, 3};
    map(delegate(int x) { return x * 2; }, a);  //.Net 2.0
    map(x => { Console.WriteLine(x); return x; }, a); //.Net 3.0 lambda
  }

  delegate int mapfun(int x);
  static void map(mapfun fn, int[] a)
  {
    for (int i = 0; i < a.Length; ++i)
      {
        a[i] = fn(a[i]);
      }
  }
}

4 전통 적 인 템 플 릿 방법 과 비교 1.하위 클래스 의 수량 을 줄 였 고 템 플 릿 방법 에서 알고리즘 을 확대 하려 면 하위 클래스 가 필요 하 다.2.템 플 릿 은 알고리즘 을 숨 기 고 의뢰 는 고객 코드 에 의 해 선택 합 니 다.

좋은 웹페이지 즐겨찾기