본문 바로가기

분류 전체보기53

[회고] 싸피 13기 면접 탈락 회고 13기 싸피 면접 지난주 서울에 올라가 면접을 보았습니다. ( 서울 너무 멀어요.. ) 질문에 솔직하게 답변 하였고 눈 떠 보니 면접이 끝났습니다.기차를 타고 집에 가면서 면접에 대해서 복기 하였는데 좀 더 답변을 잘 할수 있었을것 같은데...하는 아쉬움이 남긴 했지만 돌아간다 해도 크게 답변이 다를것 같진 않았습니다.떨어질 것 같은 느낌이 들었는데 떨어졌습니다 ㅠ 떨어진 이유 ( 추측 )싸피에 지원한 이유는 공부할 환경과 지원금 때문이였습니다.영한님 강의를 80% 배웠으나 말할 정도의 실력은 안되기 때문에 싸피에 들어가 개념을 정리하며같이 공부하면 성장에 도움이 되겠다고 생각 하였습니다.면접에서 모든 답변에 솔직하게 말했는데 왜 싸피가 필요한지에 대한 어필이 부족 했다고 생각합니다.또한 질문은 의도가 .. 2024. 12. 13.
[Java] enum 왜 쓰는 걸까? Enum 이란? Enumeration 의 약자로 열거라는 뜻을 가지고 있으며 관련있는 상수들의 집합을 의미 합니다.enum은 왜 만들어졌을까요? 간단한 예시를 통해 알아보겠습니다. 과일 할인 정책파라미터로 과일을 입력 하면 과일의 할인 퍼센트를 알려 주는 함수가 있습니다.public static int fruitDiscountPercent(String fruit){ if(fruit.equals("banana")){ return 10; } if(fruit.equals("apple")){ return 20; } if(fruit.equals("grape")){ return 25; } return 0;} 만약에 개발자가 비교하는 과일의 스펠링을 잘못쓰면 어떻.. 2024. 11. 27.
[Java] 생산자 소비자 문제 생산자 소비자 문제 생산 하는 스레드 / 소비 하는 스레드를 나누어 생각해 보겠습니다.생산 스레드는 파일에 데이터를 읽는 역할을 하고소비 스레드는 읽은 데이터를 처리 하는 역할을 합니다.이렇게 처리 하려면 어딘가 데이터를 보관하는 자료 구조가 필요 합니다.자료 구조를 Queue 로 만들고 이름을 버퍼 라고 하고 버퍼의 크기를 2개로 설정 하겠습니다.  Bounded Queue는 여러 스레드에서 접근 할수 있기 때문에 synchronized가 걸려 있습니다.생산자 스레드만 먼저 실행 해보겠습니다.  생산자 1번 스레드가 락을 획득해 버퍼에 데이터를 넣고 락을 반납 하였습니다.2,3 번 스레드는 락을 획득 하지 못해 락 대기 집합에서 blocked 상태로 있습니다.  2번 스레드가 락을 획득해 버퍼에 데이터.. 2024. 11. 25.
[Java] LockSupprot, ReentrantLock LockSupprot 자바 1.5 부터 synchronized 단점을 해결 하기 위해 java.util.concurrent 패키지가 추가 되었습니다.ReentrantLock를 알기 위해선 LockSupport에 대한 정보가 필요한데LockSupport는 자신을 Waiting 상태로 바꾸거나 인터럽트 없이 다른 스레드를 깨울 수 있는 기능을 제공 합니다.간단한 예제를 통해서 알아 보겠습니다.main 스레드 작업 : unpark를 통해 thread -1 번을 깨웁니다.thread -1 작업 :  park를 통해 자신 스레드를 waiting 상태로 바꿉니다.public static void main(String[] args) { Thread thread1 = new Thread(new ParkTe.. 2024. 11. 19.
[Java] 메모리 가시성, 임계 영역 메모리 가시성 메모리 가시성을 알아 보기 위해 예제를 만들었습니다.스레드A의 작업 : while( flag )만약 메인 스레드에서 스레드A의 flag 값을 바꾼다면 작업이 중단 될까요?public static void main(String[] args) { RoofTask task = new RoofTask(); Thread thread = new Thread(task, "Thread-A"); log("스레드-A 시작" + task.flag); thread.start(); sleep(1000); log("스레드-A 루프 종료 요청"); task.flag = false; log("task.flag = " +.. 2024. 11. 15.
[Java] Join, Interrupt, Yield 조인 ( Join )조인은 왜 필요 할까요?간단한 작업을 통해 이해 해보도록 하겠습니다.스레드A는 1~10의 합을 구하는 작업을 하고 메인 스레드는 그 결과를 출력 합니다.public static void main(String[] args) throws InterruptedException { AddOneToTen task = new AddOneToTen(); Thread threadA = new Thread(task, "Thread-A"); threadA.start(); System.out.println("결과 값 : " + task.result); System.out.println("Thread-A 상태 : " + threadA.getSt.. 2024. 11. 12.