Framework C#获得当前执行的函数名、当前代码行、源代码文件名

C#获得当前执行的函数名、当前代码行、源代码文件名

[日期:2010-10-18 11:40]   来源:.NET中国学习网  作者:admin   [字体: 大 中 小]
  得到函数名:
  System.Diagnostics.StackTrace  st  =  new  System.Diagnostics.StackTrace();
  this.Text  =  st.GetFrame(0).ToString();
  得到代码行,源代码文件名:
  StackTrace st = new StackTrace(new StackFrame(true));
  Console.WriteLine(" Stack trace for current level: {0}", st.ToString());
  StackFrame sf = st.GetFrame(0);
  Console.WriteLine(" File: {0}", sf.GetFileName());
  Console.WriteLine(" Method: {0}", sf.GetMethod().Name);
  Console.WriteLine(" Line Number: {0}", sf.GetFileLineNumber());
  Console.WriteLine(" Column Number: {0}", sf.GetFileColumnNumber());
http://www.dotnetspider.com/resources/22576-Stack-Frame.aspx
using System.Diagnostics;
http://madskristensen.net/post/JavaScript-AlertShow(e2809dmessagee2809d)-from-ASPNET-code-behind.aspx
private void btnException_Click(object sender, System.EventArgs e)
{

try
{
ProcException1(1, 2);
}
catch(Exception exp)
{
GetFullStackFrameInfo(new StackTrace(exp));
}
}
void btnSave_Click(object sender, EventArgs e)
{
   try
   {
      SaveSomething();
      Alert.Show("You document has been saved");
   }
   catch (ReadOnlyException)
   {
      Alert.Show("You do not have write permission to this file");
   }
}

private void btnStackTrace_Click(object sender, System.EventArgs e)
{
int x = 2;
ProcA(1, ref x, "Hello");
}

private void GetFullStackFrameInfo(StackTrace st)
{
int fc = st.FrameCount;

lstStackItems.Items.Clear();

for(int i = 0; i < fc - 1; i++)
{
lstStackItems.Items.Add(GetStackFrameInfo(st.GetFrame(i)));
}
}

private string GetStackFrameInfo(StackFrame sf)
{
string strParams;

MethodInfo mi;
Type typ;
string strOut = string.Empty;

mi = (MethodInfo) sf.GetMethod();

if (mi.IsPrivate)
{
strOut += "private ";
}
else if ( mi.IsPublic )
{
strOut += "public ";
}
else if ( mi.IsFamily )
{
strOut += "protected ";
}
else if ( mi.IsAssembly )
{
strOut += "internal ";
}

if ( mi.IsStatic )
{
strOut += "static ";
}

strOut += mi.Name + "(";

ParameterInfo[] piList = sf.GetMethod().GetParameters();

strParams = string.Empty;

foreach(ParameterInfo pi in piList)
{
strParams += string.Format(", {0} {1} {2}", ((pi.ParameterType.IsByRef) ? "ByRef" : "ByVal"), pi.Name, pi.ParameterType.Name);
}

if (strParams.Length > 2)
{
strOut += strParams.Substring(2);
}
typ = mi.ReturnType;
strOut += ") " + typ.ToString();

return strOut;
}
private void ProcException1(int x, int y)
{
ProcException2("Mike", 12);
}

private void ProcException2(string Name, long Size)
{
ProcException3();
}

private string ProcException3()
{
return ProcException4("[email protected]");
}

private string ProcException4(string EmailAddress)
{
throw new ArgumentException("This is a fake exception!");
}

private void ProcA(int Item1, ref int Item2, string Item3)
{
ProcB(string.Concat(Item1, Item2, Item3));
}

private void ProcB(string Name)
{
GetFullStackFrameInfo(new StackTrace());
}
        private static void addpathPower(string pathname, string username, string power)
        {
            DirectoryInfo dirinfo = new DirectoryInfo(pathname);
            if ((dirinfo.Attributes & FileAttributes.ReadOnly) != 0)
            {
                dirinfo.Attributes = FileAttributes.Normal;
            }
            //取得访问控制列表  
            DirectorySecurity dirsecurity = dirinfo.GetAccessControl();
            switch (power)
            {
                case "FullControl":
                    dirsecurity.AddAccessRule(new FileSystemAccessRule(username, FileSystemRights.FullControl, InheritanceFlags.ContainerInherit, PropagationFlags.InheritOnly, AccessControlType.Allow));
                    break;
                case "ReadOnly":
                    dirsecurity.AddAccessRule(new FileSystemAccessRule(username, FileSystemRights.Read, AccessControlType.Allow));
                    break;
                case "Write":
                    dirsecurity.AddAccessRule(new FileSystemAccessRule(username, FileSystemRights.Write, AccessControlType.Allow));
                    break;
                case "Modify":
                    dirsecurity.AddAccessRule(new FileSystemAccessRule(username, FileSystemRights.Modify, AccessControlType.Allow));
                    break;
            }
            dirinfo.SetAccessControl(dirsecurity);
        }
public static void Show(string message)
{
   // Cleans the message to allow single quotation marks

   string cleanMessage = message.Replace("'", "//'"
);
   string script = "<script type=/"text/javascript/">alert('" + cleanMessage + "');</script>"
;

   // Gets the executing web page

   Page page
= HttpContext.Current.CurrentHandler as
Page;

   // Checks if the handler is a Page and that the script isn't allready on the Page

   if (page != null && !page.ClientScript.IsClientScriptBlockRegistered("alert"
))
   {
      page.ClientScript.RegisterClientScriptBlock(
typeof(Alert), "alert"
, script);
   }
}    
}

你可能感兴趣的:(exception,.net,String,object,C#,File)