足球游戏_中国足彩网¥体育资讯$

asp.net中实现获取调用方法名
来源:易贤网 阅读:702 次 日期:2015-01-19 14:05:32
温馨提示:易贤网小编为您整理了“asp.net中实现获取调用方法名”,方便广大网友查阅!

需要添加相应的命名空间:

代码如下:

using system;

using system.diagnostics;

using system.reflection;

如果仅是获取当前方法名,可以使用如下代码:

代码如下:

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();

}

但一般情况下是获取此记录日志方法的调用方,因此需要使用下面的代码:(此方法仅为演示)

代码如下:

public static void writesyslog(string content)

{

const int level = 1000;

stacktrace ss = new stacktrace(true);

//index:0为本身的方法;1为调用方法;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();

}

对于这一点儿,感觉有意思的是main的调用方

代码如下:

system.appdomain._nexecuteassembly(assembly assembly, string[] args)

通过

代码如下:

stacktrace ss = new stacktrace(true);

stackframe[] sfs = ss.getframes();

可以得知.net程序的执行顺序:

代码如下:

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)

然后进入方法main中。

另外,从 methodbase 类 还可以获取很多其他属性,可以自行定位到system.reflection.methodbase 查看。

使用反射可以遍历获得类的所有属性名,方法名,成员名,其中一个有趣的小例子:通过反射将变量值转为变量名本身。

中国足彩网信息请查看IT技术专栏

中国足彩网信息请查看网络编程
易贤网手机网站地址:asp.net中实现获取调用方法名
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 足球游戏_中国足彩网¥体育资讯$ 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65099533/13759567129 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:易贤网
云南网警报警专用图标