SLF4J-매개 변수화 된 로깅
이 튜토리얼의 앞부분에서 설명한대로 SLF4J는 매개 변수화 된 로그 메시지에 대한 지원을 제공합니다.
메시지에 매개 변수를 사용하고 나중에 동일한 명령문에서 값을 전달할 수 있습니다.
통사론
아래와 같이 메시지 (String)에 자리 표시 자 ({})를 사용해야하며 나중에 자리 표시 자 값을 전달할 수 있습니다. object 형식, 메시지와 값을 쉼표로 구분합니다.
Integer age;
Logger.info("At the age of {} ramu got his first job", age);
예
다음 예제는 SLF4J를 사용하는 매개 변수화 된 로깅 (단일 매개 변수 사용)을 보여줍니다.
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class PlaceHolders {
public static void main(String[] args) {
//Creating the Logger object
Logger logger = LoggerFactory.getLogger(PlaceHolders.class);
Integer age = 23;
//Logging the information
logger.info("At the age of {} ramu got his first job", age);
}
}
산출
실행시 위의 프로그램은 다음과 같은 출력을 생성합니다.
Dec 10, 2018 3:25:45 PM PlaceHolders main
INFO: At the age of 23 Ramu got his first job
매개 변수화 된 로깅의 장점
Java에서 문장에 값을 인쇄해야하는 경우 연결 연산자를 다음과 같이 사용합니다.
System.out.println("At the age of "+23+" ramu got his first job");
여기에는 정수 값 23을 문자열로 변환하고이 값을 주변 문자열에 연결하는 작업이 포함됩니다.
그리고 그것이 로깅 문장이고 문장의 특정 로그 수준이 비활성화되어 있다면이 모든 계산은 소용이 없을 것입니다.
이러한 상황에서는 매개 변수화 된 로깅을 사용할 수 있습니다. 이 형식에서 처음에 SLF4J는 특정 수준에 대한 로깅이 활성화되었는지 여부를 확인합니다. 그렇다면 메시지의 자리 표시자를 각 값으로 바꿉니다.
예를 들어 다음과 같은 진술이있는 경우
Integer age;
Logger.debug("At the age of {} ramu got his first job", age);
디버깅이 활성화 된 경우에만 SLF4J는 나이를 정수로 변환하고 문자열과 연결합니다. 그렇지 않으면 아무 작업도 수행하지 않습니다. 따라서 로깅 수준이 비활성화되면 매개 변수 구성 비용이 발생합니다.
두 인수 변형
메시지에 두 개의 매개 변수를 다음과 같이 사용할 수도 있습니다.
logger.info("Old weight is {}. new weight is {}.", oldWeight, newWeight);
예
다음 예제는 매개 변수화 된 로깅에서 두 개의 자리 표시 자의 사용법을 보여줍니다.
import java.util.Scanner;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class PlaceHolders {
public static void main(String[] args) {
Integer oldWeight;
Integer newWeight;
Scanner sc = new Scanner(System.in);
System.out.println("Enter old weight:");
oldWeight = sc.nextInt();
System.out.println("Enter new weight:");
newWeight = sc.nextInt();
//Creating the Logger object
Logger logger = LoggerFactory.getLogger(Sample.class);
//Logging the information
logger.info("Old weight is {}. new weight is {}.", oldWeight, newWeight);
//Logging the information
logger.info("After the program weight reduced is: "+(oldWeight-newWeight));
}
}
산출
실행시 위의 프로그램은 다음과 같은 출력을 생성합니다.
Enter old weight:
85
Enter new weight:
74
Dec 10, 2018 4:12:31 PM PlaceHolders main
INFO: Old weight is 85. new weight is 74.
Dec 10, 2018 4:12:31 PM PlaceHolders main
INFO: After the program weight reduced is: 11
다중 인수 변형
다음 예제와 같이 두 개 이상의 자리 표시자를 사용할 수도 있습니다.
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class PlaceHolders {
public static void main(String[] args) {
Integer age = 24;
String designation = "Software Engineer";
String company = "Infosys";
//Creating the Logger object
Logger logger = LoggerFactory.getLogger(Sample.class);
//Logging the information
logger.info("At the age of {} ramu got his first job as a {} at {}", age, designation, company);
}
}
산출
실행시 위의 프로그램은 다음과 같은 출력을 생성합니다.
Dec 10, 2018 4:23:52 PM PlaceHolders main
INFO: At the age of 24 ramu got his first job as a Software Engineer at Infosys