본문 바로가기

강좌/JAVA THREAD

자바 쓰레드(Thread) - Atomic 예제 동기화를 배울때 synchronized와 volatile을 공부했다. synchronized는 메소드 시그니쳐나 블럭(?)을 지정할때 volatile은 변수에 대한 동기화였다. 아래 예제를 보자. 예제는 백만까지 for루프를 돌면서 합계를 구하는 것이다. 위의 예제를 돌려보면 결과값이 499999500000 나온다(백만의 합계이다) 걸린 시간은 대략 컴퓨터에 따라 다르지만 내 컴퓨터 기준으로는 32ms 다.(내 컴이 꾸리다) 그럼 쓰레드를 두개 생성후 돌리면 어떻게 될까? 499999500000 * 2 = 999999000000 가 나와야 하지 않을까? 근데 아니다. 가끔씩 값이 다르게 나온다.(아래처럼) 이유는 아무리 변수에 대한 volatile처리를 했어도 add메소드에서 동시에 두개가 작업이 들어가.. 더보기
자바 쓰레드(Thread) - Volatile 예제 요즘은 64비트 컴퓨터가 많이 보급됐지만 불과 몇년해도 32비트였다. 물론 지금도 엄청 많다. Volatile이라는것은 변수에 동기화(?)를 거는 것이라고 한다. 자바에서 int는 32비트 연산을 수행하지만 long이나 double은 64비트 연산을 한다. 그래서 int는 원자연산이라고 한다(더이상 쪼갤수 없는..) 이와 달리 long은 아니다. 쓰레드에서 long형으로 연산을 하다 보면 값이 엉뚱하게 나올 수 있다. 아래예제가 그 예이다. long형 두개를가지고 비교하는 것이다. 무한 반복을 해서 첫번째 long을 꺼내서 while문에서 똑같은 0번째 를 꺼내와서 비교하는것이다. (말이 좀 이상한가 아무튼 같은 값을 비교 하는것이다.) 메인에서 쓰레드 한개를 생성해서 돌리면 오류없이 잘 돌아간다. 왜냐.. 더보기
자바 쓰레드(Thread) - Volatile 더보기
자바 쓰레드(Thread) - 쓰레드(Thread) 생성자/소비자패턴 생성자/소비자 패턴이다. 예제를 보자 전에 했던 자판기나 은행예제와 다를께 없다. 아래는 컴퓨터로 프린터를 사용할때를 생각해서 만든 예제이다. 컴퓨터 3대로 프린터를 동작하는것이다. 총 클래스 4개와 인터페이스 1개로 구성되어 있다. 더보기
자바 쓰레드(Thread) - 쓰레드로컬(ThreadLocal) 쓰레드 로컬이란걸 정말 몰랐었다. 지금도 잘 모르지만 일단 정의를 보자 ThreadLocal이란? 일반 변수의 수명은 특정 코드 블록(예, 메서드 범위, for 블록 범위 등) 범위 내에서만 유효하다. { int a = 10; ... // 블록 내에서 a 변수 사용 가능 } // 변수 a는 위 코드 블록이 끝나면 더 이상 유효하지 않다. (즉, 수명을 다한다.) 반면에 ThreadLocal을 이용하면 쓰레드 영역에 변수를 설정할 수 있기 때문에, 특정 쓰레드가 실행하는 모든 코드에서 그 쓰레드에 설정된 변수 값을 사용할 수 있게 된다. 아래 그림은 쓰레드 로컬 변수가 어떻게 동작하는 지를 간단하게 보여주고 있다.(출처 : 자바캔) 이라고 되어 있다. 아래 설명도 보자 ThreadLocal의 기본 사용법 .. 더보기
자바 쓰레드(Thread) - 쓰레드(Thread)의 동기화 (synchronized) 자판기 예제 자판기를 보자. 자판기안에는 음료수들이 차례차례로 들어 있다 그리고 공급자가 있고 사람들이 돈을 넣고 음료수를 빼먹는다. 공급자 - 음료수 공급자 소비자 - 돈을 넣고 음료수를 빼먹는 사람 만약 자판기에 음료수가 없으면 소비자가 돈을 넣고 음료수를 뽑을 수 있을까? 없다. 공급자가 음료수를 넣기 전까지는 소비자가 사용하면 안된다. 예제로 네개의 클래스를 만들어 보자 메인 클래스, 공급자 클래스, 자판기 클래스, 소비자 클래스를 아래와 같이 만들었다. 자판기에서는 자바 stack 을 사용하였다. 처음 넣은 음료수는 나중에 나온다고 설정해서 사용. getDrink()는 소비자가 뽑아 먹는 것을 구현한것인데.. while조건문에 스택이 비워져있으면 안에서 스레드 wait을 걸었다. 왜냐면 음료수도 없는데 뽑아.. 더보기
자바 쓰레드(Thread) - 쓰레드(Thread)의 동기화 (synchronized) 화장실 예제 첫번째 동기화 예제를 보자 냄새는 나지만 화장실 예제다. 보통 집에는 화장실이 한개 혹은 두개다.(뭐 갑부라면 가족 한명당 한개씩 있을수도 있지만) 한개라고 치자. 그러면 아침에 일어나서 한명이 들어가면 나머지 구성원은 그 한명이 나올때까지 기달려야 한다. 예제를 보자 - 가족클래스에서 호출되어서 openDoor를 호출하면 입장하고 for로 일정시간 일(?) 보는 작업을 한다. 결과를 보자 아버지가 입장하고 끄으응을 할때쯤 엄마가 입장하고 말았다.. 그리고 나서 끄으응 할때쯤 아버지가 다 했다..이렇게 되면 현재 화장실에 두명이 일보고 있는것이다. 그 뒤로 여동생이 들어오고..등등.순서가 차례차례로 가야 할것이 마구마구 사람들이 순서 없이 들어 온다. 결국 동기화 처리가 되지 않는 것이다. 동기화 처리를.. 더보기
자바 쓰레드(Thread) - 쓰레드(Thread)의 동기화 (synchronized) 더보기
자바 쓰레드(Thread) - 쓰레드(Thread)의 데이터 교환 예제 쓰레드간의 데이터를 교환할때 무작정 하면 안된다. 쓰레드는 어찌됐는 각각 따로따로 일을 처리 한다. 예를 들어 3.14 (파이값)를 구해서 찍는걸 생각해보자. 우선 클래스 4개를 준비해보자. - A : 메인메소드가 있는 클래스 - B : 파이값을 계산하는 클래스 - C : 파이값을 찍는 클래스 - D : B와 C를 위한 공통 공유 구역이다. 요지는 B에서 계산한 값을 D클래스 인스턴스 변수에다 넣고 C는 그걸 가져가다 찍는것이다. 결과를 테스트 해보면 C는 0.0을 찍는다. 왜냐하면 아직 B는 계산중이므로 D에 값을 던져주지 못했는데 C가 D의 값을 가져다 쓰니까 그런다. 이를 위해 B가 계산 끝나고 D에 값을 넣어 줄때까지 C는 B가 끝났는지 안끝났는지 체크하면서 값을 가져 올 필요가 있다. 아래 예제.. 더보기
자바 쓰레드(Thread) - 쓰레드(Thread)의 데이터 교환 더보기