public void info(Object message) {
if (logger.isInfoEnabled()) {
forcedLog(logger, Level.INFO, message);
}
}
public void info(Object message, Throwable t) {
if (logger.isInfoEnabled()) {
forcedLog(logger, Level.INFO, message, t);
}
}
public void info(String pattern, Object... arguments) {
if (logger.isInfoEnabled()) {
forcedLog(logger, Level.INFO, format(pattern, arguments));
}
}
public void info(String pattern, Throwable t, Object... arguments) {
if (logger.isInfoEnabled()) {
forcedLog(logger, Level.INFO, format(pattern, arguments), t);
}
}
public void warn(Object message) {
if (logger.isEnabledFor(Level.WARN)) {
forcedLog(logger, Level.WARN, message);
}
}
public void warn(Object message, Throwable t) {
if (logger.isEnabledFor(Level.WARN)) {
forcedLog(logger, Level.WARN, message, t);
}
}
public void warn(String pattern, Object... arguments) {
if (logger.isEnabledFor(Level.WARN)) {
forcedLog(logger, Level.WARN, format(pattern, arguments));
}
}
public void warn(String pattern, Throwable t, Object... arguments) {
if (logger.isEnabledFor(Level.WARN)) {
forcedLog(logger, Level.WARN, format(pattern, arguments), t);
}
}
public void error(Object message) {
if (logger.isEnabledFor(Level.ERROR)) {
forcedLog(logger, Level.ERROR, message);
}
}
public void error(Object message, Throwable t) {
if (logger.isEnabledFor(Level.ERROR)) {
forcedLog(logger, Level.ERROR, message, t);
}
}
public void error(String pattern, Object... arguments) {
if (logger.isEnabledFor(Level.ERROR)) {
forcedLog(logger, Level.ERROR, format(pattern, arguments));
}
}
public void error(String pattern, Throwable t, Object... arguments) {
if (logger.isEnabledFor(Level.ERROR)) {
forcedLog(logger, Level.ERROR, format(pattern, arguments), t);
}
}
public void fatal(Object message) {
if (logger.isEnabledFor(Level.FATAL)) {
forcedLog(logger, Level.FATAL, message);
}
}
public void fatal(Object message, Throwable t) {
if (logger.isEnabledFor(Level.FATAL)) {
forcedLog(logger, Level.FATAL, message, t);
}
}
public void fatal(String pattern, Object... arguments) {
if (logger.isEnabledFor(Level.FATAL)) {
forcedLog(logger, Level.FATAL, format(pattern, arguments));
}
}
public void fatal(String pattern, Throwable t, Object... arguments) {
if (logger.isEnabledFor(Level.FATAL)) {
forcedLog(logger, Level.FATAL, format(pattern, arguments), t);
}
}
public void assertLog(boolean assertion, String message) {
if (!assertion) {
forcedLog(logger, Level.ERROR, message);
}
}
private static void forcedLog(Logger logger, Level level, Object message) {
logger.callAppenders(new LoggingEvent(FQCN, logger, level, message, null));
}
private static void forcedLog(Logger logger, Level level, Object message, Throwable t) {
logger.callAppenders(new LoggingEvent(FQCN, logger, level, message, t));
}
private static String format(String pattern, Object... arguments) {
return MessageFormat.format(pattern, arguments);
}
}
分享到:
相关推荐
TYPE-C-31-M-02 USB Type-c allegro封装 韩荣HRo TYPE-C-31-M-02 规格:10mm*9.65mm 插拔力:5-20N 类型:TYPE-C母座 品名:TYPE-C母座 TYPE-C母座技术参数: 1.额定负荷: DC 40V 2.5A 2.接触电阻: ≤40mΩ 3.绝缘阻抗:...
TYPE-C-31-M-01 USB Type-c allegro封装 韩荣HRo TYPE-C-31-M-01 规格:10mm*9.65mm 插拔力:5-20N 类型:TYPE-C母座 品名:TYPE-C母座 TYPE-C母座技术参数: 1.额定负荷: DC 40V 2.5A 2.接触电阻: ≤40mΩ 3.绝缘阻抗:...
SOT封装库SOT23_5 SOT223 SOT143 SOT89 SOT343 SOT23ALTIUM库(AD库PCB封装库 ): SOT 89.PcbLib SOT143_L.PcbLib SOT143_M.PcbLib SOT143_N.PcbLib SOT223_L.PcbLib SOT223_M.PcbLib SOT223_N.PcbLib SOT23-5.PcbLib...
包含J30J等封装,总共几百个封装,是allegro的PCB封装,只有PCB封装,有dra文件,pad文件,psm文件,fsm文件。还包含了一些其他的封装, 所有的封装名和器件名都在excel表里面有对应关系,库文件很全
ASP-134486-01 AD封装ASP-134486-01 AD封装ASP-134486-01 AD封装ASP-134486-01 AD封装ASP-134486-01 AD封装ASP-134486-01 AD封装ASP-134486-01 AD封装ASP-134486-01 AD封装ASP-134486-01 AD封装ASP-134486-01 AD封装...
PCB设计 SCN-2-19 AD封装PCB设计 SCN-2-19 AD封装PCB设计 SCN-2-19 AD封装PCB设计 SCN-2-19 AD封装PCB设计 SCN-2-19 AD封装PCB设计 SCN-2-19 AD封装PCB设计 SCN-2-19 AD封装PCB设计 SCN-2-19 AD封装PCB设计 SCN-2-19...
4. **封装NAL单元**:将NAL单元转换为FLV的视频数据块。这涉及到添加FLV的标签头,包括时间戳、数据类型(视频或音频)和数据长度。对于H.264,NAL单元通常会被前缀一个特定的字节序列,例如0x09,表示这是一个关键...
6. **事件数据结构**:Log4j2使用LogEvent对象封装日志信息,使其更易于处理和过滤。 7. **日志级别的优先级**:Log4j2允许设置每个Logger的优先级,便于控制日志输出的详细程度。 8. **自动重加载配置**:如果...
Altium Designer DDA PCB封装
### SOT-23-6 封装尺寸详解 #### 一、SOT-23-6 封装概述 SOT-23-6(Small Outline Transistor Package)是一种小型化封装技术,广泛应用于各类电子元件如晶体管、运算放大器等。这种封装形式以其紧凑的设计和良好...
AD封装带3D 自已第一次做带3D的封装。 xh2.54-4p 贴片AD封装,方便下载,可做多种3D封装。
4. **简化开发**:UDDI4J提供了封装好的API,使得开发者无需关注底层协议细节,专注于应用逻辑。 5. **测试工具**:UDDI4J还包含了模拟UDDI服务器的测试工具,方便开发和调试。 **uddi4j-bin-2.0.5.zip内容详解** ...
网络拓扑通常采用线形或星形结构,物理层定义了信号的传输方式,数据链路层处理数据包的封装和解封装,而应用层则定义了网络中各种消息的格式和语义。 ### 三、关键技术要点 #### 1. **网络访问和数据同步** SAE ...
j360-boot, j360-boot --- 使用Spring Boot封装j360,Spring Boot入门到深入学习demo
SC-70-6封装,6引脚
LFCSP4mm*4mm封装库(ada4857-2) 用于ad绘制pcb板,绘制的是ada4857-2型芯片,16pin的LFCSP封装
4G5G模块MSATA盘(M.2_B-KEY+M.2_E-KEY 封装) AD集成封装库,已经其他一些USB3.0 ,RJ45 ,SD卡等,详细封装型号如下: Component Count : 69 Component Name ----------------------------------------------- ...
同时结合了中兴通讯内部的其他相关标准,如Q/ZX04.100.2-2001《印制电路板设计规范——工艺性要求》和Q/ZX04.100.4-2001《印制电路板设计规范——元器件封装库基本要求》。所有引用标准均采用最新的在线版本。 ####...
twitter的JAVA封装工具,提供twitter API 的核心功能,是一个JAR包
TO-3,TO-5,TO-18,TO-39,TO-46,TO-52,TO-66,TO-72,TO-92,TO-126,TO-126H,TO-126V,TO-202H,TO-202V,TO-202VS,TO-218H,TO-218V等等封装