ฉันเป็นผู้ใช้ NLog และโดยปกติสิ่งนี้จะเกิดขึ้นที่:
var _logger = LogManager.GetCurrentClassLogger();
มันดูแปลกนิดหน่อยที่คุณต้องผ่านการไตร่ตรองใน Log4Net ดังนั้นฉันจึงดูซอร์สโค้ด NLog และดูเถิดนี่คือสิ่งที่พวกเขาทำเพื่อคุณ:
[MethodImpl(MethodImplOptions.NoInlining)]
public static Logger GetCurrentClassLogger()
{
string loggerName;
Type declaringType;
int framesToSkip = 1;
do
{
#if SILVERLIGHT
StackFrame frame = new StackTrace().GetFrame(framesToSkip);
#else
StackFrame frame = new StackFrame(framesToSkip, false);
#endif
var method = frame.GetMethod();
declaringType = method.DeclaringType;
if (declaringType == null)
{
loggerName = method.Name;
break;
}
framesToSkip++;
loggerName = declaringType.FullName;
} while (declaringType.Module.Name.Equals("mscorlib.dll", StringComparison.OrdinalIgnoreCase));
return globalFactory.GetLogger(loggerName);
}
ฉันเดาว่าฉันจะเขียนสิ่งที่คล้ายกันสำหรับ Log4Net เป็นส่วนขยายหรือวิธีการคงที่แทนที่จะวางภาพสะท้อนเป็นส่วนหนึ่งของรหัสหม้อไอน้ำของฉัน :)