[解決済み] なぜロガーはクラスごとに使用することを推奨しているのか?
2023-05-07 06:27:28
質問
NLogのドキュメントにある通りです。
ほとんどのアプリケーションでは、1つのクラスにつき1つのロガーを使用し、ロガーの名前はクラスの名前と同じになります。
これはlog4netの運用方法と同じです。なぜこれが良い習慣なのでしょうか?
どのように解決するのですか?
log4netでは、クラスごとに1つのロガーを使用することで、ログメッセージのソース(つまり、ログに書き込むクラス)を簡単に捕捉することができます。 クラスごとに 1 つのロガーがなく、代わりにアプリ全体で 1 つのロガーがある場合、ログ メッセージがどこから来ているかを知るために、より反射的なトリックに頼る必要があります。
以下を比較してください。
クラスごとのログ
using System.Reflection;
private static readonly ILog _logger =
LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
public void SomeMethod()
{
_logger.DebugFormat("File not found: {0}", _filename);
}
1アプリにつき1つのロガー(またはそれに類するもの)
Logger.DebugFormat("File not found: {0}", _filename); // Logger determines caller
-- or --
Logger.DebugFormat(this, "File not found: {0}", _filename); // Pass in the caller
2 番目の例を使用すると、ロガーはスタックトレースを構築して、誰がそれを呼び出したかを確認する必要があります。 logger-per-class スタイルでは、まだこれを行いますが、呼び出しごとに 1 回ではなく、クラスごとに 1 回行うことができ、深刻なパフォーマンスの問題を排除します。
関連
-
[解決済み】「The breakpoint will not currently be hit」を改善するには?このドキュメントにはシンボルが読み込まれていません。" という警告はどうすれば改善されますか?
-
[解決済み】2年前のMSDateを把握する【クローズド
-
[解決済み】「namespace」なのに「type」のように使われる。
-
[解決済み] 複数の例外を一度にキャッチする?
-
[解決済み] IDisposable インターフェースの正しい使用法
-
[解決済み] C#がforeachで変数を再利用するのは理由があるのか?
-
[解決済み] Try-catchは私のコードをスピードアップさせるか?
-
[解決済み] なぜList<T>を継承しないのですか?
-
[解決済み】大文字・小文字を区別しない「Contains(string)
-
[解決済み] [Solved] Webリクエストごとに1つのDbContext...なぜ?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】エラー。「戻り値を変更できません」 C#
-
[解決済み】統合マネージドパイプラインモードで適用されないASP.NETの設定が検出された
-
[解決済み】SmtpException: トランスポート接続からデータを読み取れません:net_io_connectionclosed
-
[解決済み】値が期待した範囲に収まらない
-
[解決済み】C# - パスに不正な文字がある場合
-
[解決済み] [Solved] 不正な文字列値: '\xEFxBFxBD' for column
-
[解決済み] UnityでOnCollisionEnterが呼ばれない
-
[解決済み】Unity 「関連するスクリプトを読み込むことができません」「Win32Exception: システムは指定されたファイルを見つけることができません"
-
[解決済み】名前 'ViewBag' が現在のコンテキストに存在しない - Visual Studio 2015
-
[解決済み】データが存在しないのに読み込もうとする試みが無効である