程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> 關於C# >> C#一些實用的,容易被遺忘的特性,經驗和技巧

C#一些實用的,容易被遺忘的特性,經驗和技巧

編輯:關於C#

突然想到,想要通過名字來獲得枚舉的值,看了不少的資料,發現上面都只是解釋枚舉的語法而已,對於它的實際應用,一點也不提及,難道只能用switch來判斷?不好吧,這樣也未免太土了點。後來發現了枚舉還有這樣的用法,真的很使用,看代碼:

Code
namespace EnumTest
{
  enum date { sun, mon, tue, wes, thu, fri, sat }
  class Program
  {
    static void Main(string[] args)
    {
      Console.WriteLine("輸入星期的名稱:");
      string name = Console.ReadLine();
      //Type參數表示要轉換成的枚舉的類型,true指示忽略大小寫
      object obj = Enum.Parse(typeof(date), name, true);
      Console.WriteLine("輸出星期的數字:");
      Console.WriteLine(obj + ":" + (int)obj);
    }
  }
}

再來看一下運行結果圖:

怎麼樣,是不是覺得很實用啊。

接下來要介紹的是委托(delegate),有對delegate不太了解的人可以看一下我以前寫的一個隨筆什麼是委托(delegate) 。我們平時使用委托都是單個的指定委托的方法,但是如果我們需要通過參數動態的指定呢?難道也是用switch?這樣做太麻煩了,還有更好的方法,看代碼:

Code
namespace DelegateTest
{
  class Person
  {
    public void FirstMethod()
    {
      Console.WriteLine("這是第一個方法!");
    }
    public void SecondMethod()
    {
      Console.WriteLine("這是第二個方法!");
    }
  }

  delegate void dele();
  class Program
  {
    static void Main(string[] args)
    {
      Console.WriteLine("輸入方法的名字:");
      string name = Console.ReadLine();
      Person p = new Person();
      //Type參數是要轉換的委托的類型,p是要調用的委托的實例,true指示忽略大小寫
      dele d = Delegate.CreateDelegate(typeof(dele), p, name + "Method", true) as dele;
      d.Invoke();
      Console.WriteLine("輸入方法的名字:");
      name = Console.ReadLine();
      d = Delegate.CreateDelegate(typeof(dele), p, name + "method", true) as dele;
      d.Invoke();
    }
  }
}

下面是運行的結果圖:

接下來是一個C#經常被忽略的特性,匿名方法。雖然匿名方法很少用到,但是知道總比不知道的好。以delegate為例,我們平時都是賦予delegate具體的方法,但是有時候有一個方法要委托,但是它要執行的功能實在是很簡單,而且可能也就只用一次而已,但是要給它寫一個具體的方法實在是麻煩。而C#2.0為我們提供了匿名方法的特性,代碼如下:

Code
namespace Anonymity
{
  delegate void dele();
  class Program
  {
    static void Main(string[] args)
    {
      dele d = delegate() { Console.WriteLine("這是一個匿名方法!"); };
      d.Invoke();
    }
  }
}

運行結果如下圖:

接下來是索引器(Indexer)了,寫技術文章不像寫小說,真的挺累的。要構思,要描述,要寫代碼,要調試,更重要的是,要敲鍵盤。好了,抱怨到些為止。索引器(Indexer)能讓我們像訪問數組一樣訪問對象,至於它有什麼作用呢?只有用到了才知道,看代碼:

Code
namespace IndexerTest
{
  class PersonNames
  {
    List<string> names = new List<string>();
    /// <summary>
    /// 為對象創建索引器,注意它和屬性的get/set的不同
    /// </summary>
    /// <param name="index">索引值</param>
    /// <returns></returns>
    public string this[int index]
    {
      get { return names[index]; }
      set { names.Add(value); }
    }
  }
  class Program
  {
    static void Main(string[] args)
    {
      PersonNames names = new PersonNames();
      names[0] = "微軟";
      names[1] = "谷歌";
      names[2] = "百度";
      for (int i = 0; i < 3; i++)
      {
        Console.WriteLine(names[i]);
      }
    }
  }
}

遺憾的是,它不支持foreach送代。要實現送代的功能,可以實現IEnumerable接口。

接下來是。。。?還有接下來?是不是看得很累了,其實我也寫得很累了。接下來是哈希表(HashTable),HashTable大家都知道很好用,大家可能會發現,它好像不能使用foreach來送代。其實它是可以送代的,只是稍微有點不同而已,看代碼:

Code
namespace HashTableTest
{
  class Program
  {
    static void Main(string[] args)
    {
      Hashtable table = new Hashtable();
      table["name1"] = "微軟";
      table.Add("name2", "谷歌");
      table["name3"] = "百度";
      //注意name的類型名
      foreach (DictionaryEntry name in table)
      {
        Console.WriteLine(name.Key + ":" + name.Value);
      }
    }
  }
}

運行結果如下圖:

大家仔細看一下,它送代返回的類型是DictionaryEntry而不是我們預料中的string。為什麼是這樣的呢?HashTable不同於其它的Collection,它保存的不僅是值(value),同時還保存著鍵(key),它們在HashTable中是以DictionaryEntry類型保存著的。再回顧一下上面的索引器(Indexer),我們就能推斷出,HashTable可能是一個實現了索引器功能的類(不是別罵我,我也是猜的)。

好了,終於寫完了,希望對大家有所幫助。

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