日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

简单一致的Log4j2 Logger命名

發(fā)布時(shí)間:2023/12/3 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 简单一致的Log4j2 Logger命名 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

在帶有Java 7方法句柄的可移植記錄器名稱(chēng)一文中 ,我寫(xiě)了關(guān)于使用Java 7的方法句柄來(lái)命名類(lèi)的記錄器的文章。 我在那篇文章中說(shuō)過(guò),這種方法的優(yōu)點(diǎn)包括記錄器命名的一致性,避免了意外的代碼復(fù)制和粘貼,這可能會(huì)導(dǎo)致將不同的類(lèi)名用作記錄器名稱(chēng)。 在這篇文章中,我看看如何Log4j的2提供了一種方法實(shí)現(xiàn)這些同樣的好處。

Log4j 2可以識(shí)別基于類(lèi)名的記錄器命名方法。 Log4j 2手冊(cè)中 “ Log4j 2 API ”頁(yè)面的“ Logger Names ”部分指出:“在大多數(shù)情況下,應(yīng)用程序通過(guò)將當(dāng)前類(lèi)的名稱(chēng)傳遞給LogManager.getLogger來(lái)命名其記錄器。 因?yàn)檫@種用法非常普遍,所以Log4j 2提供了它作為記錄器名稱(chēng)參數(shù)被省略或?yàn)榭諘r(shí)的默認(rèn)值。”

以下非常簡(jiǎn)單的Calculator類(lèi)演示了此過(guò)程,即使用無(wú)參數(shù)LogManager創(chuàng)建一個(gè)Logger 。 getLogger()調(diào)用。 因?yàn)闆](méi)有參數(shù)傳遞給getLogger()方法,所以記錄器將以創(chuàng)建Logger的類(lèi)命名。 方法LogManager.getLogger()的Javadoc注釋確認(rèn)了此行為:“返回帶有調(diào)用類(lèi)名稱(chēng)的Logger。”

計(jì)算器.java

package dustin.examples.log4j;import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger;import java.util.Arrays;/*** Simple calculator class that is intended more for demonstration* of Log4j2 than for calculating anything.*/ public class Calculator {private static final Logger logger = LogManager.getLogger();public String getLoggerName(){return logger.getName();}/*** Add the provided operands together and provide their sum.** @param operands Operands to be added together.* @return Sum of the provided operands.*/public long add(final long ... operands){long sum = 0;for (final long operand : operands){sum += operand;}logger.debug("The sum of " + Arrays.toString(operands) + " is " + sum);return sum;} }

通過(guò)如上所示實(shí)現(xiàn)Calculator類(lèi),可以通過(guò)調(diào)用Logger.getName()來(lái)獲得該類(lèi)的記錄器名稱(chēng),如Calculator方法getLoggerName()所示,該名稱(chēng)是“ dustin.examples.log4j.Calculator”。 盡管此處未顯示,但使用無(wú)參數(shù)LogManager.getFormatterLogger()檢索的Logger也將使用“調(diào)用類(lèi)的完全限定名稱(chēng)作為L(zhǎng)ogger名稱(chēng)。”

結(jié)論

假設(shè)選擇的記錄器命名方案使用完全合格的程序包和類(lèi)名,則本文中討論和演示的Log4j 2方法易于使用,并且易于使用一致且正確的記錄器名稱(chēng)。 這種方法比命名記錄器的方法處理方法更簡(jiǎn)短,甚至更具可讀性,但是該方法特定于Log4j 2,而該方法處理方法可以與多個(gè)日志記錄框架和庫(kù)一起使用。

翻譯自: https://www.javacodegeeks.com/2015/10/easy-and-consistent-log4j2-logger-naming.html

總結(jié)

以上是生活随笔為你收集整理的简单一致的Log4j2 Logger命名的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。