本文整理汇总了C#中System.Diagnostics.StackTrace.Any方法的典型用法代码示例。如果您正苦于以下问题:C# StackTrace.Any方法的具体用法?C# StackTrace.Any怎么用?C# StackTrace.Any使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类System.Diagnostics.StackTrace
的用法示例。
在下文中一共展示了StackTrace.Any方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: SimpleExceptionDetail
public SimpleExceptionDetail(System.Exception e, bool isIncludeStack = true)
: this()
{
Message = e.Message;
Type = e.GetType().FullName;
if (!isIncludeStack) return;
var frames = new StackTrace(e, true).GetFrames();
if (frames == null || !frames.Any()) return;
StacktraceDetails = frames.Select(r => new SimpleStacktraceDetail
{
File = r.GetFileName(),
LineNumber = r.GetFileLineNumber(),
Method = r.GetMethod().Name
});
}
示例2: Write
public override void Write(string message)
{
try
{
var frames = new StackTrace().GetFrames();
// 同じAssemblyのメソッドから呼ばれているか?
var any = frames.Any(x =>
x.GetMethod().DeclaringType != MethodBase.GetCurrentMethod().DeclaringType &&
x.GetMethod().ReflectedType.FullName.Contains(this.Name));
if (!any)
{
return;
}
var log =
DateTime.Now.ToString("[yyyy/MM/dd HH:mm:ss.fff]") + " " +
message;
this.defaultListener.Write(log);
if (this.LogTextBox != null)
{
this.LogTextBox.AppendText(log);
}
// ログファイルに出力する
lock (this.logBuffer)
{
this.logBuffer.Add(log);
if (this.logBuffer.Count >= 64)
{
var toWrite = string.Join(string.Empty, this.logBuffer.ToArray());
File.AppendAllText(this.logFile, toWrite);
this.logBuffer.Clear();
}
}
}
catch
{
}
}
示例3: IsUnitTest
public static bool IsUnitTest()
{
StackFrame[] frames = new StackTrace().GetFrames();
return frames.Any(frame => IsTestAttribute(frame) || IsInTestSetUp(frame));
}
示例4: ContainsUnitTest
public static bool ContainsUnitTest()
{
StackFrame[] frames = new StackTrace().GetFrames();
return frames != null && frames.Any(IsTestWithoutCategory);
}