濮阳杆衣贸易有限公司

主頁 > 知識庫 > .net泛型通用函數(shù)的特殊問題的解決方法

.net泛型通用函數(shù)的特殊問題的解決方法

熱門標簽:玉林市機器人外呼系統(tǒng)哪家好 南陽外呼系統(tǒng)定制化 蘋果手機凱立德地圖標注 申請400電話手續(xù) 百度ai地圖標注 電話機器人軟件銷售工作 同安公安400電話怎么申請流程 合肥電銷外呼系統(tǒng)哪家公司做的好 預測式外呼系統(tǒng)使用說明

  自從2.0版本的net framework推出之后泛型(Generic)得到了廣泛好評。它不必像object類型一樣性能上因為“拆箱”或者“裝箱”得到損失,同時在編譯語法檢測階段就可以實時檢測出傳入或者傳出的類型是否符合特定條件。

  但“金無赤足,人無完人”——在我們享受這些幸福編程的同時,泛型自身類型的不確定也帶來了一個顯著的問題——無法進行運算符重載。譬如現(xiàn)在我要寫一個函數(shù)(一個通用的選擇排序算法,使用泛型T),該怎么辦呢?如果你簡單使用這樣的代碼(C#如下):

復制代碼 代碼如下:

//從小到大,改進型選擇排序算法

public static void SortT>(T[] array)
{
     bool flag = false; //標記是否已經(jīng)排序

     for(int i=0;iarray.Length-1;++i)
     {
          flag = false;  //每次假定都已經(jīng)排序,無須再排序

          for(int j=i+1;iarray.Length;++j)
          {
               if(array[i]>array[j])
                {
                      int temp = array[i];
                      array[i]=array[j];
                      array[j]=templ
                      flag = true; //已經(jīng)排序
                }
          }
           if(!flag)
           {
               break;
           }
     }
}


  編譯之后很快發(fā)現(xiàn)提示“運算符‘>'無法作用于T”一類的提示。

  為什么呢?我們知道,凡是可以進行大于、小于比較的類型肯定都定義了運算符重載。一般類必須為此定義方可進行比較,不然大于號或者小于號(或者其它運算符)無法知道如何比較而發(fā)生錯誤。那么泛型因為事先都不知道什么類型?編譯器檢查器自然無法推斷你運行時動態(tài)傳入的這個類型一定保證是實現(xiàn)了運算符重載,嚴格語法檢查情況下就自然報錯。

  怎么辦呢?強制規(guī)定泛型T必須實現(xiàn)比較器(強制T必須實現(xiàn)IComparable,或者類似接口)。

復制代碼 代碼如下:

public static void SortT>(T[] array)where T:IComparable
{
     bool flag = false; //標記是否已經(jīng)排序

     for(int i=0;iarray.Length-1;++i)
     {
          flag = false;  //每次假定都已經(jīng)排序,無須再排序

          for(int j=i+1;iarray.Length;++j)
          {
               if(array[i].Compare(array[j])>0)
                {
                      int temp = array[i];
                      array[i]=array[j];
                      array[j]=templ
                      flag = true; //已經(jīng)排序
                }
          }
           if(!flag)
           {
               break;
           }
     }
}


  一旦對泛型進行約束,那么泛型必然是實現(xiàn)該接口的類,必然擁有此方法(Compare方法返回結果int類型,如果大于0表示前面一個數(shù)字大于后面一個)。

  當然,微軟類庫中有一個Comparer靜態(tài)類,已經(jīng)實現(xiàn)了此接口可以直接進行比較(http://msdn.microsoft.com/zh-cn/library/system.collections.comparer.comparer.aspx),因此我們也可以選擇直接使用這個靜態(tài)類中的Compare方法得到結果。

  【例2】實現(xiàn)一個通用的“+”——即如果傳入的字符串,則自動按照字符串進行字符拼接;如果傳入的是其它基本類型(int,double等),則返回相加結果。

  微軟沒有為“+”預定義接口,因此無法直接使用接口的方式來做(當然你自己強制定義一個,也可以如法炮制)。我們現(xiàn)在換一個方法——使用表達式樹(C#代碼如下):

復制代碼 代碼如下:

public static T AddT>(T a, T b)
        {
            Expression left = Expression.Constant(a);
            Expression right = Expression.Constant(b);

            Type t = typeof(T);

            Expression value;

            if (t == typeof(string))
            {
                value = Expression.Constant(a.ToString()+b.ToString());
            }
            else
            {
                value = Expression.Add(left, right);
            }

            ExpressionFuncT>> addExp = Expression.LambdaFuncT>>(value);

            FuncT> addFunc = addExp.Compile();

            return addFunc();
        }


  動態(tài)判斷T是string還是其它基本類型,然后調(diào)用不同的方法組合成為表達式樹,動態(tài)編譯成為一個Func表達式,返回結果即可。

您可能感興趣的文章:
  • asp.net實現(xiàn)利用反射,泛型,靜態(tài)方法快速獲取表單值到Model的方法
  • 詳解.NET 4.0中的泛型協(xié)變(covariant)和反變(contravariant)
  • .NET基礎之自定義泛型分析
  • .NET開發(fā)基礎:從簡單的例子理解泛型 分享
  • 使用.NET中的Action及Func泛型委托深入剖析
  • .NET CORE動態(tài)調(diào)用泛型方法詳解

標簽:揚州 南京 海南 南昌 嘉興 臺州 淄博 南京

巨人網(wǎng)絡通訊聲明:本文標題《.net泛型通用函數(shù)的特殊問題的解決方法》,本文關鍵詞  .net,泛型,通用,函數(shù),的,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《.net泛型通用函數(shù)的特殊問題的解決方法》相關的同類信息!
  • 本頁收集關于.net泛型通用函數(shù)的特殊問題的解決方法的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    石台县| 天祝| 开封县| 新宾| 云南省| 景泰县| 栖霞市| 新余市| 新乡县| 政和县| 福州市| 周宁县| 新乡市| 长岭县| 蒲城县| 梁河县| 沁阳市| 临清市| 通海县| 正镶白旗| 淮滨县| 黄陵县| 屏南县| 泰和县| 凤冈县| 仙桃市| 青神县| 治县。| 吉安县| 扶风县| 昌吉市| 东至县| 张家港市| 北碚区| 璧山县| 武定县| 河曲县| 西盟| 崇信县| 泰宁县| 绥化市|