您好,登錄后才能下訂單哦!
本篇內容主要講解“java日志LoggerFactory.getLogger怎么使用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“java日志LoggerFactory.getLogger怎么使用”吧!
LoggerFactory.getLogger可以在IDE控制臺打印日志,便于開發,一般加在最上面:
使用:
//調試日志 private final static Logger logger = LoggerFactory.getLogger(xxxController.class);
優點:使用指定類初始化日志對象,在日志輸出的時候,可以打印出日志信息所在類
logger.debug、logger.info、logger.warn、logger.error、logger.fatal 的區別:
相同處:
它們的作用都是把錯誤信息寫到文本日志里
不同的是它們表示的日志級別不同:
日志級別由高到底是:fatal -> error -> warn -> info -> debug,低級別的會輸出高級別的信息,高級別的不會輸出低級別的
信息,如等級設為Error的話,warn,info,debug的信息不會輸出
修改日志輸出的級別要在log4j文件中進行配置
項目正式發布后,一般會把日志級別設置為fatal或者error
package wwfww.warehouse.aaaaa; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * @version Revision 1.0.0 * @版權:版權所有 (c) 2018 * @see: * @創建日期:2020年3月2日 @功能說明: @begin * @修改記錄: * @修改后版本 修改人 修改內容 * @2020年3月2日 liuyu 創建 * @end */ public class LoggerFactoryDemo { private static final Logger LOGGER = LoggerFactory.getLogger(LoggerFactoryDemo.class); public static void main(String[] args) { for (int i=0;i<5;i++){ LOGGER.info("這是一條數據"+i); } } }
13:58:52.913 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - 這是一條數據0
13:58:52.925 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - 這是一條數據1
13:58:52.925 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - 這是一條數據2
13:58:52.925 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - 這是一條數據3
13:58:52.925 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - 這是一條數據4
可以看到控制臺日志輸出的時候,打印出日志信息所在類
也可以用在try catch中:
try{ ...... } catch (IOException e) { logger.info("錯誤信息:" + e.getMessage()); return new Result(e.getMessage()); }
在日志輸出時,字符串變量之間的拼接使用占位符的方式
說明:因為 String 字符串的拼接會使用 StringBuilder 的 append()方式,有一定的性能損耗。使用占位符僅是替換動作,可以有效提升性能。
新建entity
package wwfww.warehouse.aaaaa; import javax.xml.crypto.Data; import java.util.Date; /** * @version Revision 1.0.0 * @版權:版權所有 (c) 2018 * @see: * @創建日期:2020年3月2日 @功能說明: @begin * @修改記錄: * @修改后版本 修改人 修改內容 * @2020年3月2日 liuyu 創建 * @end */ public class DemoEntity { public String name; public String address; public Date birthday; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } }
package wwfww.warehouse.aaaaa; import com.alibaba.fastjson.JSON; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.util.Date; /** * @version Revision 1.0.0 * @版權:版權所有 (c) 2018 * @see: * @創建日期:2020年3月2日 @功能說明: @begin * @修改記錄: * @修改后版本 修改人 修改內容 * @2020年3月2日 liuyu 創建 * @end */ public class LoggerFactoryDemo { private static final Logger LOGGER = LoggerFactory.getLogger(LoggerFactoryDemo.class); public static void main(String[] args) { for (int i=0;i<5;i++){ DemoEntity entity = getDemoEntity(i); LOGGER.info("這是一條數據:{}", JSON.toJSONString(entity)); } for (int i=0;i<5;i++){ DemoEntity entity = getDemoEntity(i); LOGGER.info("{}:也可以是前面", JSON.toJSONString(entity)); } } private static DemoEntity getDemoEntity(int i){ DemoEntity demoEntity = new DemoEntity(); demoEntity.setName("小明"+i+"號"); demoEntity.setAddress("北京胡同"+2+"街道"); demoEntity.setBirthday(new Date()); return demoEntity; } }
控制臺輸出:
14:27:42.161 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - 這是一條數據:{"address":"北京胡同2街道","birthday":1587882461879,"name":"小明0號"}
14:27:42.173 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - 這是一條數據:{"address":"北京胡同2街道","birthday":1587882462173,"name":"小明1號"}
14:27:42.173 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - 這是一條數據:{"address":"北京胡同2街道","birthday":1587882462173,"name":"小明2號"}
14:27:42.173 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - 這是一條數據:{"address":"北京胡同2街道","birthday":1587882462173,"name":"小明3號"}
14:27:42.173 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - 這是一條數據:{"address":"北京胡同2街道","birthday":1587882462173,"name":"小明4號"}
14:43:49.631 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - {"address":"北京胡同2街道","birthday":1587883429631,"name":"小明0號"}:也可以是前面
14:43:49.631 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - {"address":"北京胡同2街道","birthday":1587883429631,"name":"小明1號"}:也可以是前面
14:43:49.631 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - {"address":"北京胡同2街道","birthday":1587883429631,"name":"小明2號"}:也可以是前面
14:43:49.631 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - {"address":"北京胡同2街道","birthday":1587883429631,"name":"小明3號"}:也可以是前面
14:43:49.631 [main] INFO wwfww.warehouse.aaaaa.LoggerFactoryDemo - {"address":"北京胡同2街道","birthday":1587883429631,"name":"小明4號"}:也可以是前面
注:
使用JSON.toJSONString要添加阿里的依賴
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.57</version> </dependency>
到此,相信大家對“java日志LoggerFactory.getLogger怎么使用”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。