디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.07.26 20:57:19
조회 113 추천 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/11/24 - -
AD 따뜻한 겨울나기! 방한용품 SALE 운영자 25/11/27 - -
2877452 졸려씨박 프갤러(223.38) 08.02 131 0
2877451 요즘 컴퓨터 근황 입니다. [5] 넥도리아(220.74) 08.02 202 0
2877450 보석놈 러스트 코드가 보고 싶나? 프갤러(14.58) 08.02 119 0
2877448 디씨가 나한테 끼친 영향 슈퍼막코더(126.194) 08.02 132 0
2877444 모든게 원망스럽다 ㅇㅇ(118.235) 08.02 130 0
2877443 모든 것에 잘못에는 개개인의 책임이 크다. 넥도리아(220.74) 08.02 137 0
2877439 롤 대회 미니언은 방어력 더 약함 ㅇㅅㅇ?? 왤캐 잘죽음 ㅇㅇ(223.39) 08.02 120 0
2877438 ■노베이스가 게시판 만드려면 기간 대충 얼마나 잡아야할까요? [1] ㅇㅇ갤로그로 이동합니다. 08.02 163 0
2877430 ■취업할려면 스프링과 스프링부트 중 뭘 파야하나요? [3] ㅇㅇ갤로그로 이동합니다. 08.02 298 0
2877429 오늘 해킹 공부하면서 배운 것 [2] 루도그담당(58.239) 08.02 165 0
2877425 겜만들어서 세금 3300낸다는대 [2] 프갤러(211.235) 08.02 154 0
2877421 넥도리아 안철수 댓글에 달았습니다. 뒷골목 간담회 넥도리아(220.74) 08.02 128 0
2877419 개발자도 이제는 인싸 직업임 [2] 어린이노무현갤로그로 이동합니다. 08.02 194 0
2877418 aa 프갤러(113.59) 08.02 120 0
2877417 ㅇㅇ 프갤러(113.59) 08.02 155 0
2877414 내가 느끼는게 일단 지금 잘 돌아가는거 사실 구조 바꾸고 리팩토링해야하데 ㅆㅇㅆ(124.216) 08.02 131 0
2877413 가끔 보면 나는 프로그래밍에 재능이 없는거 같아 [4] ㅆㅇㅆ(124.216) 08.02 204 0
2877412 사담콘 다녀와씀 [6] 어린이노무현갤로그로 이동합니다. 08.02 170 0
2877411 내가 만든 mcp 나름 성능좋은거같은데 [2] ㅆㅇㅆ찡갤로그로 이동합니다. 08.02 141 0
2877408 월급이 3번 나오는 삶… [3] 어린이노무현갤로그로 이동합니다. 08.02 151 0
2877407 제품번호를 277 이 아닌 원래 227이여야 하는데, [1] 넥도리아(220.74) 08.02 148 0
2877405 한컴 회장님 저 이 옵션에 접근했어요... 넥도리아(220.74) 08.02 140 0
2877403 나는 스스로 쓰레기인거 인증하고 남한테 말할 자신있음 [1] 뒷통수한방(1.213) 08.02 157 0
2877394 cmd에서 빌드실행 하는데 왜 이러나요? [3] 프갤러(218.149) 08.02 149 0
2877382 지금 토스나 뱅크샐러드 들어가보면 [3] 아스카영원히사랑해갤로그로 이동합니다. 08.02 282 0
2877381 취업하려면 토익,컴활1급 도움되나요?? ㅇㅇ(14.52) 08.02 142 0
2877380 마인드 컨트롤.. 프갤러(222.234) 08.02 104 0
2877378 클라이언트 절대다수는 코드 수준을 평가할 수 없다 [3] ㅆㅇㅆ(124.216) 08.02 184 0
2877377 포인터 = 사실 정수형 담는 변수임 [5] 루도그담당(58.239) 08.02 197 0
2877376 근데 포인터 너무 어려워서 겁쟁이 런한 나같은 개발자 없냐? [2] ㅆㅇㅆ(124.216) 08.02 164 0
2877375 포인터 씨발년아 [3] 프갤러(222.234) 08.02 206 0
2877374 코딩 처음시작 조언좀 [2] 프갤러(114.199) 08.02 182 0
2877373 프리도 실력천차만별임. 프리코드 받아보면 [8] ㅆㅇㅆ(124.216) 08.02 227 0
2877370 프리 할 정도면 존나 잘해야 되지 않냐 [2] ㅇㅇ갤로그로 이동합니다. 08.02 177 0
2877369 굉장히 접고 습합니다 [1] 개멍청한유라갤로그로 이동합니다. 08.02 137 0
2877365 프리랜서 이력서 가짜로 쓰는 애들은 뭐냐 [3] ㅇㅇ갤로그로 이동합니다. 08.02 219 0
2877363 레드팀 문서 같은거 보면서 느낀건데 [2] 루도그담당(58.239) 08.02 128 0
2877362 나 약쟁이가 되어버렸음 [4] 공기역학갤로그로 이동합니다. 08.02 190 0
2877361 나 안쫒겨났다. 무지성 도배하기 싫어서 떡밥을 기다리는 중이지 프갤러(14.58) 08.02 114 0
2877358 김건희씨에 대한 빤스맨 윤수괴의 집착이 대단하지않냐? [3] 헬마스터갤로그로 이동합니다. 08.02 156 0
2877357 개인적으로 강의는 프로그램 만드는 강의 아니면 굳이 싶다. ㅆㅇㅆ(124.216) 08.02 129 0
2877356 회사에서 llm 지원해주냐..? [3] 프갤러(58.122) 08.02 162 1
2877354 근데 어차피 지피티 쓰면서 예제 짜달라고하면서 문서 읽는게 [2] ㅆㅇㅆ(124.216) 08.02 171 0
2877351 솔직히 문서 좋은데 루도그담당(58.239) 08.02 139 0
2877350 리액트 문서 추천하자면 ㅆㅇㅆ(124.216) 08.02 168 0
2877349 C/C++ C# Java 이건 기본으로 공부해 놔라. [1] 프갤러(59.16) 08.02 212 0
2877348 갠적으로 내 생각엔 강의 듣는것보다 문서 따라가는게 더 나은거같은데 [2] ㅆㅇㅆ(124.216) 08.02 181 0
2877346 해킹 공부 시작할게요 [2] 루도그담당(58.239) 08.02 150 0
2877345 리액트(코알누, 인프런) [2] 프갤러(222.101) 08.02 1788 0
2877343 멋사 백엔드 부트캠프 ㄱㅊ? 프갤러(218.149) 08.02 262 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2