디시인사이드 갤러리

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

갤러리 본문 영역

Ada의 심각한 단점: 타입 이름을 네임스페이스로 사용할 수 없다

나르시갤로그로 이동합니다. 2025.07.26 20:57:19
조회 74 추천 0 댓글 1

Ada를 쓰기로 마음먹었다면, 언젠가는 부딪혀야 할 가장 큰 장벽이자 가장 큰 짜증을 유발하는 문제가 있습니다.

Java나 C# 개발자라면, 같은 패키지(네임스페이스) 안에서 클래스들이 서로 상속받아 자연스러운 타입 계층을 만드는 것에 익숙합니다.

// Java/C# 스타일 의사 코드
// 'widget' 네임스페이스 안에서 타입들이 상속 관계를 형성
package com.example.widget;

public class Widget { /*...*/ }
public class Window extends Widget { /*...*/ }
public class Button extends Widget { /*...*/ }
public class ToggleButton extends Button { /*...*/ }
public class CheckedButton extends Button { /*...*/ }

Widget이라는 베이스 타입과 이를 상속받은 Window 타입이 widget 이라는 같은 이름 공간에 공존하는, 지극히 상식적인 구조입니다. Ada에서는 이처럼 직관적인 타입 계층을 이름으로 표현하는 데 근본적인 한계가 있습니다.

계층 구조 비교: 직관적인 Java/C# vs 어색한 Ada

GUI 툴킷을 만든다고 가정하고 두 언어의 계층 구조를 다이어그램으로 비교해 보겠습니다. ToggleButton CheckedButton Button을, Button Window Widget을 상속받는 관계입니다.

Java / C#의 방식: 상속 기반의 타입 계층

하나의 패키지(네임스페이스) 안에서, 클래스들이 상속을 통해 직관적인 타입 계층을 형성합니다. 타입의 이름이 곧 개념을 나타냅니다.

   Widget
   /     \
Window  Button
         /   \
        /     \
       /       \
ToggleButton  CheckedButton

Ada의 방식: 모듈 중심의 계층

Ada는 모든 것을 별개의 패키지(모듈)로 분리해야 합니다. Window Widget을 상속받는 개념을 표현하기 위해, Widget.Window라는 별도의 자식 패키지를 만들어야 합니다.

     Widget
       |
     Object
     /   \
    /     \
Window   Button
   |       |
Object   Object
         /    \
        /      \
ToggleButton  CheckedButton
     |              |
   Object         Object
-- Object가 뒤따를 수 밖에 없는 변수 선언 예시
-- 참고로 with, use를 사용하면 일부 네임 스페이스를 생략할 수 있습니다.
my_widget        : access Widget.Object;
my_window        : access Widget.Window.Object;
my_button        : access Widget.Button.Object;
my_toggle_button : access Widget.Button.ToggleButton.Object;

Widget.Window면 될 것을 Widget.Window.Object라고 써야 하는 이 모습은, 솔직히 말해 끔찍한 혼종처럼 보입니다.

결론: 울며 겨자 먹기로 Ada를 쓰는 이유

Ada의 이런 고집스러운 설계 철학은 정말 마음에 들지 않습니다. 코드는 장황해지고, 다른 언어의 직관적인 객체 지향 패턴을 포기해야 하는 대가를 치러야 합니다.

하지만 아이러니하게도, 저는 이 언어를 버릴 수 없습니다. 안전성/신뢰성을 보장해주는 선택지가 사실상 Ada가 유일하기 때문입니다. 컴파일 시점에는 컴파일러의 엄격한 검사를 하고 실행 시점에는 언어 자체에 내장된 강력한 런타임 검사가 실시간으로 오류를 검사하기 때문에, 저는 이 모든 불편함을 감수하는 것입니다.

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 시구, 시축 했다가 이미지가 더 나빠진 스타는? 운영자 25/08/11 - -
AD 가전디지털, 휴대폰 액세서리 SALE 운영자 25/08/08 - -
2881410 PwC 삼일회계법인 인턴 하는것에 대해 프갤러(117.111) 08.14 47 0
2881409 그 약이라는게 그렇게 끊기가 힘듬?? 계속 생각나?? [1] ㅇㅇ(223.39) 08.14 87 0
2881408 개발이 근데 그렇게 힘듬? [3] 프갤러(106.101) 08.14 109 0
2881407 시골 터미널 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 08.14 64 0
2881406 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.14 41 0
2881405 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 08.14 50 0
2881404 AI 가 답해주는 포럼 웹사이트 만듬 프갤러(211.55) 08.14 58 0
2881402 게임 1인 개발 성공하니까 단나더 생각나네 ㅇㅇ(125.182) 08.14 103 1
2881400 게임개발하고싶어서 컴공 진학 희망하는 학생인데 진짜 궁금한거 있음. [15] 프갤러(58.78) 08.14 176 0
2881399 패턴 템플릿을 만들어두고 세부 구현 주의사항을 제네릭하게 만들어서 [1] ㅆㅇㅆ(124.216) 08.14 74 0
2881397 시스템 명세 짜고 설명붙이고 구현하고 ㅆㅇㅆ(124.216) 08.14 53 0
2881396 하루 평균 클래스 40개의 명세, 함수, 메서드 약 200개여개 명세 [1] ㅆㅇㅆ(124.216) 08.14 86 0
2881381 근데 개발자 취업시장 안좋은건 [22] 프갤러(118.235) 08.14 375 0
2881370 참 공부를 하면서 느낀다 루도그담당(58.239) 08.14 53 0
2881369 프갤에 글이 없네 ㅋㅋ [2] 프갤러(121.139) 08.14 77 1
2881368 냉면 먹어야겠다 ㄱ ㅐ ㅆ ㅣ빨썌끼들아!!!!!! 프갤러(121.139) 08.14 40 0
2881366 님이 사용 중인 어플들 러스트가 아니라 C/C++로 만든거다 나르시갤로그로 이동합니다. 08.14 63 0
2881365 납품 준비 하나 끝. 아 존나 힘들다 ㅆㅇㅆ(124.216) 08.14 37 0
2881364 식당 술값이 폭리면? 주식 수익은 부당 이익이냐? 나르시갤로그로 이동합니다. 08.14 44 0
2881363 식당 술값이 폭리면? 개발비도 폭리냐? 나르시갤로그로 이동합니다. 08.14 38 0
2881360 GC없는, (메모리 등) 안전 대세 언어: Ada 나르시갤로그로 이동합니다. 08.14 66 0
2881359 러스트가 확실히 대세가 아닌 이유 나르시갤로그로 이동합니다. 08.14 69 0
2881351 개인적으로 개발 세부 구현사항은 문서화 안하지만 전반적으로 ㅆㅇㅆ(124.216) 08.14 61 0
2881348 그리고 기본적으로 마소 예제는 나름대로 기술 분석 해두는게 좋더라 [2] ㅆㅇㅆ(124.216) 08.14 79 0
2881347 뇌과학적으로 고소득층 사람들은 물건보다 '이것'에 집착합니다 발명도둑잡기갤로그로 이동합니다. 08.14 42 0
2881346 아인슈타인의 ‘그 논문’ 50년간 묻혔다가 과학계 레전드로 역주행 발명도둑잡기갤로그로 이동합니다. 08.14 50 0
2881345 나는 대부분 내가 만들어보거나 해본 것들 어지간하면 적어둠 [8] ㅆㅇㅆ(124.216) 08.14 98 0
2881344 나는 크롤링 전문이 아니라서, 그냥 기초 원리만 아는거. [3] ㅆㅇㅆ(124.216) 08.14 81 0
2881343 아씨발나스닥왜자꾸올라개새끼야!!!!!!! [3] 아스카영원히사랑해갤로그로 이동합니다. 08.14 79 0
2881342 웹 크롤링 뷰티풀 스프 사용하는 방법 [2] ㅆㅇㅆ(124.216) 08.14 84 0
2881341 나도 어제 좆개판으로 크롤러 짯는데 [2] 루도그담당(58.239) 08.14 67 0
2881340 R 스크립트 짜면서 느끼는데 유독 파이썬 R은 GPT가 잘짜 ㅆㅇㅆ(124.216) 08.14 54 0
2881338 개발 항상 하면 느끼지만 가장 큰 적은 '돌아가는데 굳이..' 이거임 [2] ㅆㅇㅆ(124.216) 08.13 82 0
2881337 그 약이라는게 그렇게 끊기가 힘듬?? 계속 생각나?? [7] ㅇㅇ(223.39) 08.13 99 0
2881336 파이썬 질문있습니다 [3] 프갤러(211.105) 08.13 76 0
2881335 ㅆㅇㅆ님 이 글에 대해 의견좀 [1] 발명도둑잡기갤로그로 이동합니다. 08.13 71 0
2881331 내가 ai 안쓰는 이유 프갤러(121.139) 08.13 63 0
2881330 금융 로직의 문제는 뭐냐면 [1] 밀우갤로그로 이동합니다. 08.13 70 0
2881327 프갤러들 제국주의자 되는 과정 발명도둑잡기갤로그로 이동합니다. 08.13 43 0
2881326 이직했는데 존나어렵다 [1] 프갤러(220.70) 08.13 93 0
2881324 코테 문제들 어질어질하노 [1] 프갤러(220.85) 08.13 252 0
2881321 ㅇㅣ거 뭐냐 ㅇㅇ(211.105) 08.13 40 0
2881317 요즘 식당, 술집들 보면 술로 너무 폭리 취함 [15] 야옹아저씨갤로그로 이동합니다. 08.13 207 5
2881315 챗티씨에 코드 맡기고 나는 누워잇는중 [1] 헬마스터갤로그로 이동합니다. 08.13 58 0
2881312 도대체 영화관리를 어떻게 하길래 벌써 XX티비에 영화가 다떴지?? [6] ㅇㅇ(223.39) 08.13 83 0
2881309 잡코리아에서 AI 공모전으로 채용까지 하네요 프갤러(114.203) 08.13 41 0
2881302 퍼플렉시티랑 지피티 듀오로 가야하나 프갤러(61.79) 08.13 47 0
2881300 빌게이츠 이새낀 좇센 왜오는거?? 미국에선 총기맞을까봐 오는거?? 타이밍뒷통수한방(1.213) 08.13 47 0
2881297 카페 와이파이를 쓰면 안 되는 이유 발명도둑잡기갤로그로 이동합니다. 08.13 40 0
2881294 리눅스 예전에는 좋았던거 같은데 점점 성능이 내려가는느낌임 타이밍뒷통수한방(1.213) 08.13 49 0
뉴스 ‘사당귀’ 안유성 명장, 일머리 없는 1호 제자에 한숨 “정신 똑바로 차려야” 디시트렌드 08.15
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2