国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

ASP.NET中實(shí)現(xiàn)獲取調(diào)用方法名

2024-07-10 13:28:37
字體:
供稿:網(wǎng)友
這篇文章主要介紹了ASP.NET中實(shí)現(xiàn)獲取調(diào)用方法名的技巧,較為詳細(xì)的講述了相關(guān)的命名空間的調(diào)用及語句執(zhí)行順序,具有一定的參考借鑒價值,需要的朋友可以參考下
 
 

本文實(shí)例講述了ASP.NET中實(shí)現(xiàn)獲取調(diào)用方法名的技巧。分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:

在寫記錄日志功能時,需要記錄日志調(diào)用方所在的模塊名、命名空間名、類名以及方法名,想到使用的是反射(涉及到反射請注意性能),但具體是哪一塊兒還不了解,于是搜索,整理如下:

 
需要添加相應(yīng)的命名空間:

復(fù)制代碼代碼如下:
using System;
using System.Diagnostics;
using System.Reflection;

如果僅是獲取當(dāng)前方法名,可以使用如下代碼:
復(fù)制代碼代碼如下:
public static void WriteSysLog(int level, string content)
{
    MethodBase mb = MethodBase.GetCurrentMethod();
    string systemModule = Environment.NewLine;
    systemModule += "模塊名:" + mb.Module.ToString() + Environment.NewLine;
    systemModule += "命名空間名:" + mb.ReflectedType.Namespace + Environment.NewLine;
    //完全限定名,包括命名空間
    systemModule += "類名:" + mb.ReflectedType.FullName + Environment.NewLine;
    systemModule += "方法名:" + mb.Name;
 
    Console.WriteLine("LogDate: {0}{1}Level: {2}{1}systemModule: {3}{1}content: {4}", DateTime.Now, Environment.NewLine, level, systemModule, content);
    Console.WriteLine();
}

 

但一般情況下是獲取此記錄日志方法的調(diào)用方,因此需要使用下面的代碼:(此方法僅為演示)

復(fù)制代碼代碼如下:
public static void WriteSysLog(string content)
{
    const int level = 1000;
 
    StackTrace ss = new StackTrace(true);
    //index:0為本身的方法;1為調(diào)用方法;2為其上上層,依次類推
    MethodBase mb = ss.GetFrame(1).GetMethod();
 
    StackFrame[] sfs = ss.GetFrames();
    string systemModule = Environment.NewLine;
    systemModule += "模塊名:" + mb.Module.ToString() + Environment.NewLine;
    systemModule += "命名空間名:" + mb.DeclaringType.Namespace + Environment.NewLine;
    //僅有類名
    systemModule += "類名:" + mb.DeclaringType.Name + Environment.NewLine;
    systemModule += "方法名:" + mb.Name;
 
    Console.WriteLine("LogDate: {0}{1}Level: {2}{1}systemModule: {3}{1}content: {4}", DateTime.Now, Environment.NewLine, level, systemModule, content);
    Console.WriteLine();
}

 

對于這一點(diǎn)兒,感覺有意思的是Main的調(diào)用方

復(fù)制代碼代碼如下:
System.AppDomain._nExecuteAssembly(Assembly assembly, String[] args)

 
通過
復(fù)制代碼代碼如下:
StackTrace ss = new StackTrace(true);
StackFrame[] sfs = ss.GetFrames();

可以得知.NET程序的執(zhí)行順序:
復(fù)制代碼代碼如下:
System.Threading.ThreadHelper.ThreadStart()
System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
System.AppDomain._nExecuteAssembly(Assembly assembly, String[] args)

然后進(jìn)入方法Main中。

 

另外,從 MethodBase 類 還可以獲取很多其他屬性,可以自行定位到System.Reflection.MethodBase 查看。
 
使用反射可以遍歷獲得類的所有屬性名,方法名,成員名,其中一個有趣的小例子:通過反射將變量值轉(zhuǎn)為變量名本身。

希望本文所述對大家的asp.net程序設(shè)計有所幫助。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 雷山县| 青龙| 五峰| 盐亭县| 镇康县| 宿迁市| 海安县| 孟州市| 青河县| 宁强县| 温宿县| 巴彦淖尔市| 江达县| 长海县| 含山县| 永寿县| 临湘市| 商水县| 苍梧县| 甘孜县| 连平县| 盐源县| 宽甸| 集贤县| 南木林县| 如东县| 土默特左旗| 义马市| 大方县| 开平市| 孟州市| 德清县| 宜兰市| 怀集县| 文化| 邹城市| 永顺县| 双桥区| 正安县| 江安县| 神农架林区|