본문 바로가기

스레드

(3)
[병렬프로그래밍] 스레드그룹 이해하기 스레드 그룹 자바에서는 스레드들을 여러개 묶어 그룹으로 관리할 수 있습니다. 자바에서 제공하는 클래스들 중에는 쓰레드가 있고 스레도 그룹도 있습니다. 스레드 그룹 객체를 생성하면 그 밑에 스레드들을 모아 놓을 수 있습니다. 여러 개의 쓰레드들을 한꺼번에 모아서 관리하고 싶을때 이용하기도 합니다. 평상시에 스레드 그룹을 사용할 일이 많지는 않지만 대용량 프로그램의 경우에는 스레드 그룹을 이용하면 유용하게 스레드를 컨트롤할 수가 있습니다. 1) 스레드 그룹 개요- 애플리케이션에서 많은 스레드 생성시 사용- 스레드를 그룹으로 묶어서 사용하는 것이 편리- 그룹안의 스레드를 제어하기 위한 지원메소드 부족 (자바 라이브러리 중 가장 실패한 부분 중 하나) 2) 스레드 그룹 구성- 자바에서의 모든 스레드는 특정 스레..
[병렬프로그래밍] 스레드 이해하기 스레드의 생명주기 스레드의 생명주기는 프로세스의 생명주기와 유사합니다. java에서 프로세스 생명주기를 나타내는 그림입니다. 프로그램이 실행되면 메인부터 시작하여 하나하나씩 개발자가 짠 함수들이 순차적으로 실행됩니다. 이때 a(), b()라는 함수가 있는데, 동시에 실행하고 싶을때 쓰레드를 이용하게 됩니다. 각 함수별로 해당 함수를 실행하는 스레드를 생성합니다. 자바에서 실행되는 모든 엔티티는 객체입니다. 쓰레드 역시 마찬가지로 객체입니다. 쓰레드를 실행하는 메소드(start()) 실행하면 쓰레드가 동작하면서 CPU가 점유된 상태가 됩니다. 스레드 이후 커리큘럼은 파일 IO에 대한 설명이 이루어지는데, 파일 IO 역시 네트워크 프로그래밍과 연결되어 있습니다. 왜냐하면 네트워크 프로그래밍은 결국 네트워크 ..
[병렬프로그래밍] 프로세스, 스레드 개념 프로세스란 무엇인가?- 프로세스 : 자기 자신만의 주소 공간을 갖는 독립적인(Self-Contained) 실행 프로그램- 멀티 프로세스 : 두 개 이상의 프로세스가 실행되는 것. 프로그램이 여러개 띄워져 있는 형식.- 멀티 태스킹 : 두 개 이상의 프로세스를 실행하여 일을 처리하는 것 프로그램 : 스태틱하게 머신에 인스톨되어있는 인스트럭션(코드, 커맨드, 실행해야할 명령)등의 집합프로세스 : 프로그램이 실행중(프로그램 안의 인스트럭션들이 실행되고 있는 중)인 것. 스레드란 무엇인가?- 스레드(경량 프로세스) : 프로세스 내의 독립적인 순차흐름 또는 제어- 멀티 스레드 : 하나의 프로세스에서 여러 개의 스레드가 병행적으로 처리 프로세스 내에 스레드란 개념이 포함되어 있으므로 스레드와 프로세스는 서로 연관이..