gpt4 book ai didi

c# - 如何使用公共(public)跟踪标识?

转载 作者:太空宇宙 更新时间:2023-11-03 12:42:24 24 4
gpt4 key购买 nike

我想使用通用跟踪 ID。我正在使用以下代码。

 public void method1(){
using (new Tracer(Guid.NewGuid().ToString()))
{
//my code
}
}
public void method2(){
using (new Tracer(Guid.NewGuid().ToString()))
{
//my code
}
}

这里的 guid 是我的跟踪 ID。但是为每个方法调用生成不同的跟踪 ID。我想保持它的独特性。如何实现这一目标? (注意:我从不同的客户端调用 method1、method2)

最佳答案

如果您需要获取有关类名和/或您的 .NET <= 4.0 的信息,请使用 StackFrame .使用 StackFrame 会产生一些开销。如果您不需要获取类名并且使用 .NET >= 4.5,这里是 solution .它使用 Caller Information . :

namespace Tracer
{
using System;
using System.Runtime.CompilerServices;
sealed class CallerInfoTracer : IDisposable
{
private readonly string _message;
private readonly string _memberName;
private readonly string _sourceFilePath;
private readonly int _lineNumber;

private bool _disposed;

public CallerInfoTracer(string message, [CallerMemberName] string memberName = "",
[CallerFilePath] string sourceFilePath = "", [CallerLineNumber] int lineNumber = 0)
{
_message = message;
_memberName = memberName;
_sourceFilePath = sourceFilePath;
_lineNumber = lineNumber;
}
public void Dispose()
{
if (_disposed) return;

Console.WriteLine("Message: {0}", _message);
Console.WriteLine("MemberName: {0}", _memberName);
Console.WriteLine("SourceFilePath: {0}", _sourceFilePath);
Console.WriteLine("LineNumber: {0}", _lineNumber);
_disposed = true;
}
}
public class Program
{
public static void Main(string[] args)
{
Method1();
Method2();
}
public static void Method1()
{
using (var tracer = new CallerInfoTracer("Desc1")) { }
}
public static void Method2()
{
using (var tracer = new CallerInfoTracer("Desc2")) { }
}
}
}

关于c# - 如何使用公共(public)跟踪标识?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38460375/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com