利用反射獲得類(lèi)的public static/const成員的值實(shí)例
首先,我們定義一個(gè)類(lèi):
class CDynamic { #if true public const string TableName = "p_battlerecord"; // OK //public static string TableName = "p_battlerecord"; // OK #else public static string TableName // 用屬性不行 { get { return "hello"; } } #endif public string Name { get; set; } public int Add(int a, int b) { return a + b; } }
寫(xiě)一個(gè)測(cè)試函數(shù):
/// <summary> /// 獲取類(lèi)的public static/const成員的值 /// </summary> /// <typeparam name="T"></typeparam> public void TestGetValue<T>() { var tableName = typeof(T).GetField("TableName").GetValue(null); Console.WriteLine(tableName); }
調(diào)用測(cè)試接口:
public void test1() { #if false var d = new CDynamic(); // 簡(jiǎn)化演示, 未使用反射 var add = typeof(CDynamic).GetMethod("Add"); var ret = add.Invoke(d, new object[] { 1, 3 }); #else dynamic d = new CDynamic(); // 使用dynamic動(dòng)態(tài)綁定 var ret = d.Add(1, 3); //d.Hello(); // 編譯通過(guò), 運(yùn)行將出錯(cuò)(未包含Hello()的定義) TestGetValue<CDynamic>(); #endif //Console.WriteLine("sum = {0}, {1}", ret, s); }
完成!
以上這篇利用反射獲得類(lèi)的public static/const成員的值實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
C#使用反射加載多個(gè)程序集的實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇C#使用反射加載多個(gè)程序集的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-06-06C語(yǔ)言模式實(shí)現(xiàn)C++繼承和多態(tài)的實(shí)例代碼
本篇文章主要介紹了C語(yǔ)言模式實(shí)現(xiàn)C++繼承和多態(tài)的實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07C語(yǔ)言 解決不用+、-、×、÷數(shù)字運(yùn)算符做加法的實(shí)現(xiàn)方法
本篇文章是對(duì)在C語(yǔ)言中解決不用+、-、×、÷數(shù)字運(yùn)算符做加法的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C++ OpenCV讀寫(xiě)XML或YAML文件的方法詳解
XML是一種元標(biāo)記語(yǔ)言。所謂元標(biāo)記,就是開(kāi)發(fā)者可以根據(jù)自身需要定義自己的標(biāo)記。YAML是一個(gè)可讀性高,用來(lái)表達(dá)資料序列的格式。本文將通過(guò)C++和OpenCV實(shí)現(xiàn)這兩種文件的讀寫(xiě),需要的可以參考一下2022-05-05C語(yǔ)言通過(guò)二分查找實(shí)現(xiàn)猜數(shù)字游戲
這篇文章主要為大家詳細(xì)介紹了在C語(yǔ)言中如何通過(guò)二分查找思想編寫(xiě)一個(gè)簡(jiǎn)單的猜數(shù)字游戲,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-02-02C++中AVL樹(shù)的底層以及實(shí)現(xiàn)方法總結(jié)
這篇文章主要介紹了C++中AVL樹(shù)的底層以及實(shí)現(xiàn)方法的相關(guān)資料,AVL樹(shù)是一種自平衡的二叉搜索樹(shù),每個(gè)節(jié)點(diǎn)的左右子樹(shù)高度差不超過(guò)1,通過(guò)旋轉(zhuǎn)操作保持平衡,詳解了AVL樹(shù)的結(jié)構(gòu)、插入、旋轉(zhuǎn)、查找和遍歷方法,展示了其保持平衡的機(jī)制及對(duì)應(yīng)代碼實(shí)現(xiàn),需要的朋友可以參考下2024-10-10用c++實(shí)現(xiàn)將文本每個(gè)單詞首字母轉(zhuǎn)換為大寫(xiě)
本篇文章是對(duì)用c++實(shí)現(xiàn)將文本每個(gè)單詞首字母轉(zhuǎn)換為大寫(xiě)的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05淺談C++內(nèi)存分配及變長(zhǎng)數(shù)組的動(dòng)態(tài)分配
下面小編就為大家?guī)?lái)一篇淺談C++內(nèi)存分配及變長(zhǎng)數(shù)組的動(dòng)態(tài)分配。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09