程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> C#應用delegate完成Javascript的each辦法

C#應用delegate完成Javascript的each辦法

編輯:C#入門知識

C#應用delegate完成Javascript的each辦法。本站提示廣大學習愛好者:(C#應用delegate完成Javascript的each辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是C#應用delegate完成Javascript的each辦法正文


C#中有許多易混雜的症結詞,例如delegate,Func, Action和 Predicate。Func, Action和 Predicate實質上都是delegate,上面看一下delegate概念。

1 delegate概念
  delegate實質上就是一個指向函數的指針,可以指向分歧的函數,只需函數的簽名和署理分歧便可。

2 delegate運用
  其實Func, Action, Predicate等都是delegate,只是特別的delegate罷了。delegate的奇妙運用,可以年夜年夜簡化代碼和進步靈巧性。上面有一段Javascript代碼,JS中常常應用數組的each辦法來遍歷數組並對其停止處置,以下所示:

var arr = [ "one", "two", "three", "four"];    
$.each(arr, function(){    
  alert(this);    
 });   
 //下面這個each輸入的成果分離為:one,two,three,four

  那末在C#中若何經由過程delegate來界說一個數組each辦法呢,可以經由過程傳入辦法來完成靈巧的邏輯處置,靜態ListEx類下有一個靜態的Each辦法,界說以下:

public static T[] Each<T>(T[] source, Func<T, T> function)
{

  T[] ret =new T[source.Length];
  int i = 0;
  foreach (T item in source)
  {
    ret[i]=function(item);
    i++;
  }
  return ret;
} 

那末我們可以界說一個字符串數組,並界說一個delegate作為函數參數停止傳入,挪用ListEx.Each辦法:

var arr =new string[]{ "one", "two", "three", "four"};   
 var newArr= ListEx.Each<string>(arr,delegate(string x){
   x=x+"_do";
  return x;
 });

固然可以用表達式停止簡化:

 var newArr2 = ListEx.Each<string>(newArr, (string x) => x = x + "_do");

我們也能夠界說一個Where辦法來過濾數組:

public static IList<T> Find<T>(IList<T> source, Predicate<T> predicate)
{
  List<T> ret = new List<T>();
  foreach (T item in source)
  {
    if (predicate(item))
    {
      ret.Add(item);
    }
  }
  return ret;
}
public static T[] Where<T>(T[] source, Predicate<T> predicate)
{
  IList<T> list=source.ToList<T>();
  IList<T> retList= Find<T>(list, predicate);
  return retList.ToArray<T>();
}

挪用以下:

var newArr3 = ListEx.Where<string>(arr, x => x == "two");

3 差別概述

  •    Func是必需指定前往值的署理;
  •  Action為前往值為void的署理;
  •  Predicate為前往值為bool的署理;

以上就是本文的具體內容,願望對年夜家的進修C#法式設計有所贊助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved