디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

통합 에러 핸들러와 이진 탐색 최적화

나르시갤로그로 이동합니다. 2025.11.26 22:04:19
조회 47 추천 0 댓글 0

제목: [System/Ada] POSIX errno 지옥에서 탈출하기: 통합 에러 핸들러와 이진 탐색 최적화

안녕하세요. 현재 Ada 언어로 고성능 비동기 I/O 라이브러리인 Clair를 개발하고 있습니다.

시스템 프로그래밍을 하거나 C 라이브러리를 래핑해 보신 분들은 공감하시겠지만, 에러 처리(Errno Handling)는 정말 끝없는 노가다의 연속입니다. 오늘은 이 과정을 획기적으로 줄인 경험을 공유하고자 합니다.

1. 고통의 시작: 함수마다 에러가 다르다?

처음에는 정석대로 구현했습니다. man 2 open, man 2 read를 일일이 찾아보며 각 시스템 콜이 리턴할 수 있는 에러 목록을 조사하고 switch/case 문을 작성했죠.

-- [기존 방식] 함수마다 case 문이 복붙됨...
procedure Open (...) is
begin
   res := c_open(...);
   if res < 0 then
      case errno is
         when EACCES => raise Permission_Denied;
         when ENOENT => raise Not_Found;
         when EISDIR => raise Is_A_Directory;
         -- ... open이 뱉는 에러 10개 나열 ...
      end case;
   end if;
end Open;

procedure Read (...) is
begin
   -- ...
   if res < 0 then
      case errno is
         when EACCES => raise Permission_Denied; -- 또 나옴
         when EAGAIN => raise Resource_Busy;     -- 새로운 에러 등장
         when EBADF  => raise Bad_Descriptor;
         -- ... read가 뱉는 에러 5개 나열 ...
      end case;
   end if;
end Read;

함수가 10개면 괜찮지만, socket, bind, listen, epoll_ctl... 함수가 늘어날수록 코드는 중복된 case 문으로 도배되고, 유지보수는 지옥이 되었습니다.


2. 발상의 전환: Superset 전략

문득 이런 생각이 들더군요. 굳이 open이 리턴하는 에러만 골라서 검사해야 하나? 어차피 다 errno 정수값 아닌가?

함수별로 에러를 필터링하지 말고, POSIX 표준이 정의한 모든 에러(Superset)를 처리하는 단 하나의 통합 핸들러를 만들면 어떨까?

  • open EAGAIN을 뱉을 일이 없다고 해도, 핸들러에 EAGAIN 처리 로직이 있는 건 문제 되지 않는다.
  • 어차피 errno가 발생했다면, 그건 우리가 아는 에러 중 하나일 것이다.

3. 해결책: 정렬된 테이블 + 이진 탐색 (Lookup Table)

if-else switch-case를 수백 줄 나열하는 대신, 데이터 기반(Data-driven)으로 접근했습니다.

  1. 데이터 구조: (Errno, Exception_ID) 쌍을 저장하는 배열을 만듭니다.
  2. 정렬: 프로그램 시작 시 Errno 값을 기준으로 정렬합니다. (OS마다 번호가 다를 수 있으므로)
  3. 검색: 런타임에는 이진 탐색(Binary Search)으로 예외를 찾습니다.
-- [Clair.Error 패키지 내부]

-- 1. 모든 POSIX 에러를 때려 넣은 테이블
Error_Table : array (1 .. MAX_ERRORS) of Error_Entry :=
  ((EACCES, Permission_Denied'Identity),
   (EAGAIN, Try_Again'Identity),
   (EBADF,  Bad_File_Descriptor'Identity),
   -- ... (약 30~50개 표준 에러) ...
   (ENOMEM, Memory_Error'Identity));

-- 2. 통합 핸들러 (이진 탐색 O(log N))
procedure Raise_From_Errno (Errno : int; Message : String) is
   -- Binary Search 로직 ...
   -- 찾으면 해당 예외 발생 (Raise)
   -- 못 찾으면 Unknown Error 발생
end Raise_From_Errno;

4. 결과: 매뉴얼과의 이별

이제 시스템 콜 래퍼 함수들은 이렇게 변했습니다.

procedure Open (...) is
begin
   if c_open(...) < 0 then
      -- [끝!] 어떤 에러인지는 핸들러가 알아서 찾아서 던짐
      Clair.Error.Raise_From_Errno(errno, "Open failed on " & Path);
   end if;
end Open;

이득:

  1. 생산성 폭발: 더 이상 man 페이지를 뒤지며 이 함수가 무슨 에러를 뱉지? 고민할 필요가 없습니다. 그냥 넘기면 됩니다.
  2. 제로 할당 (Zero Allocation): 해시 맵(Hash Map) 대신 정적 배열을 썼기 때문에 힙 메모리 할당이 전혀 없습니다.
  3. 성능: 50개의 에러가 있어도 이진 탐색은 최대 6번 비교면 끝납니다. 에러 상황에서의 오버헤드로는 완벽합니다.
  4. 캐시 효율: 배열이라 메모리에 연속적으로 배치되어 CPU 캐시 히트율이 높습니다.

결론: 시스템 프로그래밍에서 변하지 않는 정적 데이터를 다룰 때는, 무거운 맵(Map) 자료구조보다 정렬된 배열(Sorted Array)이 깡패라는 걸 다시 한번 느꼈습니다.

혹시 비슷한 고민을 하시는 분들이 있다면 Superset 전략을 강력 추천합니다.

C 바인딩을 위해 Ada 예외를 C int 값으로 변환하는 핸들러도 마찬가지의 알고리즘으로 작성할 수 있습니다.

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 뛰어난 운동 신경으로 남자와 싸워도 이길 것 같은 여자 스타는? 운영자 25/11/24 - -
AD 따뜻한 겨울나기! 방한용품 SALE 운영자 25/11/27 - -
2905142 백엔드 퇴사하고 국비 클라우드 인프라 과정 어떤가요 [3] 프갤러(115.23) 11.27 41 0
2905141 하긴 지금이야 러이브러리 차원에서 많이들 크로스 os 지원하는거지 [1] 프갤러(110.8) 11.27 32 0
2905140 그러니까 이 자바 이식성도 개소린게 [5] 프갤러(110.8) 11.27 49 0
2905139 님들 기획서 쓸때 프로그램 머씀? 뉴진파갤로그로 이동합니다. 11.27 16 0
2905138 님들 기획서 쓸때 프로그램 머씀? [2] 뉴진파갤로그로 이동합니다. 11.27 25 0
2905137 틀렸다. 힙 메모리 64mb로 제한해도 여전히 280mib처먹는다. [2] 프갤러(110.8) 11.27 37 0
2905135 진정하자. jvm도 메모리 할당 옵션이 있겠지 [3] 프갤러(110.8) 11.27 44 0
2905134 처 돌았네 자프링 헬로월드만 띄워도 램 300mib 처먹는다. [2] 프갤러(110.8) 11.27 46 0
2905130 졸렬두 할건 하구 자우징좌우지징 ♥멘헤라냥덩♥갤로그로 이동합니다. 11.27 37 0
2905129 일단 러스트가 자바보다 뛰어난건 그냥 사실이고 [2] 프갤러(110.8) 11.27 42 0
2905127 슬슬 자바 조끔 해보고 있는데 [6] 프갤러(110.8) 11.27 54 0
2905126 #나님#왤케#뭔가뭔가임#특별 ♥멘헤라냥덩♥갤로그로 이동합니다. 11.27 32 0
2905123 ❤✨☀⭐⚡☘⛩☃나님 시작합니당☃⛩☘⚡⭐☀✨❤ ♥멘헤라냥덩♥갤로그로 이동합니다. 11.27 32 0
2905120 강박을 줄이는 음식 발명도둑잡기(39.7) 11.27 19 0
2905119 신입생들을 위한 대학 면접 합격 가이드(따뜻한 조언)!/ 프갤러(121.142) 11.27 37 1
2905118 ASCII아트나 레고와 강박증 관계 발명도둑잡기(39.7) 11.27 18 0
2905117 ‘짝퉁’도 내 손으로…‘DIY 조립키트’ 판매 일당 검거 발명도둑잡기(39.7) 11.27 21 0
2905115 점심 간식 저녁 발명도둑잡기(39.7) 11.27 17 0
2905114 아 ㅈ같은부서 ㅈ같은 사무실로 이동하는데 ㅇㅇ(211.234) 11.27 25 0
2905113 장경태, 성추행 혐의 피소…장 의원 “허위 무고, 강력 대응” [1] 발명도둑잡기(39.7) 11.27 34 0
2905111 중국 보따리상이나 해볼까 [1] 프갤러(49.165) 11.27 31 0
2905110 애널은 이상하게 저녁먹기 싫넹 ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.27 15 0
2905109 [대한민국] 좌파가 계속 거짓말을 하는 이유 ㅇㅇ(121.172) 11.27 14 0
2905108 나님은 언제나 늘 해답을 찾아내지 [3] ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.27 43 0
2905104 [애니뉴스] flex 배너 광고 무료 이용방법 1급시크릿공문(121.172) 11.27 14 0
2905103 오늘 여기 참석함. [2] Move갤로그로 이동합니다. 11.27 83 0
2905102 @.@ 재현갤로그로 이동합니다. 11.27 23 0
2905101 오드로이드 중간평가 [5] 에이도비갤로그로 이동합니다. 11.27 97 1
2905100 [연구주제] 저출산의 배경 1급시크릿공문(121.172) 11.27 18 0
2905099 나님 끙야즁❤+ ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.27 38 0
2905097 [대한민국] 저출산과 저출생과 출생아 단어 차이 [1] 1급시크릿공문(121.172) 11.27 27 1
2905095 냥덩이 발도잡 감성지능 0인듯 ㅇㅇ(182.231) 11.27 30 2
2905094 ❤✨☀⭐⚡☘⛩☃나님 시작합니당☃⛩☘⚡⭐☀✨❤ ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.27 31 0
2905093 부동산 아저씨가 집 보러 안 오시네요. [1] 넥도리아(220.74) 11.27 27 0
2905091 식빵이랑 커피 샀어 넥도리아(223.38) 11.27 28 0
2905090 [한국전파진흥협회] 2026년 상반기 클라우드 아키텍처 전문가 양성과정 [1] 프갤러(14.32) 11.27 53 0
2905089 미국영어보단 영국영어발음이 쉽고 멋지지않냐? [5] 헬마스터갤로그로 이동합니다. 11.27 69 0
2905088 나님 왤케 특별하실깡? [1] ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.27 51 0
2905082 12개 핫딜 사이트 북마크해놨던 과거의 나 ㅂㅅ 프갤러(117.111) 11.27 61 0
2905081 이재명이 잘하고있긴함 타이밍뒷.통수한방(1.213) 11.27 52 1
2905080 [대한민국] 차이나인에 대한 답글 1급시크릿공문(121.172) 11.27 24 0
2905079 ❤✨☀⭐⚡☘⛩☃나님 시작합니당☃⛩☘⚡⭐☀✨❤ ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.27 40 0
2905078 [대한민국] FBI 부정선거 조사 착수와 메인 뉴스에 나오는 법조인들 1급시크릿공문(121.172) 11.27 32 0
2905077 이태원모욕죄로 벌금 100만원이면 싸게쳤다 vs 억울하다 [8] ㅇㅇ(203.232) 11.27 64 0
2905076 회사에 다른오퍼를 빌미로 연봉협상 시도하는거 [13] 프갤러(112.219) 11.27 88 0
2905075 33세 남성 벌레인생 나같은 성욕부시레기도 결혼 가능하려나 ㅇㅇ(203.232) 11.27 68 0
2905073 이재명 대통령님 전자정부프레임워크를 러스트 기반으로 이전해주십 [4] 프갤러(110.8) 11.27 67 0
2905072 [대한민국] 이재명 때문에- [1] 1급시크릿공문(121.172) 11.27 46 1
2905070 개발자 새끼들이 씹덕 애니 프사 하는 이유는? [2] ㅇㅇ(211.235) 11.27 53 0
2905069 졸라 피곤하네..ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 11.27 26 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2