학습 내용 (8/16)

Welcome to Seoyun Dev Log·2023년 8월 15일
0

[WORK] 학습내용

목록 보기
16/25

LinkedBlockingQueue

: 각각의 blockingQueue가 노드로 연결되어있는 것
큐에서 꺼내갈 원소가 없는 경우 해당 쓰레드는 wait 상태에 들어간다.
큐의 폭발을 막기 위해 생성자에 큐의 사이즈를 명시할 수 있도록 설계되었으며 데이터를 가져오기 retrieve 위해 poll()과 take() 메소드를 제공한다.
두 메소드의 차이점은 큐가 비어있을 때 poll 메소드는 null을 리턴하거나 timeout을 설정할 수 있는 반면에 take 메소드는 꺼낼 수 있는 원소가 있을 때까지 기다린다.

applicationContext.getBean()

Spring에서 ApplicationContext는 애플리케이션의 설정을 제공하기 위한 중심 인터페이스입니다. 이는 애플리케이션의 빈(bean)과 그들의 의존성, 라이프사이클 및 기타 설정 요소를 관리하는 역할을 담당

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class MyApp {
    public static void main(String[] args) {
        // Spring 애플리케이션 컨텍스트 구성 파일을 로드합니다.
        ApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml");

        // 애플리케이션 컨텍스트에서 "myBean"이라는 이름의 빈을 가져옵니다.
        MyBean myBean = (MyBean) applicationContext.getBean("myBean");

        // 이제 myBean 인스턴스를 사용할 수 있습니다.
        myBean.doSomething();
    }
}

javax.sql.DataSource

javax.sql.DataSource는 Java에서 데이터베이스와의 연결을 관리하기 위한 인터페이스입니다. 데이터베이스와의 연결을 설정하고 관리하는 기능을 추상화하여 제공하는 인터페이스로, Java 애플리케이션에서 데이터베이스와의 상호작용을 간단하게 만들어줍니다.

DataSource 인터페이스는 데이터베이스 연결 풀링과 관련된 작업을 지원하는데 중점을 둡니다. 연결 풀링은 데이터베이스 연결을 필요할 때마다 생성하고 닫는 대신 미리 생성된 연결들을 풀에 보관하여 재사용하는 방식을 말합니다. 이를 통해 애플리케이션의 성능과 확장성을 향상시킬 수 있습니다.

DataSource 인터페이스의 주요 메서드와 기능은 다음과 같습니다:

getConnection(): 데이터베이스와의 연결을 가져오는 메서드입니다. 이 메서드를 호출하면 미리 생성된 연결을 반환하거나, 연결 풀에 여유 연결이 없다면 새로운 연결을 생성하여 반환합니다.

getConnection(username, password): 지정된 사용자 이름과 비밀번호로 데이터베이스와의 연결을 가져오는 메서드입니다.

unwrap(): 특정 데이터베이스 업체의 구현 클래스로부터 해당 데이터베이스 고유의 메서드와 속성을 사용하기 위해 객체를 언래핑하는 메서드입니다.

isWrapperFor(): 특정 클래스나 인터페이스로 래핑되어 있는지 여부를 확인하는 메서드입니다.

DataSource 인터페이스를 구현하는 구체적인 클래스들은 데이터베이스 종류에 따라 다르며, 주요한 구현 클래스로는 Apache Commons DBCP, HikariCP, C3P0 등이 있습니다. 이러한 라이브러리들은 연결 풀링 기능을 제공하면서 애플리케이션의 성능과 리소스 관리를 최적화합니다.

Java에서 데이터베이스와 작업을 할 때, 직접 연결을 생성하고 관리하는 대신 javax.sql.DataSource 인터페이스와 그 구현체를 활용하여 데이터베이스 관련 작업을 보다 효율적으로 처리할 수 있습니다.

new File()

: 파일을 나타낼 수 있는 객체를 생성하는 것으로 path, name 등의 메서드를 활용할 수 있으나 java 7부터는 구식이 되어 Java 7 이후에는 java.nio.file.Path 및 java.nio.file.Files 클래스를 활용하여 파일 작업을 하는 것이 더 권장됩니다. Path와 Files 클래스는 기존의 File 클래스보다 더 강력하고 유연한 파일 조작 기능을 제공합니다.
따라서 가능하다면, Java 7 이후의 버전에서는 Path와 Files 클래스를 사용하여 파일 작업을 수행하는 것이 좋습니다.

File.exists()

:지정된 파일 또는 디렉토리가 실제로 파일 시스템에 존재하는지 여부를 확인
파일 시스템에서 해당 경로에 파일이나 디렉토리가 존재하는지 여부에 따라 true나 false를 반환

File.getParent()

: 해당 파일의 부모 디렉토리를 나타내는 문자열을 반환

import java.io.File;

public class FileParentExample {
    public static void main(String[] args) {
        File file = new File("path/to/example.txt");

        // 부모 디렉토리 경로 가져오기
        String parentDirectory = file.getParent();

        System.out.println("부모 디렉토리: " + parentDirectory);
    }
}

//출력 : path/to

파일의 경로 정보를 분석하고 다양한 파일 조작 작업을 수행

FileUtils.forceDelete()

: 파일 또는 디렉토리를 강제로 삭제하는데 사용된다.
이 메서드는 파일 또는 디렉토리가 존재하는 경우에도 삭제를 시도하며 해당 파일이나 디렉토리를 삭제할 수 없을때에도 덮어쓰기 등의 작업을 통해 삭제를 시도합니다.

SAXBuilder.class

: JDOM 라이브러리의 일부인 클래스
XML 문서를 파싱하여 JDOM 객체로 변환하는 데 사용됩니다. JDOM은 Java에서 XML을 다루기 위한 라이브러리로, DOM 및 SAX 파서와 유사한 API를 제공하면서도 간결하고 사용하기 쉬운 특징을 가지고 있습니다.

SAXBuilder는 주로 XML 문서를 메모리에 로드하지 않고 스트림 방식으로 파싱하여 메모리 사용량을 최적화하는데 사용

.build()

: XML 데이터를 파싱하여 JDOM Document 객체로 변환하는 메서드입니다. build() 메서드를 호출할 때 파싱할 XML 데이터를 제공하여 사용합니다.
파싱 중에 오류가 발생하면 JDOMException이나 IOException 예외가 던져질 수 있습니다.

Element getChild(String name, Namespace namespace)

Element.getChild("providers", null)
는 JDOM 라이브러리를 사용하여 XML 문서에서 특정 이름을 가진 자식 요소를 가져오는 코드입니다. 이 코드는 getChild() 메서드를 호출하여 XML 요소에서 이름이 "providers"인 자식 요소를 찾는 역할을 합니다.

일반적으로 getChild() 메서드는 다음과 같은 형식으로 사용됩니다

name: 가져올 자식 요소의 이름을 나타냅니다.
namespace: 네임스페이스 정보를 나타내는 객체로, 해당 요소가 어떤 네임스페이스에 속하는지 지정할 수 있습니다. 네임스페이스를 사용하지 않는 경우에는 null로 설정합니다.
여기서 "providers"는 가져올 자식 요소의 이름이며, 네임스페이스를 사용하지 않는 경우 두 번째 인자로 null을 전달합니다.

StringUtils.isNoneBlank()

: 문자열이 비어있는지 확인 검증하는 것

System.getProperty("line.separator")

: Java에서 사용되는 시스템 속성 중 하나로, 현재 플랫폼의 줄 바꿈 문자열을 반환하는 메서드입니다. 줄 바꿈 문자열은 텍스트 파일이나 문자열 내에서 한 줄의 끝을 나타내는데 사용됩니다. 다양한 운영 체제에서 줄 바꿈 문자가 다르기 때문에 이 메서드를 사용하면 플랫폼 호환성을 유지하면서 줄 바꿈 문자를 적절히 처리할 수 있습니다.

FileReader fileReader = new FileReader( configFile );
			BufferedReader bufferedReader = new BufferedReader( fileReader );
			String xmlFile = "";
			StringBuilder xmlFileBuilder = new StringBuilder();
			while ( ( xmlFile = bufferedReader.readLine() ) != null ){
				xmlFileBuilder.append( xmlFile ).append(System.getProperty("line.separator"));

			}

StringBuilder.setLegth()

: 문자열을 동적으로 조작할 수 있는 가변적인 문자열 버퍼를 제공하는 클래스입니다. setLength() 메서드는 StringBuilder의 내부 버퍼 크기를 조절하는 역할

이 과정에서 문자열은 내부 버퍼 길이에 맞게 잘리거나 늘어날 수 있습니다.

FileUtils.forceMkdir()

: Apache Commons IO 라이브러리에 속하는 메서드로, 파일 또는 디렉토리를 생성하는 기능을 제공하는 메서드입니다. 이 메서드를 사용하면 지정된 경로에 디렉토리를 생성할 수 있습니다.

SecretKeySpec.class

: SecretSpec 클래스의 생성자를 사용해서 바이트 배열의 데이터키를 비밀키로 변환할 수 있다.

SealedObject

: javax.crypto 패키지에 속하는 클래스로, 암호화된 객체를 포함하고 있는 래퍼 객체입니다. SealedObject를 사용하면 객체를 암호화하여 저장하거나 네트워크를 통해 전송할 수 있습니다. 이 클래스는 Serializable 인터페이스를 구현하며, 암호화된 상태로 객체를 저장하고 전송하기 위해 주로 사용됩니다.

해당 객체는 getObject() 메서드를 사용하여 복호화된 상태로 다시 추출할 수 있습니다.

  • 예제
    SealedObject(Serializable object, Cipher c)는 암호화된 객체를 생성하는 데 사용되는 생성자입니다. 이 생성자는 암호화할 객체와 암호화 작업을 수행하는 Cipher 객체를 인자로 받습니다. SealedObject를 사용하여 객체를 암호화된 상태로 래핑하고 저장하거나 전송할 수 있습니다.

ObjectInputStream

: 객체를 직렬화하여 스트림으로 출력하는데 사용
직렬화는 객체의 상태를 바이트 스트림으로 변환하는 프로세스

profile
하루 일지 보단 행동 고찰 과정에 대한 개발 블로그

1개의 댓글

comment-user-thumbnail
2023년 8월 16일

훌륭한 글 감사드립니다.

답글 달기