DataColumn類的幾個需要Type型別參數的建構函式如下:
// // 摘要: // 使用指定列名稱和資料類型初始化 System.Data.DataColumn 類的新執行個體。 // // 參數: // columnName: // 一個字串,它表示要建立的列的名稱。如果設定為 null 或Null 字元串 (""),則當添加到列集合中時,將指定一個預設名稱。 // // dataType: // 支援的 System.Data.DataColumn.DataType。 // // 異常: // System.ArgumentNullException: // 未指定任何 dataType。 public DataColumn(string columnName, Type dataType); // // 摘要: // 使用指定的名稱、資料類型和運算式初始化 System.Data.DataColumn 類的新執行個體。 // // 參數: // columnName: // 一個字串,它表示要建立的列的名稱。如果設定為 null 或Null 字元串 (""),則當添加到列集合中時,將指定一個預設名稱。 // // dataType: // 支援的 System.Data.DataColumn.DataType。 // // expr: // 用於建立該列的運算式。有關更多資訊,請參見 System.Data.DataColumn.Expression 屬性。 // // 異常: // System.ArgumentNullException: // 未指定任何 dataType。 public DataColumn(string columnName, Type dataType, string expr); // // 摘要: // 使用指定名稱、資料類型、運算式和確定列是否為屬性的值,初始化 System.Data.DataColumn 類的新執行個體。 // // 參數: // columnName: // 一個字串,它表示要建立的列的名稱。如果設定為 null 或Null 字元串 (""),則當添加到列集合中時,將指定一個預設名稱。 // // dataType: // 支援的 System.Data.DataColumn.DataType。 // // expr: // 用於建立該列的運算式。有關更多資訊,請參見 System.Data.DataColumn.Expression 屬性。 // // type: // System.Data.MappingType 值之一。 // // 異常: // System.ArgumentNullException: // 未指定任何 dataType。 public DataColumn(string columnName, Type dataType, string expr, MappingType type);
C#的幾個與類型Type有關的幾個語句
1、typeof
typeof是個運算子,typeof(類型)。例如typeof(bool)、typeof(int)、typeof(System.Windows.Forms.TextBox)
2、Type.GetType(類型名)。這個類型名是string型,加引號的。
3、Object.GetType()。Object類的成員,c#的類對象都有此方法。
上面3個都返回System.Type。
具體使用樣本:
private void Form1_Load(object sender, EventArgs e) { try { dt = new DataTable(); dt.Columns.Add(new DataColumn("one", System.Type.GetType("System.Double"))); //System.Type.GetType(TypeCode.Double.ToString())這種方式不能用 dt.Columns.Add(new DataColumn("two", System.Type.GetType("System.Double"))); dt.Columns.Add(new DataColumn("three", typeof(Double))); dt.Columns.Add(new DataColumn("four", (1D).GetType())); Random rnd = new Random(); for (int i = 0; i < 10; i++) { dt.Rows.Add(new object[] { (Double)rnd.Next(1, 234923745), (Double)rnd.Next(1, 234923745), (Double)rnd.Next(1, 234923745), (Double)rnd.Next(1, 234923745) }); } dt.DefaultView.Sort = "one ASC,two ASC"; dataGridView1.DataSource = dt.DefaultView; } catch (System.Exception ex) { MessageBox.Show(ex.Message); } }