委托让冒泡排序的扩展更加优雅--开闭原则的使用

  本文主要谈的是委托相关运用。包括委托的简单定义,使用,好处;以及委托和Lambda的关系。所有知识点都简化为启发式的注释,应该不难理解,希望对你有帮助。

   /// <summary>
/// 委托让排序代码更加优雅(易扩展,易维护)
/// 本文包含知识点:
/// 1.委托定义
/// 2.委托的好处
/// 3.Lamda(包括语句Lamda和表达式Lambda)
/// 4.Lambda和委托的关系
/// </summary>
class Program
{
//定义内嵌委托(委托本质是一个类;编译器默认为继承自System.Delegate)
public delegate bool ComparerionHandler(int first, int second);

static void Main(string[] args)
{

int[] beforeSortList = new int[3] { 1, 3, 2 };

Console.WriteLine(string.Join(",", beforeSortList.ToArray()));

///实名委托传递参数
//int[] afterSortList = BubbleSort(beforeSortList, Asb);
      //int[] afterSortList = BubbleSort(beforeSortList, Desc);

            ///匿名方法传递参数
//int[] afterSortList = BubbleSort(beforeSortList, delegate(int first, int second) { return first > second; });
       //int[] afterSortList = BubbleSort(beforeSortList, delegate(int first, int second) { return first < second; });

///语句Lambda传递参数(Lambda是匿名方法的简化语法)
int[] afterSortList = BubbleSort(beforeSortList, (first, second)=>{ return first > second; });

Console.WriteLine(string.Join(",", afterSortList.ToArray()));


}
    ——————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————

     //利用委托达到-->对扩展是开放的
//升序
//public static bool Asb(int first, int second)
//{
// return first > second;
//}

//降序
public static bool Desc(int first, int second)
{
return first < second;
}

//字母排序

//可扩展其他排序……


     ——————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————
     //冒泡排序
     //利用委托达到-->对修改是封闭的
public static int[] BubbleSort(int[] list, ComparerionHandler compareion)
{
int temp;

for (int i = list.Length - 1; i >= 0; i--)
{
for (int j = 1; j <= i; j++)
{
if (compareion(list[j - 1], list[j]))
{
temp = list[j];
list[j] = list[j - 1];
list[j - 1] = temp;
}
}
}
return list;
}

}
上一篇:CSS 实现加载动画之四-圆点旋转


下一篇:innodb page重组空间压缩函数(btr_page_reorganize_low)注释