« Previous : 1 : ... 210 : 211 : 212 : 213 : 214 : 215 : 216 : 217 : 218 : ... 221 : Next »

C++의 멤버 포인터

C++에는 pointer-to-member이라는 아주 기괴한 개념이 있다.

마치 일반 변수를 포인터로 가리키고 전역 함수를 가리키는 포인터가 있는 것처럼,
이 포인터는 포인터이긴 한데, 변수 포인터라면 특정 클래스(=구조체)에 대한 오프셋에 매여 있다고 볼 수 있으며, 함수 포인터라면 특정 클래스의 멤버 함수로 소속된 함수만 가리킨다는 특수성을 지닌다.

그래서 한 클래스 안에 프로토타입이 일치하는(리턴값, 인자의 개수와 type들) 여러 멤버 함수들이 있으면 그것들 중 하나를 가리켜서 특정한 한 함수를 if나 switch..case 없이 계속 가리키면서 호출하게 할 수 있다. 이걸 이용해서 얼추 다형성까지 구현할 수 있다는 것이다.

또한 한 클래스 안에 동일한 타입을 지닌 여러 멤버에 대해서 일괄적으로 초기화를 해 줘야 할 때, 멤버 함수를 가리키는 포인터를 써서 이 일을 아주 generic하고 수월하게 할 수 있다.
MFC에서 message map도 매크로를 파헤쳐 보면 응당 pointer-to-member를 써서 구현되어 있다.

C++에서 추가된 클래스 멤버 함수는 굉장히 묘한 존재이다.
사실, C에서도 구조체에다가 함수 포인터를 갖다 둠으로써 obj.func() ptr->func() 같은 문법 자체가 불가능한 것은 아니다. 그런데 이 경우 ()를 생략함으로써 해당 함수의 주소를 간단하게 얻을 수 있은 반면, C++ 멤버 함수는 그렇게 할 수 없다. 그 멤버 함수는 그 클래스의 '인스턴스'에 소속되어 있으면서 그 클래스의 크기에 영향을 주는 존재가 아니기 때문이다. scope이라는 개념이 존재하고 this 값을 기본으로 받는 것만 빼면 위상은 오히려 전역 함수에 더 가깝다.

아예 개체와 함께 함수 호출 연산자 ()를 줘서 확실하게 호출을 하든가, 아니면 &Class::Function과 같은 형태로 pointer-to-member 값을 얻어 와서 자기 타입에 맞는 pointer-to-member에다가 그 주소를 대입만 수 있다. 일반 함수 포인터와는 달리 이렇게 얻어진 값은 곧바로 함수 호출을 할 수 없으며, 반드시 그 클래스에 해당하는 개체가 있어야 한다. 개체 뒤에다 .* 이라든가 ->* 연산자를 붙이면 되는데, 이때 .*나 ->*은 *까지 붙어서 완전히 한 연산자 토큰이기 때문에 둘 사이에 공백이 들어갈 수 없다.

또 하나 주의해야 하는 것은 C++의 연산자 우선 순위이다. (obj->*pfnFunc)(함수인자)처럼 함수 인자 앞에는 반드시 괄호가 들어가야 한다. 또한 우리 클래스 안이라고 해도 ->*나 .* 앞에서는 this를 생략할 수 없으며 반드시 붙여야 한다. 여러 모로 문법부터가 기괴하다는 것이다.
이 pointer-to-member의 타입은 공식적으로 void (Class::*)(함수인자) 이라 불린다. 이때, ::와 *은 서로 독립된 토큰이다.

그런데 pointer-to-member하고 가상 함수가 서로 만나면 이거 정말 골치아픈 문제가 발생하고 만다. 둘 다 다형성을 위해 존재하는 기능이며, 둘 다 구현하기 위해서 컴파일러가 프로그래머가 모르게 암시적으로 몰래 하는 일이 상당히 많은 기능들이다. 하지만, 결론부터 말하자면 이 두 기능은 서로 연동해서 사용할 수 없다. 이게 무슨 말인지를 지금부터 설명하겠다.

A라는 클래스가 있고 f라는 가상 함수를 정의했다. 그 후 A로부터 상속 받은 B라는 클래스는 f라는 가상 함수를 또 오버라이드했다.

그 후 A의 포인터 pf에 어떤 값이 들어왔다. 얘가 가리키는 값이 실제로 A인지, 아니면 A의 파생인 B인지는 알 수 없다.
이때,

if( &pf->f == &A::f ) puts("pf 개체는 A 타입");
else if( &pf->f == &B::f ) puts("pf 개체는 B 타입");

와 같은 형태로, 이 개체에 소속된 가상 함수의 주소를 판단함으로써 그 개체의 원래 타입을 판별할 수 있을까? 마치 C 언어 구조체의 멤버로 들어있는 함수 포인터를 비교하듯이, 가상 함수와 pointer-to-member 주소를 이런 식으로 연계할 수 있을까?

그럴 수가 없다는 뜻이다.
일단 클래스 멤버 함수의 pointer-to-member 주소를 되돌리는 방법 자체가 pf 같은 동적 바인딩을 허락하지 않는다.

그리고 더욱 나쁜 사실은, &A::f와 &B::f의 값 자체가 실제로 확인해 보면 동일하다는 것이다!
어떤 A 타입의 포인터가 있는데, pointer-to-member를 이용하여 어떨 때는 강제로 A::f를 호출하고, 어떨 때는 일부러 B::f를 호출하여 기반 클래스와 파생 클래스를 구분하는 것 자체가 불가능하다. 한 클래스 안에서 프로토타입이 같은 여러 수평적 함수들을 구분할 수는 있으나, 부모와 파생 클래스 사이의 수직적 관계가 존재하는 가상 함수는 전혀 구분할 수 없다.

사실은 이것이 원래 의도했던 C++ pointer-to-member의 동작 스펙이기도 하다. 가상 함수와 일반 함수를 구분하지 않고 그 위 계층에서 동작하게끔 말이다.

C++에서 가상 함수가 어떻게 구현되는지 대충 아는 분들도 있겠지만,
가상 함수가 생기면 사실 해당 클래스에 가상 함수들의 포인터가 당장 쭉 추가되는 게 아니라, 해당 클래스를 나타내는 가상 함수 포인터 배열이 하나 생기고, 이를 가리키는 '포인터'가 하나 추가된다. 즉,

ptr->nonVirtual(...) ==> globalFunc(this, ...) 가 일반 함수라면, 가상 함수는

ptr->virtualFunc(...) ==> ptr->vtbl->pfn[n](this, ...) 처럼 전개된다는 뜻.

그런데 pointer-to-member 함수는 매 타입에 대해서 vtbl의 값을 저장하고 있는 게 아니다.

virtualFunc_stub(this, ...)
{
        return this->vtbl->pfn[n](this, ...)
}

가상 함수의 address란 바로, ptr에 대해 가상 함수 테이블을 뒤져서 실제 가상 함수를 호출해 주는 "껍데기 함수"의 주소로 정적으로 고정되는 것이다! &A::f이든 &B::f이든 가리키는 주소는 바로 저기가 된다는 것이다. 이 일을 컴파일러가 몰래 슬쩍 해 준다.

그렇기 때문에 pointer-to-member 함수는 함수의 프로토타입만 일치한다면 일반이든 virtual이든 전혀 구분 없이 함수를 가리킬 수 있으며,
(pp->*pfn)(); 와 같은 문장은

004010C8 8B CE            mov         ecx,esi
004010CA FF D3            call        ebx

가리키는 대상이 virtual이든 아니든 관계없이 위와 같은 두 명령으로 간단히 번역된다. 실제 가상 함수 호출은 저 껍데기의 내부에서 이루어지니까.
pp->SayA(); 처럼 대놓고 가상 함수를 호출할 때는

004010CC 8B 16            mov         edx,dword ptr [esi]
004010CE 8B 02            mov         eax,dword ptr [edx]
004010D0 8B CE            mov         ecx,esi
004010D2 FF D0            call        eax 

테이블을 참조하는 오버헤드가 해당 코드에서 바로 이뤄지는 것과 좋은 대조를 이루는 셈이다.

따라서 이 함수가 어느 가상 함수를 가리키는지는, 문서화되지 않은 컴파일러 꽁수라든가 어셈블러 같은 지저분한 방법을 동원하지 않고서는 알 수 없다는 것이 결론이 되겠다. pointer-to-member의 동작은 가상 함수의 영향을 받지 않는다.

그런데, 가상 함수는 그나마 이런 식으로 극복해서 일관성을 얻었다지만, 가상 상속, 다중 상속 같은 극악한 C++만의 기능과 마주치면(요즘 언어들은 채택도 안 하고 있는), pointer-to-member 구현의 복잡도는 그야말로 GG 치는 경지에 다다른다.

결국 자기가 가리키는 함수뿐만 아니라 기반 클래스처럼 그 클래스와 관련된 다른 정보도 들어가야 하기 때문에, machine word(통상 4 또는 8바이트) 단위 크기보다 크기가 더 커지게 된다! this 포인터도 막 왔다갔다 해야 하므로.
그런 클래스에서 멤버 포인터가 구체적으로 어떻게 구현되며 잉여 데이터가 어떻게 활용되는지는 본인도 잘 모르겠다.. -_-;; () [] * 가 막 뒤섞인 복잡한 타입을 바로 읽고 쓰는 것만큼이나 도저히 이해를...;;;

더구나, forward 선언만 해 놓은 클래스인 경우, 이 클래스의 pointer-to-member는 4바이트 크기로만 잡아도 될지, 아니면 더 커야 할지를 알 수 없기 때문에 일단 최악의 경우를 가정하여 엄청 큰 사이즈가 잡힌다. 같은 포인터가 클래스 몸체의 선언 전과 후에 계산되는 크기가 달라진다는 뜻이다. (차라리 몸체가 없는 클래스의 멤버 포인터는 크기를 계산할 수 없다고 컴파일 에러를 내뱉는 게 더 낫겠다 -_-)

pointer-to-member는 꼭 필요는 하지만 이렇게 지저분한 존재가 되어 있다.
C++ 다음 표준에서는 이것도 뭔가 문법이 바뀔 거라는 식으로 들은 것 같기도 한데 잘 모르겠다. 가령, 이제 true, false도 꽤 오래 전에 정식 예약어로 추가가 됐는데, 0말고 NULL 포인터만을 가리키는 nil 같은 키워드도 type-safety를 위해서라면 좀 있어야 않나 싶다. 사실, C++이 오버로딩이 가능해지면서 타입 구분 강화 쪽으로 개선이 많이 되어 왔으며, explicit도 type-safety 보장을 위해서 추가된 키워드이다.

차라리 함수 포인터는 껍데기 함수 만들지 말고 그 함수 실체만 바로 가리키게 하면 영 안 되려나?? 지금처럼 해 놓은 이유가 있는지 잘 모르겠다.

Posted by 사무엘

2010/01/11 10:13 2010/01/11 10:13
Response
No Trackback , No Comment
RSS :
http://moogi.new21.org/tc/rss/response/88

- 클래스 이름과 파일 이름이 반드시 일치함이 보장되니, 소스 navigation이 은근히 편하다. 그리고 각 클래스 내부에 static void main 함수만 구현해 주면, 그 클래스만 용도를 테스트하는 프로그램을 간단히 짜고 그 유닛 단위로 실행이 가능하니 무척 편하다.
- 클래스에 각종 명칭의 선언과 정의가 따로 구분되어 있지 않으며, forward 선언이라든가, 온갖 dependency 따지기, 재컴파일 같은 지저분한 튜닝이 자바에는 필요하지 않다. 링크 에러라는 개념도 자바에는 존재하지 않는다. ㅋㅋ

- 모든 오브젝트들에 무조건 RTTI 정보가 들어있어서 type을 알 수 있다.
- 프로그램이 뻗으면 자동으로 함수 호출 스택 목록과 줄번호가 다 뜬다.

물론, 자바의 장점들 중 구조적인 것 말고 프로그램 실행과 관련된 편의는, 대부분 C/C++에 비해 성능을 상당히 희생하고서 얻어진 것임은 의심의 여지 없는 사실이다.

그래서 남이 짠 코드를 분석하고 들여다보고 유지보수 해야 할 때, 자바가 적응만 잘 돼 있으면 생산성이 상당히 높겠다는 점을 인정한다.
C/C++은 정말 변태스러운 튜닝과 자유도를 추구하는 대신, 그 코드가 여러 사람의 손을 거치면서 무질서도의 증가로 이어진다면 maintenance 측면에서 재앙이 될 수도 있다. 복잡한 암호 같은 C++ 코드에서 메모리 누수 하나 찾아 보시겠는가?

C/C++은 각 기계의 특성을 일일이 수용하고 존중해 준다는 점에서 이식성이 높다. 조건부 컴파일, 공용체, 포인터, 온갖 복잡한 컴파일러/링커 옵션 등등등...
하지만 자바나 C#급 언어는 그런 기계스러운 건 숨기고 포인터를 감싸고 특히 C/C++의 야생마스러운 면모를 적당히 제어하면서, 그 언어를 돌리는 플랫폼 자체를 이식성 있게 여럿 만듦으로써 이식성을 추구한다고 볼 수 있다. (자바 가상 머신, 닷넷 프레임워크 등) 즉, 언어의 근본 설계 철학과 용도가 다르다.

C++은 virtual로 지정된 놈만 가상 함수인 반면,
자바는 final이 지정되지 않은 다른 모든 놈이 기본으로 다 가상 함수이다.
가상 함수의 구현 비용이 만만찮은데, 이런 발상의 전환이 어떻게 이뤄졌는지 대단하다.

C/C++은 static이 무척 의미가 다양한 키워드인데 이는 자바도 어느 정도 이어받고 있다.
그런데 자바에만 있는 키워드로 final이 있는데, 얘가 일종의 const 역할도 하고 비가상함수임도 나타내니 문법이 무척 기발하다.

끝으로, 자바에서 아쉬운 것을 꼽자면,

- 조건부 컴파일이 안 되고, 특정 코드를 #if 0 ... #end if 이렇게 간편하게 막아 버리는 방법이 없다. -_-
- C 스타일 %d, %s로 간편하게 스트링을 포맷하는 방법이 없나? (디버그 로그 찍을 때 필요)

- 나는 자바로 범용적인 swap 함수를 어떻게 만드는지 아직도 전혀 모른다.
int a=3, b=5; swap(a,b); 이렇게 할 수가 없나? (자바에는 템플릿도, 매크로 함수도 없으며, int는 무조건 call by value로 전달됨)

Posted by 사무엘

2010/01/11 10:11 2010/01/11 10:11
,
Response
No Trackback , 2 Comments
RSS :
http://moogi.new21.org/tc/rss/response/87

비주얼 C++ 2010 외

※ auto keyword

지금까지 signed와 더불어서 C/C++의 주요 '유명무실' 사문 예약어이던 auto가 비주얼 C++ 2010에서는 완전히 새롭게 거듭날 예정이다.
auto는 그 변수에 초기화해주는 값이 나타내는 타입을 그대로 부여해 준다. 즉,

int a=5; (...) auto b=a; 라면 b는 int형이 되고
vector<int> arr; auto itor=arr.begin(); 이라면 itor의 타입은 vector<int>::iterator 가 된다.

그래서 말 그대로 auto는, 뒤에 나오는 대입값을 보고 자료형을 '자동'으로 알아서 판단하라는 의미가 된다.
이런 게 언제 C++ 표준으로 상정됐는지는 모르겠는데, 기능과 문법을 만들어 놓은 방식이 정말 기발하고 참신하기 그지없다.
이 키워드 하나가 수많은 번거로운 자료형 하드코딩 타이핑 내지 typedef들을 예방해 주리라 기대된다.

당연한 말이지만 auto 자체는 sizeof 같은 연산자의 피연산자가 될 수 없다. 또한 auto가 무슨 비주얼 베이직의 variant 타입처럼 아무 자료형이나 수시로 집어넣을 수 있는 타입을 의미하지는 않는다.
auto 형으로 선언되는 개체나 변수는, 마치 참조자를 선언할 때처럼 반드시 선언과 동시에 값 대입 내지 초기화가 되어야 할 것이다.
C++은 함수의 인자 개수와 인자의 자료형으로만 오버로딩을 구현하지, 함수의 리턴값으로 오버로딩을 구현하지는 않기 때문에 이런 기능을 모호성 없이 구현할 수 있는 것이다.

이 외에 다른 이상한 C++ 문법도 도입되고 C++ 라이브러리 쪽에도 무슨 변화가 있는데 그건 잘 모르겠고,
프로젝트 파일 포맷이 또 바뀔 예정이라고 한다.

※ 비주얼 C++ 프로젝트 파일

여기서 잠깐 역사 수업. 비주얼 C++ 프로젝트 파일의 역대 계보는 다음과 같다.

1기 *.vcp는 16비트 1.x 초창기 시절에 쓰였다.
2기 *.mdp는 32비트 통합 IDE인 Developer Studio 초창기 시절인 4.x에서 쓰였다. 세월이 세월이니만큼, 1기와 2기는 지금은 거의 찾을 수 없는 전설의 파일 포맷이 돼 있다.
3기 *.dsw와 *.dsp는 드디어 여러 프로젝트를 한데 묶어 관리하는 워크스페이스라는 개념이 도입된, 5와 6 두 버전에서 쓰였다.
그 후 닷넷급이라 할 수 있는 비주얼 C++ 200x에 가서는 4기인 *.sln, *.vcproj 방식이 등장했다. 비주얼 베이직/C++/C# 모든 언어들의 프로젝트 사이에 일관성이 생겼으며 워크스페이스라는 명칭이 솔루션으로 바뀌었다. 그리고 프로젝트 파일은 내부 구조가 XML 형태로 바뀌었다.

이제 프로젝트 파일의 내부 구조가 또 바뀔 일은 없을 거라고 생각했는데 2010에서는 vcxproj라고 또 바뀔 거라고 하니 이게 웬일?
설마 MS 오피스 2007처럼 또 zip 압축을 하는 건 아닌가 모르겠다.
하지만 개발툴의 프로젝트 파일은 소스 버전 관리의 편의성 같은 이유도 있고 해서 다들 plain text 방식으로 저장하지, 바이너리 방식을 쓰지는 않을 텐데 말이다.

더구나 개발툴의 버전이 바뀔 때마다 각종 컴파일러 옵션들은 시시때때로 추가되거나 삭제, deprecate되기도 하기 때문에, 이런 프로젝트 파일들은 유연성, 하위 호환성, 확장성을 최대한 유지하는 게 짱이다. 즉 plain text가 정답이라는 뜻이다.

경험상 비주얼 C++ 2005하고 2008은 프로젝트 파일 포맷이 거의 차이가 없다.
sln과 vcproj 파일 앞줄에 있는 버전 번호만 1 줄여 주면, 2008로 만든 프로젝트도 2005에서 아무 문제 없이 바로 읽어들일 수 있다.

※ 비주얼 C++ 6.0이 나온 지 좀 있으면 벌써 12주년

얘기가 여기까지 왔는데 또, 애증이 교차하는 비주얼 C++ 6.0 얘기를 하지 않을 수 없다.
무려 11년 전엔 1998년에 출시되었고 아직까지도 애용되고 있는 소프트웨어로는 스타크와 더불어 양대 산맥이 아닌가 생각된다.
너무 구닥다리가 되어 외형이 후져 보이고(비록 당대로서는 MS 오피스 97 스타일의 새끈-_-한 UI였지만),
64비트 지원 안 되고 최신 하드웨어 기술 및 C++ 표준이 반영 안 돼 있는 것 자체만 빼면 정말 잘 만든 물건이긴 하다.

가끔은 6.0 특유의 그 클래스 마법사가 그리워질 때도 있다.
MFC는 이제 <날개셋> 타자연습 소스 열어볼 때 말고는 별로 접할 일도 없어졌구나.

그 비주얼 C++이 곧 있으면 연도도 2010이고 버전 번호로도 10.0이 나올 예정이다. 감회가 새롭다.
참고로 비주얼 C++ 2005는 2005년 하반기에 나왔지만 2005라는 타이틀이 붙은 반면,
2008은 비슷한 2007년 하반기에 출시됐지만 1이 더해진 2008이라는 타이틀이 붙었다.

※ 여자 프로그래머

7월 1일.. 경의선 전철 개통, 용인-서울 고속도로 개통, 거기에다 비정규직법 상정 2주년-_- 등 여러 굵직한 일이 많았는데, 나도 이제 병특 끝난 지 1주년이 됐다.
그리고 직장 생활 경력이 3년을 넘어갔다. 최소한 말단 신입사원 딱지는 떼는 짬밥이 됐고, 주임/대리급을 바라보는 신분이다. 하지만 옛날 회사나 지금 회사나 여전히 제일 나이가 어리고 내 밑으로 신입을 대한 적이 없으니, 예나 지금이나 늘 막내이다.

그리고 내가 지금까지 다닌 회사에서 여자 개발자를 본 적은 전혀 없다.
IT 회사라고 해도 여직원 하면 오로지 디자인, 기획 아니면 회계/경리이다. 개발자가 여자인 경우는.. 글쎄다.
하지만 외근 나간 연구소에서는 그래도 비주얼 C++ 띄워 놓고 코드와 씨름하고 있는 여자분들을 주변에서 여럿 볼 수 있어서 인상적이었다.

차라리 학교에 있을 때는 그런 모습을 심심찮게 볼 수 있었다. 내가 나온 학교는 공대 중에서 성비가 상당히 균형 잡힌-_-;; 편에 드는 곳이었으며, 전산과 역시 예외가 아니었기 때문이다.
하지만 나는 학교 시절엔 과 친구들하고 거의 어울리지 않고 동아리 같은 것도 안 하고 지냈기 때문에 그런 학우들로부터는 이렇다할 '임팩트'를 받지 못했다.

여직원하고 "아.. 그 땐 이런 함수를 쓰면 돼요"
"이 클래스는 여기서 상속 받았고 이 가상 함수는 이런 용도로 오버라이드하면 됩니다. 대략 이렇게 구현을 하면 어떨까요?"
"아 그렇게 생각해 보니 이렇게 짜면 버퍼 오버런이 우려되고, 멀티스레드 환경에서는 잠재적으로 또 문제가 있겠군요"
이런 이야기를 나눈다면.. 졸라 감회가 새로울 것 같다. 태어나서 이성하고 그런 얘기는 한 번도 한 적이 없으니까. =_=

하긴, 부부 교사도 있고,
커플이 나란히 코레일에 입사하여 기관차 운전 연수를 받던 부부 기관사도 봤는데, (촬영 당시 곧 결혼 예정이라고 쓴 걸 봤음)
부부 개발자라고 없을 이유는 없으리라 생각한다. -_-

Posted by 사무엘

2010/01/11 10:10 2010/01/11 10:10
Response
No Trackback , 2 Comments
RSS :
http://moogi.new21.org/tc/rss/response/86

예비군 갔다 온 소감 (2009/7/8)

본인, 병특 만료한 지 그래도 1년이 경과했고, 예비군 1년차 동미참 훈련에 들어갔다. 첫 날 갔다 온 소감을 분야별로 옴니버스 형태로 정리해 본다.

  총평: 합법적으로 꽤 오래 회사 빠질 구실 생겼다고 그저 꿀빨고 좋아만 할 사항은 아니다. =_=;; 훈련 자체야 하나도 안 빡세며, 조교나 교관은 그냥 친절한 후배 내지 동네 아저씨인 거 맞다. 하지만 오지로 왔다 갔다 하면서 군화 군복 차림으로 장시간 땡볕에서 고생하고 평소에 안 하던 꽤 긴 거리 도보-_-를 하는 거.. 본인은 그것만으로도 상당히 고생스러웠다. 갔다 오니 피곤해 죽겠다.

  훈련 교장의 접근성: 퇴소 명령이 떨어진 후 집까지 도착하는 데 1시간 반이 걸렸다. 집에서 그렇게 멀지 않고 전철+버스 연계가 괜찮으며 부대 바로 앞에 버스 정류장이 있는 것은 좋았다. 하지만 부대 내부의 집결/퇴소 장소에서 정문까지 가는 게 걸어서 15분 ㅜㅜ! 자가용 내지 수송 버스(물론 있었으나, 비싸고 어차피 집 근처까지 바로 안 감)가 아쉬운 순간이었다.

  현역 훈련병과 예비군의 차이: 물론 군기가-_- 들어간 정도라든가 조교/교관들이 대하는 태도 같은 것도 천지 차이이지만, 내게 질문한다면 외형상으로 가장 두드러지는 차이란 바로, “머리 길이와 담배”라고 요약하겠다. 이거 뭐 단순 80년대 장발 스타일을 넘어서, 뒤에서 보면 여자처럼 보일 정도로 치렁치렁 긴 머리를 묶은 예비군 아저씨도 있었으니 원! 현역 입대하는 훈련병이라면 상상도 못 한다.

  다른 아저씨들하고는: 말 한 마디도 안 했고 할 일도 없다. 서로 아는 사이인 예비역들은 같은 지방에서 자란 친구이기라도 한 걸까?
사실 근본적으로 나는 내 고향이 아닌 지역으로 부대 지정을 받았으니 이런 곳에서 아는 사람을 찾을 수도 없다. 차라리 2002년 신검 받을 때는 그때 중/고등학교 동기놈하고 얼굴 마주치기도 했는데 말이다.
작대기 네 개짜리 예비군 병장이 대부분이고, 가끔 해병대 출신 예비역도 보였는데 이들은 명찰이 빨간 배경 노란 글씨인 게 인상적이다. 나처럼 병특이나 공익 출신은 상의 주머니에 계급 작대기가 찍혀 있지 않다.

  담배: 우리나라의 내 또래 남자들의 평균 흡연율을 짐작케 할 정도였다. 현역 입대 훈련소라면 상상도 못 하겠지만, 일과 끝나고 조금만 틈만 생기면 예비군 아저씨들은 대부분 담배 뻑뻑 피워 댄다. 교관들도 “담배 피우는 분들은 건물 아래 말고 밖에서 피우세요” 이런 주의나 주는 정도이다.
예비군들이 머물렀던 훈련 교장 인근은 온통 담배꽁초 투성이가 되었다.

  손전화: 주위 아저씨들은 무지막지하게 들고 다닌다. 이건 반입을 원천 금지하는 게 사실상 불가능이니, 교관들도 사실상 묵인해 주고, 훈련 중에 대놓고 전화질만 하지 말라고 주의를 주는 수준이다. 사실 예비군 가 보면 기다리느라 보내는 시간 엄청 많은데, 심심하면 전화기라도 만지작거려야 직성이 풀리긴 한다. 하지만 나는 뭐 딱히 전화할 상대도 없고, 갖고 다니기가 거추장스러우니 앞으로도 손전화를 갖고 가지는 않을 것이다.

  점심 식사: 인터넷 상으로는 고작 4000원짜리 밥이 요 따위라니, 도대체 예비군 식사 납품 업체는 차익을 얼마나 챙기는지 모르겠다는 식의 악플이 엄청 많았지만 오늘 여기서 먹은 밥은 괜찮은 편이었다. 국은 육개장 내지 갈비탕 컨셉이었고, 더 달라고 하면 무료로 꽤 푸짐하게 많이 주기도 해서 잔반 하나 안 남기고 잘 먹었다. 밥에 관한 한은 나는 불만 없었다.

  총: 예비군한테는 이거 뭐 2차 세계 대전 내지 6 25 때나 쓰였다는 카빈 소총이 지급됐다는 루머-_-도 있었지만, 내가 간 교장에서는 오로지 M16 소총이었다. 논산 육군 훈련소에서도 만져 본 총이어서 친근했지만 사격 때는 정말 정신없었다. 물론, 폼으로만 들고 다니는 개인 소총으로 총 쏜 건 아니고, 사격은 사격장에 비치되어 있는 실제로 동작-_-하는 별도의 총으로 한다. ^^;;
물론 거기서 근무하는 현역들은 여전히 K2 소총 쓰더라.

  정신 교육: 앞으로 현역들의 복무 기간이 더 짧아지고 저출산 때문에 인구 갈수록 적어지면 예비군의 중요성이 더 커지게 되며, 여러분들이 국가 안보의 초석이라고 띄워 주는 멘트는 꽤 많더라. 그 외엔 북한이 우리의 주적이며 과거에 이렇게 나쁜짓 많이 저지르고도 전혀 반성의 기미가 없다는 식의 레퍼토리임. ㄱㅅ 그나저나 입소식 때, 현역 조교들도 앞으로 제대 후 우리처럼 될 애들인데, 걔네들 보기에 부끄러움이 없게 훈련에 임해 달라고 말한 연대장의 훈화가 좀 마음에 와 닿았다. =_=;;
참고로 정신 교육 때는 사람들 진짜 거의 다 잔다.

여기까지는 좀 평범한 내용이었고, 지금부터가 좀 썅소리 나오는 내용.. -_-

  날씨: 정말 증오로 죽이고 싶었다. ㅜㅜ 별로 덥지도 않았고 섭씨 20도 후반 정도의 평범한 흐린 날 같았는데 땀이 왜 이렇게 분수처럼 솟구치는지! 이미 오전이 채 가기 전에 온몸이 땀으로 샤워를 했다. 땀으로 젖은 손은 끈적끈적. 한번 어디 걷고 나면 몸의 기력이 싹 빠지는 느낌이었고, 강당에서 엎드려서 눈 좀 붙였다간 땀이 눈으로까지 들어갈 정도로 흘렀다.
햇볕은 별로 나지도 않은 거 같았는데 결국 팔뚝은 약간 벌겋게 타서, 손목시계를 찬 부위와 나머지 부위가 색깔이 다르게 보일 정도가 됐다. 어쨌든 날씨에 관한 한 최악이었다. 참을 수 없는 찝찝함!

  갈증과 피로: 훈련 자체는 예비군 특유의 정말 얼렁뚱땅 야메였음에도 불구하고, 집에 도착하자 녹초가 됐다. 술 좀 마셔서 알코올 독기가 몸에 퍼진 상태도 아닌데, 다리가 이렇게 저리고 쑤신 건 참 오랜만에 겪어 본다. 2년 전 훈련소에서 행군하고 나서도 저랬나? =_= 내가 체력이 꽝이어서 그런 것도 있겠지만 .. 정말 아무것도 하기 싫고 멍하고 짜증만 날 지경.
그리고 갈증. 내일 갈 때는 손수건(땀 닦으러)하고 사제 물병으로 물을 최소한 1리터는 꼭 챙겨 가야겠다고 굳게 다짐을 했을 정도로 제대로 고생했다. 너무 목이 말라서 집에 도착하자마자 물, 우유 등으로 거의 2리터 가까이를 비웠다. (음료수 사 먹고 싶지는 않아서. -_-)
그나마 집에서 싹 샤워하고 속옷 다 갈아입고 에어컨 바람 쐬면서 쉴 수 있었으니 망정이지, 동원(2박 3일 외박)이었으면 정말 자살했겠다. =_=;;

  증오로 죽이고 싶은 전투화: 내 발 상태를 엉망진창으로 만들고, 그 널널한 예비군 훈련을 극기 훈련으로 바꾼 일등공신이었다. 도대체 재질이 궁금하게 느껴질 정도로 까끌까끌 배긴다고 해야 하나? 결국 고무링이 닿는 발목에는 긁힌 흔적이 남았고, 양발 모두 발뒷꿈치는 완전히 까져 버렸다. ㅆㅂ~  사람 피부 껍질을 벗긴다는 게 얼마나 고통스러운지 체험했다. 발이 그렇게 아프니 뛰지도 못하고 오르막이나 내리막 걷는 것도 힘들고 엉거주춤 걸어야 했다.
이거 때문에 샤워도 제대로 못 했다. 가죽이 벗겨진 발뒷꿈치로  물이 흘러들어가자 “Oh no~” ㅠ.ㅠ
발도 발이지만 양말도 굉장히 무리를 많이 받았을 텐데, 이렇게 한두 번 신은 양말은 곧 발가락이나 뒤꿈치 쪽에 얼마 못 가 펑크가 날 것 같다. 이거 군화 뒷부분에다가 솜이나 휴지 같은 거라도 잔뜩 집어넣어야겠다.

이 짓을 금요일까지, 그리고 월요일에도 해야 한다. 발도 그렇고 팔뚝, 그리고 총을 메었던 오른쪽 어깨까지 벌건 자국이 생겨 있다.. 벌써 side effect가 꽤 크다.. ㅜ.ㅜ
빌어먹을 전투화는 무슨 일이 있어도 손을 좀 봐야 되는데 막막하구나.

동미참 교육은 금요일이 끝이지만, 월요일엔 지난번에 경조사 때문에 못 간 전반기 향방 작계 보충 교육을 받게 된다. -_-;;
집에는 회사 다닐 때보다야 일찍 들어왔지만, 무척 피곤하고 자기도 일찍 자야 하기 때문에 시간이 그렇게 많이는 못 난다. 그래도 동원보다는 동미참이 낫다. ㄱ- 부하 직원이 예비군인 회사의 생각은 이와 좀 다르겠지만.

Posted by 사무엘

2010/01/11 10:07 2010/01/11 10:07
Response
No Trackback , No Comment
RSS :
http://moogi.new21.org/tc/rss/response/85

※ JAL123 (1985년 8월 12일)

단일 항공기 추락 사고로는 최다 사망자가 나온 최악의 항공 사고로 손꼽힌다. 승무원 포함 탑승객 524명 중 520명 사망. 맨 뒤에 타고 있던 여성 4명만 생존. =_=
가장 먼저 드는 의문은, 아니 그때 지금 같은 초대형 에어버스급 항공기가 있었던 것도 아닌데, 도대체 무슨 500명이 넘게 사람이 몰살이냐? 비행기가 무슨 지상의 민간인을 덮치기라도 했냐는 것이다.
하지만 그렇지는 않다. 비행기는 산중턱에 추락했으며 희생자는 모두 비행기 탑승객 맞다.

여기에는 일본 특유의 짠돌이 근성이 한몫 기여했다.
일본이 어떤 나라인가? 전철만 봐도, 승객을 짐짝 취급하는 정도가 한국보다 더하다. 안 그래도 작은 협궤 전동차에 승객들이 터져나가다 보니 출퇴근 시간엔 승강장 길이보다 더 긴 열차, 한 량에 문이 우리나라처럼 4개가 아니라 6개인 열차, 아예 좌석이 없이 모든 승객이 서서 가는 열차처럼 별 게 다 다닌다.

사고기는 물론 보잉 747 대형 항공기이다. 원래 정원은 300명인데, 당시 경제 호황에다 명절 특수 덕분에 수요가 넘치는지라, 퍼스트/비즈니스를 없애고 모든 좌석을 이코노미로 개조하여 정원을 500명이 넘게 늘리고, 그 큰 비행기를 국내선에다 투입했다. 그렇다, 이 비행기는 도쿄에서 출발하여 오사카로 약 4, 50분 남짓한 시간만에 날아갈 예정이던 단거리 국내선이었다.

사고기에 크리가 터진 것은, 이륙 12분 후 거의 순항 고도에 진입했을 즈음에, 꼬리날개 부분이 바깥과 기내의 기압차를 견디지 못하고 폭발음과 함께 파괴되고부터였다. 이건 비행기에서 마치 배의 조향타, 사람 귀의 반고리관과 같은 부위인지라 비행기가 중심을 잡고 상하좌우 조향을 하는 데 반드시 필요하다. 조작은 사람의 힘만으로는 하기 어렵기 때문에 마치 자동차의 파워 스티어링처럼 유압 동력의 도움을 받아 행하는데, 이 오일도 다 유출되고 비행기는 한 마디로 엔진만 작동할 뿐 전혀 조종을 할 수 없는 상태에 빠지고 만다. 객실과 외부가 뚫려 버려서 산소 마스크가 내려왔으며, 그럼에도 불구하고 몇몇 승객은 산소 부족으로 인해 의식을 잃기도 했다고 한다.

사고기는 좌우로 들썩들썩거리면서 일반적인 착륙 속도의 수 배가 넘는 속도로 급강하하다가, 내려가는 과정에서 스스로 또 양력을 얻어서 붕 뜨고, 또 급강하를 지상과 완전히 충돌할 때까지 계속 반복했다. 삼각 함수처럼 진동했다는 소리인데, 뜨고 내리는 그 고도 진동의 폭은 가히 수 km는 됐다고 한다. 이렇듯 이 비행기는 바로 땅으로 자유 낙하를 한 게 아니다. 꼬리날개가 날아가 버린 후, 이 짓을 완전히 추락할 때까지 거의 3, 40분간 지속하면서 서서히 실속(stall) 상태에 빠졌고 평균 고도는 낮아져 갔다. 그러니 들썩거리는 비행기 안에서 승객들은 극도의 어지러움과 공포에 떨어야 했으며, 일부는 여권에다 유서를 쓰기도 했다. 물론 엄청난 진동 때문에 글씨는 완전 꼬불꼬불 제멋대로였다.

사고기의 조종사에 대해는, 그런 패닉 상태에서 비행기를 최선을 다해 그 시간 동안만이라도 조종한 게 대단했다는 평도 있고, 기장이 이미 산소 부족으로 인해 잠시 맛이 가서 정상적인 대처를 못 했다는 평도 있다. 어쨌든 한번 실속 상태에 빠진 비행기는 모두의 기대를 저버린 채 아래로 곤두박질치기 시작했고, 머리 부분이 '/' 모양으로 아래를 향하면서 산에 거의 수직으로 충돌함으로써 비참한 최후를 마쳤다. 추락 직전 드디어 GPWS (대지 접근 경보 장치)에서는 수 차례 "왱왱 pull up!" 죽음의 경고음이 흘러나왔다.

사고기는 저녁 6시에 출발했고 사고가 났을 때는 이내 해가 떨어진 밤이 되었다. 사고 소식을 들은 일본 정부에서는 즉시 수색/구조 헬리콥터를 출동시켰다. 그러나 현장을 확인한 헬리콥터는 생존자가 있을 리가 없다고 속단하고, 날씨도 안 좋은 깜깜한 밤에 빽빽한 산의 중턱에 헬리콥터를 착륙시키기란 힘들다는 귀차니즘에 입각하여 단념하고 그냥 돌아가 버렸다! 그리고 구조 대원들도 산기슭에서 하룻밤을 그냥 묵고 만다. 최후 생존자의 증언에 따르면, 사고 직후엔 사실 4명 말고도 아직 숨이 붙어 있는 위급 환자가 여럿 더 있었다. 그러나 그들은 밤을 지새우면서 추위와 구조 작업 지연으로 인해 결국 죽고 말았다. 온몸이 쑤시고 꼼짝달싹도 하지 않는 상황에서 필사적으로 헬기 불빛을 향해 손을 흔들었건만..! 일본 정부의 큰 판단 실수였다.

다음날 아침 드러난 사고 현장은 참혹하기 그지없었다. 흙더미에 파묻힌 채 나뒹구는 사람 손발, 이목구비 형체가 싹 사라진 민얼굴을 한 사람 모양의 숯검댕까지만 말하겠다.
(뜬금 없는 이야기이다만, 성경 창세기 1:2에서 땅이 형체가 없고 비었다는 말은, 멀쩡하던 사람 얼굴이 저 지경이 됐다는 것과 정확히 같은 맥락이다. 이전 세상에 대한 심판과 파멸 뉘앙스이지, 중간 과정을 나타내는 게 절대로 아니다)

대놓고 엔진이 고장났거나 기내에서 화재가 발생한 것도 아니고, 비행기가 뒷부분이 그렇게 망가져서 저렇게 서서히 추락하는 것은, 항공 역사상 무척 괴이하고 드문 사례였다. 그렇기 때문에 사건을 수사한 경찰과 항공 기술자들은 처음엔 무척 의아해했다. 그런데 진짜 원인은 사고기의 과거 내력에 있었다. 이 비행기는 7년 전 1978년엔 다 도착해서 착륙하던 중에 기수를 너무 높게 들어서 \ 뒷부분이 활주로에 긁히는 사고가 난 적이 있었다. 그때도 승객이 어마어마하게 많이 타서 비행기는 무거운 상태였고, 질량이 큰 항공기에게 조금이라도 더 큰 공기 저항을 주어 착륙 시 신속하게 속도를 줄이게 하려면 기수를 좀 높게 치켜세우면서 착지할 필요가 있었다. 그리고 이게 화근이었다.

비행기는 운항 종료 후 즉시 수리를 받아야 했다. 하지만 매우 critical한 부품인 뒷부분 벌크헤드의 정비는 일본 항공사가 자체적으로 할 능력이 없었기 때문에 항공기 제조사인 미국 보잉 사에 의뢰를 해야 했다.
그런데 최소한 두 줄로 땜질을 해야 하는 곳을 보잉 사에서는 한 줄만으로 대충 때웠다고 한다. 이것이 나중에 금속 피로도의 증가로 인한 파손으로 이어졌고 결국 비행기의 추락을 야기하고 520명의 승객의 목숨을 앗아갔다.

오랜 기간에 걸친 재판 끝에 사고 원인이 보잉 사의 수리 잘못으로 결정이 내려졌기 때문에 보잉 사는 상당한 거액의 보상금을 일본 측에 지불해야 했다고 한다. 전해지는 일화에 따르면 보잉 747를 처음으로 설계했던 기술자는 자기 회사 직원의 정비 불량 때문에 내가 설계한 비행기가 추락해서 사람들이 이렇게 많이 죽은 것에 통한을 감추지 못했고, 별로 책임이 크지도 않은 일본 항공 측의 한 비행기 정비사는 숫제 자살까지 했다고 한다. 무슨 큰일이 터지면 혼자 책임 다 뒤집어쓰고 희생양으로 자살하는 관행이 통용되고 있는 일본다운 스타일이다. 그렇지만 한편으로, 또 일방적으로 보잉 사만 나쁜놈으로 만들기에는, 그 부실한 벌크헤드가 왜 무려 7년이란 시간 동안은 별 문제가 없었는지에 대해 의문을 품는 사람도 있다.

이 사고를 계기로 전세계 항공업계는 아무리 대형 항공기라 해도 정원을 초과해서 승객을 태우지는 않게 됐다. 비록 이 사고의 직접적인 원인이 정원 초과는 아니었지만, 그래도 한꺼번에 너무 많이 태우고 가다가 사고라도 한번 났다가는 정말 너무 참혹한 올킬이기 때문이다. 그러나 요즘은 500명 이상급의 초대형 항공기가 다시 등장하고 있는 추세이다.

※ 테네리페 참사 (1977년 3월 27일)

잘 알다시피 비행기는 하늘을 날아다니는 3차원 교통수단이다. 그런데 두 비행기가 공중에서나 활주로에서나 서로 충돌할 일이 과연 있을까?
비행기는 단위 거리당 사망자 수로만 보면 자동차보다 월등히 안전한 교통수단이다. 더구나 요즘 같은 관제 시스템 하에서 추락도 아니라 비행기끼리 어이없게 충돌하기란, 그야말로 철길에서 열차가 정면 충돌할 확률 내지 가다가 벼락에 맞아 죽을 확률보다도 더 낮은 게 사실이다.

하지만 스페인 령 카나리아 제도 테네리페 섬의 로스 로데오 공항의 그 날은 그렇지 않았다. 대부분의 항공 사고가 자연 재해나 인재 등 단일 원인으로 인해 발생하는 반면, 이 사고는 하필 정말 "재수 옴붙었다고밖에" 볼 수 없을 정도로 최악에 최악의 가능성만 골라서 벌어지는 바람에 사상 최악의 최다 사망자 항공 사고가 터지고 말았다. 활주로에서 전속력으로 이륙 중이던 네덜란드 소속 여객기와, 이륙하려고 택싱 중이던 팬암 소속 여객기, 이렇게 보잉 747 두 대가 정면 충돌하여 두 비행기에서 총 무려 583명이 목숨을 잃은 것이다. (참고로 아까 JAL123기 사망자 520명, 삼풍 백화점 참사 사망자 501명)

정말 지지리도 운이 없었다. 로스 로데오 공항은 비좁고 한산한 '삼류(?)' 지방 공항이며 사실 보잉 747 급의 대형 항공기를 제대로 취급하기가 버거운 형편이었다. 사고를 당한 네덜란드 KLM기와 미국 팬암 기는 원래 거기에 갈 예정도 아니었으며, 착륙하려던 라스팔마스 공항에 테러 위협 경보가 들어오는 바람에 임시로 저 공항에 가게 된 것이다.

하필 그 시각, 날씨도 엄청 흐려지고 짙은 안개가 앞을 가려서 관제탑에서 활주로 전체 모습을 식별할 수가 없어졌다.
거기에다 비행기 조종사와 관제탑 사이에 같은 영어를 쓰고도 서로 말귀를 제대로 못 알아들었다. (전에 김 재주 님께서 영국 영어와 미국 영어에서 동사 table 의미 차이에 대해 지적한 것처럼)
KLM 기 기장의 멘트는 "이륙할 예정이다(의도한 뜻) / 이륙 준비 끝났다 (관제탑이 알아들은 의미)"로 의미가 서로 엇갈렸다.

이에 대한 관제탑의 회신은 "좋다. (2초간 쉬고) 이륙 허가를 곧 내리겠으니 기다리고 있어라"였는데, 뒷부분 멘트는 팬암 기 기장이 보낸 "안 돼. 우리가 아직 활주로에서 택싱 중이다!"와 겹쳐서 KLM 기로 제대로 전송이 되지 않았다.
"우린 이륙 준비 끝났다 / 좋다. 이륙 허가가 떨어질 때까지 좀 기다리고 있어 봐라" 가
"우린 이륙할 예정이다 / 좋다, 할 테면 해라" 로
의미가 순식간에 와전되고 만 것이다!

안개 때문에 KLM 기와 팬암 기, 관제탑 모두 상대편 비행기의 존재를 제대로 파악하지 못했으며, 일요일이라 관제탑엔 직원도 평소보다 적었고 지상 관제 레이더는 동작하지 않는 상태였다...;; 그리고 팬암 기는 지시받은 진입 지점을 안개 때문에 놓쳤지만, 돌아가기엔 귀차니즘에 입각하여 무시했다. 설마 별 일 있겠냐 하는 생각.

이륙 직전, 마지막으로 뭔가 수상한 낌새를 눈치챈 KLM의 부기장은 마지막으로 기장에게 "아직 팬암 기가 활주로에 있는 것 같은데요?"라고 반문했으나, 자신의 직속 상사이며 비행 시간 2만 시간이 넘는 KLM 최정예 조종사 기장의 "괜찮다" 한 마디에 그 의견은 묵살된다. 사실 KLM, 팬암 기 모두 기장은 베테랑급 고급 인재들이었다. 이로써 두 비행기가 충돌을 피할 마지막 기회마저 지나가고 말았다. 이 정도면 정말 재수 더럽게 없던 날이지 않은가?

결국 악몽 같은 일이 벌어지고 말았다. 상대방 비행기를 저 앞에서 발견해 버린 두 비행기의 조종사 입에서는 정말 "씨바! X됐다!" 소리가 나오고도 남았을 것이다.. 실제로 팬암 기의 조종실 음성 기록에는 "OMG! 저 개XX가 우리 쪽으로 돌진 중이야!"가 남아 있다..

택싱 중이던 팬암 기는 정면 충돌을 피하고 대피하려고 필사적으로 핸들(?)을 왼쪽 출구로 꺾었다. KLM 기는 이미 V1 (이륙을 중단할 수 없고 무조건 하늘로 떠야만 하는) 속도를 넘어서고 돌아오지 못할 강을 건너 버린지라, 필사적으로 하늘로 떠서 팬암 기를 타넘으려고 꼬리 부분을 손상시키면서까지 무리해서 기수를 들어올렸다. 하지만 완전히 피하지 못하고 KLM은 20미터 남짓 떴다가, 팬암 기의 윗부분을 박살내 버린 후 150여 미터를 타넘고 날아가다 추락했다. 그리고 두 비행기 모두 유출된 연료로 인한 맹렬한 화염에 휩싸였다.

하필 KLM은 이륙 직전에 급유를 마치고 연료도 5만 리터가 넘는 '만땅' 상태였다. 그것 때문에 무거워서 급하게 뜨기가 어려워진 것도 있었다. 그러나 불운의 KLM 항공기는 그 연료로 미처 날지도 못하고 오히려 그 연료 덕분에 홀랑 전소하고 말았으며 탑승객도 미처 탈출할 틈도 없이 전원 사망했다. 그 반면 팬암 기는 KLM 기가 비껴 간 중앙을 제외하고 맨 앞과 맨 뒤쪽에서 60여 명의 생존자가 나왔으며, 기장, 부기장 같은 승무원들도 살아남았다.

이 어이없으면서도 여러 변수가 복합적으로 AND로 작용하여 발생한 사고로 인해, 항공 규정은 크게 바뀌었으며, 무엇보다도 관제 중에는 의미가 명확한 표준 용어만 사용하게 되었다. 요즘은 특히 조종사들에 대해 요구하는 영어 실력도 크게 강화되고 있다. 작은 오해가 자칫 이런 식의 큰 항공 사고를 야기할 수도 있기 때문이다. 국제 민간 항공 기구(ICAO)는 2004년 9월, 한국 같은 비영어권 국가들에 대해, 영어 실력을 갖추지 못한 항공 종사자들을 현업에서 배제해줄 것을 요구하기까지 했다. 물론 여기에 대한 반발도 적지 않다.

따지고 보면, 당시 스페인 공항을 상대로 테러를 저지르고 싶었던 가상의 테러범들은 자신의 목표를 이런 사고로 인해 간접적으로 더욱 초과 달성한 것 같기도 하다. 자기를 피하려고 대형 여객기를 그 좁고 날씨 열악한 공항에다 몰아넣게 하고, 결국 저런 사고까지 나게 만들었으니 말이다.

참고로 두 항공기가 공중에서 거의 충돌할 뻔한 적이 놀랍게도 없지는 않다. 비행기라고 해도 날아다니는 항로는 정해져 있으며 여러 항공기가 한 항로를 공유한다면 사고의 위험은 언제나 존재하게 되는 법이다. 더구나 요즘은 수십 년 전과는 비교도 할 수 없이 많은 여객기들이 공중을 누비고 있다는 사실을 잊어서는 안 된다.
항공업계에서는 두 비행기가 불과 약 150미터 이내로만 근접해도 near-miss라 하여, 실제로 부딪치지 않았더라도 사고라고 간주한다. 전동차만 해도 추돌을 방지하려면 앞 차와 최소 200미터 이상 간격을 유지하면서 달리게 되어 있는데 그 빠른 항공기가 1초에 얼마나 멀리 나갈 수 있는지를 감안한다면, 저 정도만 해도 정말 큰 사고라고 간주할 수 있다.

순항 중인 항공기의 충돌이 우려되는 경우 관제탑에서는 한쪽 비행기는 고도를 높이고, 다른 쪽 비행기는 고도를 낮추어서 서로 비껴 가라고 명령한다(혹은 좌우 방향 틀기). 그런데 거의 충돌할 뻔한 상황이란, 의사 소통이 제대로 안 되어 두 비행기가 조치를 취하지 않았거나, 심지어 둘 다 동일하게 고도를 높이거나 낮추었을 때이다.

※ 결론

1. 비행기는 순항 중에는 좀체 사고가 나지 않는다. 사고는 대부분이 이륙, 착륙 과정에서 발생한다. 나는 옛날에는 착륙이 이륙보다 더 위험하다고 생각했는데, 젖먹던-_- 힘까지 내어 달려서 공중에 떠야만 하는 이륙도 만만찮게 위험하고 크리티컬한 순간이다. 개인적으로 이륙할 때의 그 비행기 엔진 소리와 떨림이 좋다. ^^;; 그런 의미에서 보면, 지난 6월 초에 발생한 에어 프랑스 비행기 사고는 멀쩡히 바다 위에서 순항 중이다가 갑자기 불의의 사고로 추락했다는 게 이해가 잘 되지 않는다.

2. 생명체는 아무리 심하게 다치더라도 최소한 뱃속의 음식물(연료??=_=)이 폭발하거나 각종 장기들이 누전, 합선되어 화재가 발생하지는 않는다는 게 존경스럽다. 전체 시스템의 한 고리가 끊어지는 순간에 와장창 조직 전체가 와해되는 게 아니라, 사실은 조직을 이루는 각 구성요소도 재귀적으로 별개의 미시적 시스템을 이루고 있고, 숨이 끊어지는 마지막 순간까지도 최대한 살려고 발버둥친다. 테란 건물과 저그 건물의 차이이며, 사람의 작품과 하나님의 작품의 구조적인 차이가 이런 게 아닐까 한다. ^^

Posted by 사무엘

2010/01/11 10:03 2010/01/11 10:03
Response
No Trackback , No Comment
RSS :
http://moogi.new21.org/tc/rss/response/82

원자폭탄, 기타 이것저것

20세기에 인간이 이뤄낸 위대한 과학 성과 중 하나는 원자력에 대한 지식이다.
학생들이 무려 고등학교나 대학 학부 수준에서 배우는 물리 교재에 chapter가 하나 추가될 정도로, 종전의 고전 역학과는 차원이 다른 지식이 추가되었다.
 
이를 바탕으로 인간은 예전에는 미처 상상도 할 수 없던 어마어마한 동력과 에너지를 얻을 수 있게 되었다.
원자력 발전은 태양에 전혀 근간을 두지 않고 에너지를 얻는 거의 유일한 방법이기도 하다.
20세기 이후에 시작된 찬란한 전기 문명은, 교류 전기의 실용화와 더불어 원자력 발전도 큰 일조를 했음을 부인할 수 없을 것이다.
 
그러나 원자력은 이내 핵무기라는 것을 만들었고, 국제 사회 정세를 완전히 다른 양상으로 바꿔 놓기도 했다. 예전에는 마음에 안 들면 애들처럼 서로 주먹으로나 툭탁거리고 싸우던 것이, 이제는 총을 손에 쥔 거나 마찬가지가 됐다는 소리이다.
 
현재까지 인류 역사상 자국민이 사는 도시에 핵무기를 맞아 본 나라는, 잘 알다시피 전세계에서 일본이 유일하다. 그것도 두 번이나 맞았다. 2차 세계대전의 말기에 유럽에 독일, 이탈리아는 다 항복하고 히틀러마저 제거됐는데 아직 일본만 유일하게 개기고 있어서 저랬다. '무시무시한 폭탄'을 맞고서야 정신을 차린 일본은 왕이 직접 서면으로 연합국에 항복하고, 자기 식민지들에 대한 권리도 일체 포기한다. 그래서 2차 세계대전이 정말 극적으로 끝나고, 우리나라도 일제로부터 해방된다.

아마 우리나라가 이렇게 당했으면 미국하고는 완전 철천지원수가 됐을 것이다. 방사선 피폭은 대물림까지 된다. 그 데미지의 레벨이 6 25 때 무슨 노근리 학살 같은 거하고 비교가 되나?
 
잘 알다시피 원폭은 1945년 8월 6일에 히로시마 상공에 먼저 떨어졌다. 의역 좀 하면 '귀여운 꼬마애'뻘 되는 길이 약 3미터, 무게 약 4톤쯤 되는 Little Boy 폭탄이 어지간한 여객기 고도와 비슷한 9.5km 상공에서 전투기로부터 투하되었다. 타이머를 걸었는지 뭐 어떻게 activate가 됐는지는 모르겠지만, 그 폭탄은 한참을 추락하다가 약 550m 상공에서 그대로 펑 터졌다.
수류탄도 그렇고 폭발물은 약간 공중에서 터져야 사방팔방으로 가장 큰 파괴력이 나오는 법. 이 원폭도 일종의 공중 폭발을 일으켰다.
 
곧바로 눈을 보호하기 위해 가글을 착용한 당시의 전투기 승무원들은 정말 경악할 만한 광경을 목격하게 됐을 것이다.
이것은 보어, 페르미, 천재 컴퓨터 과학자인 폰 노이만 등 이름만 들어도 아는 당대의 저명한 과학자들이 일본 본토 지형을 치밀하게 분석하고, 폭탄을 어디에서 투하하고 터뜨려야 가장 큰 피해가 나오는지까지 계산하여 진행한 프로젝트였다. 그 첫 실험 대상으로 일본이 선택된 것이다.
 
눈을 상하게 할 정도의 엄청난 섬광이 비쳤다가, 정신을 차리고 보니 어마어마한 불기둥과 무시무시한 후폭풍. 하늘이 어두워지고 그저 도미노처럼 힘없이 주저앉는 건물들. 영화보다 더 영화 같은 순간.
아마 핵실험 촬영 같은 것도 수십 킬로미터 떨어진 곳에서 zoom 무지막지하게 당겨서, 과장 좀 보태면 천체 활동 관측하듯이 해야 하지 않을까 싶다.

히로시마 시는 순식간에 폐허가 되었다. 죽은 사람 시체 사진을 보니까 거의 유대인 홀로코스트 내지 관동 대지진 학살 사진 수준이었다.
물론 그 며칠 전에 미국에서는 원폭 투하를 예고하고 어서 대피하라는 경고 전단지를 살포하긴 했었다고 한다.
하지만 대부분의 사람들은 사고방식이 "설마? 뭐 좀 위력이 큰 폭탄 떨어져 봤자, 늘 하던 대로 방공호로 대피하면 되겠지" 수준이었으며, 결국 원폭에 고스란히 당했다고 전해진다.
 
  (이런 예화는 기독교에서 복음 전할 때 자주 인용, 등장하기도 한다.)
 
나는 일본에 대해 완전 몸서리치게 증오하거나 딱히 피해 의식이 있지는 않다. 원폭 맞아서 도시 전체가 저렇게 개떡이 되고 만 것은, "꼬시다 쌤통이다 메롱"까지는 아니더라도, 감정 배제하고 객관적으로 봐도 정말 일본이 자기네가 심은 대로 거둔 것이다.
 
우리한테 한 짓이 얼마인데! 특히 잊어서는 안 되는 그들의 죄악 중 하나는, 관동 대지진 때 민심이 흉흉해지니까 조선인들을 폭도로 몰아서 수천, 수만 명을 다 학살하고, 그걸 일본 경찰과 정부 당국은 일부러 묵인까지 해 준 사실이다. 독립 운동 항일 투쟁을 하던 사람도 아니고 멀쩡한 민간인을! 사태가 수습된 뒤에도 이 학살극에 대해 법적으로 책임을 진 쪽은 일본에 아무도 없었다.
 
외모가 비슷하니까 일부러 한국인이 발음하기 힘든 일본어 단어를 발음까지 시켜서 사람을 죽였으며, 그러다 심지어 몇몇 자국인도 오인 살해 당했다고 한다. 성경에서 사사기 12장 5~6절을 읽어볼 것. 오히려 조선인을 단원으로 고용하고 있는 야쿠자 같은 조직에서 조직원의 목숨이 위태로우니 애써 숨겨 줬을 정도라고 한다. 그러니 저런 죄값쯤은 좀 치러야 하지 않겠는가? (물론 원폭 피해자 중에서도 조선인이 일부 있었지만.)
 
그럼에도 불구하고 일본은 자기가 저지른 죄에 대한 언급이나 진정한 반성과 사죄는 싹 회피하고, 오로지 핵폭탄을 맞아 자기네가 불쌍한 피해자인 것만 부각시키면서 동정을 호소하고 있으니, 경계해야 할 점이 아닐 수 없다. "다시는 이런 실수 되풀이하지 않겠습니다"... 일본 문화 특유의 뱅뱅 돌려 말하는 모호한 표현인데.. 도대체 그들은 무엇을 실수라고 생각하는 걸까?
 
'귀여운 꼬마애'를 실은 전투기를 조종한 사람은 폴 티베츠라는 베테랑 공군 조종사이다. 당시 30대 초반의 혈기왕성한 대령이던 그는 2차 세계대전을 종식시키는 데 일조한 영웅으로 미국 내에서 추앙 받았으며, 나중에 원스타 준장으로까지 진급한 후 전역했다. 그리고 천수를 누리며 굉장히 오래 살다 2007년에 작고했다.
그는 2002년이던가 미디어를 통해, 당시의 원폭 투하는 그저 명령에만 따른 것일 뿐 딱히 개인의 양심의 가책을 느끼지는 않는다고 회고했다.
 
사흘 뒤 나가사키 상공에 투하된 원폭은 원판보다 더 뚱뚱하고 위력도 좀더 강해진 것이었다. 하지만 평지인 히로시마와는 달리 나가사키는 지형의 기복이 큰 편이어서 히로시마 만한 데미지는 나지 않았다.
 
핵무기까지 가미된 2차 세계대전을 겪은 후 세계 지성인들의 세계관, 인간관은 정말 큰 변화를 겪게 되었음이 틀림없다. 아마 성선설에 대한 믿음이 크게 흔들리게 됐을 것이고, 이런 과학 기술로 이런 규모의 전쟁이 앞으로 더 터졌다간 진짜 지구가 멸망할 거라는 경각심을 갖게 됐을 것이다. 그러니 국가 위의 다른 중재 조직이라도 만들어서 세계 열강이 또다시 이런 끔찍한 전쟁에 도미노처럼 휘말리는 것만은 무슨 수를 써서라도 막아야 한다는 생각을 했을 것이다.
 
그래서 유명무실하던 국제 연맹도 없애고 국제 연합이라는 조직이 새로 생겼다. 그러나 그런다고 해서 세상에 전쟁이 없어지지는 않고 있다. 사악한 자에겐 결코 평화가 없다고 말하는 주님의 이사야서 말씀을 기억하자.
 
어쩌면 6 25 전쟁이 장기화되었다면, 냉전이고 나발이고 없이 2차 세계 대전이 끝난 지 10년이 채 안 지나서 한반도에서 거의 세계 대전급의 피터지는 싸움이 또 벌어졌을지도 모르며, 최악의 경우 핵무기가 또 동원되게 됐을지도 모르겠다. 특히 우리나라에서는 맥아더 장군을 욕하고 비판하는 진영이 이런 점을 주로 들추곤 한다. 하지만 이런 진영은 그 불행의 근본 원인 제공자에 대해서는 이상하리만치 언급이 없고, 저런 식의 주장을 하는 의도가 매우 불순한지라 본인은 별다른 의미를 두지 않는다. (아무리 생각해도 정말 불순하다.)
 
사실 6 25도 1951년 하반기 이후부터는 38선 인근에서의 지겨운 엎치락뒷치락 소모전 위주였기 때문에, 미국도 필요 이상으로 소련 심기를 건드리고 싶지도 않았으며 어지간해서는 승산 없는 이 전쟁에서 적당히 손 떼고 싶었을 것이다. 이승만, 맥아더 같은 짝짜꿍이 맞는 꼴통(?)들만이 오로지 북진 통일을 고집했던 것이다.
 
그 후 세월이 흘러 박정희 정권은 70년대 말에 우리나라도 전투기와 핵무기를 제외한 모든 무기를 국산화했다고 선언했다. 이는 박 대통령의 적극적인 지원 하에 국방 과학 연구소 연구원들이 헌신적으로 노력한 덕분이었다.
 
그는 더 나아가, 우리가 북한과 일본, 미국을 상대로 당당히 큰소리 치려면 우리도 핵무기를 만들어 내야 한다고 생각했다. 박정희가 부하의 총에 맞아 비명에 가지 않았다면, 그리고 이휘소 박사 같은 사람이 그렇게 허무하게 가지 않았다면 한국의 역사가 또 바뀔 수 있었을까? 얘기를 더 하자면 정치성 논쟁이 되므로 이 자리에서는 생략하겠다. (그런데 정작 이휘소 당사자는 오히려 유신 독재와 핵무기 개발을 강력 반대했던 걸로 유명하다. 김진명 씨의 소설에 나오는 설정은 허구이다 ^^)
 
아무쪼록 이 바닥으로 글을 쓰면서 또 느낀 것은, 역시 아는 것이 힘이고 냉혹한 세상에서는 힘이 최고라는 것. 어차피 강자와 약자가 둘 다 시편 20:7 말씀을 모르거나 안 믿는 상황이라면 말이다.
"무기를 만드는 자는 지배자가 되고 방패를 만들지 않는 자는 노예가 된다는 진리"는 돌도끼로 전쟁을 할 때부터 미사일로 전쟁을 할 때까지 인류문명이 만들어 놓은 진리이다. 과거에 우리나라가 힘이 없어서 일제에 주권을 빼앗기지 않았던가.
 
우리나라 국민들이, 일본에 대한 증오심과 적개심이 부족해서 양국의 국력 차이가 그 정도이고 우리가 이렇게 살고 있는 게 절대 아니다. 일본에 있는 동급의 저질 찌질이들하고 같이 댓글 논쟁, 사이트 DDOS 공격이나 주고받으면서 그게 애국인 줄로 착각하지는 말아야 한다.
일본으로부터 받아낼 건 비용 대 효율 최대로 받아내고, 말 없이, 모방을 통해 창조를 해 내고, 실력을 쌓고 기술을 개발하고 국부를 창출하는 것이 일본을 가장 수준 높게 이기는 것이다. 일본을 그런 방법으로 이기려고 애썼던 옛날 지도자의 공도 과와 더불어 객관적으로 인정과 평가를 받아야 하지 않나 싶다.
 
덧.
이 글의 전반적인 논조로부터 느껴졌겠지만, 본인은 원자력 발전 찬성이고, 핵무기 개발도 그렇게 반대 안 한다. 남이 만들면 우리도 해야 된다 주의에 가깝다. -_-;; 그깟 인본주의적인 반핵 반전 운동 한다고 해서 세계 평화가 유지될 거라고 믿지 않는다.

Posted by 사무엘

2010/01/11 10:01 2010/01/11 10:01
Response
No Trackback , No Comment
RSS :
http://moogi.new21.org/tc/rss/response/81

코트 안의 마물

제가 초등학생이던 시절, 미국 역사에 대해 쓰인 책을 읽고 있었는데 "보스턴 차 사건"이라는 걸 접했습니다.
그때 저는 미국의 독립 운동가들이 야적장에 쌓여 있던 영국산 자동차들에다 불을 질렀거나 무역선에 실려 있던 자동차를 다 바다에 처박아 넣은 걸로 생각했습니다.
그 당시는 자동차가 발명된 시기하고 미국이 건국된 시기를 연계해서 보는 안목이 없었을 뿐더러 어휘력이 부족했기 때문이지요. =_=;;

마치 "코트의 안에는 마물이 살고 있어"를 듣고는 사람이 입는 코트 안에 괴물이 숨어있는 장면을 떠올리는 것과 같은 맥락입니다. -_-;; (coat가 아니라 court입니다. In the court lives a demon ㅋㅋㅋ)

하지만 그 차가 자동차가 아니라 마시는 차의 원료라는 것은,
그래도 스페인과 에스파냐가 동일한 나라인 걸 깨달은 것보다는 일찍 깨달았습니다.
저는 고등학교 때까지만 해도 무적 함대(영국에게 격파 당한)를 갖췄던 천주교 국가 스페인은 유럽에 있고,
투우로 유명한 에스파냐는 멕시코 같은 라틴 아메리카 중남미에 있는 나라인 줄 알고 있었습니다. -_-;;

특히 외래어를 표기할 때, 귀차니즘에 입각하여 장음을 따로 반영하지 않게 됨으로써, 외래어의 동음이의어 모호성도 꽤 심각한 수준이 되지 않았나 생각됩니다.
한자어 동음이의어랑 똑같죠. 더구나 한자와는 달리 영어 알파벳은 컴퓨터로 치기도 아주 수월하니 영단어 혼용은 앞으로 더욱 심해질 것 같습니다.

리드: lead (지도/통솔), read (읽기), reed (갈대, 악기 부품), lid (뚜껑)
코드: code (부호, 정보, 성향), chord (음악 용어 화음), cord (전기 플러그가 연결된 줄)

결론: 코트 안의 마물은 마치 귓속에 도청 장치만큼이나 임팩트가 큽니다. ㅋㅋ

Posted by 사무엘

2010/01/11 10:00 2010/01/11 10:00
Response
No Trackback , No Comment
RSS :
http://moogi.new21.org/tc/rss/response/80

레거시 코드

꽤 희귀한 기회 덕분에,
한때 시대를 풍미했던 상업용 소프트웨어의 소스를 구경하게 됐습니다.

윈도우 3.1에서 돌아가는 녀석이었거든요.
저야 도스박스에다 윈도우 3.1 + 비주얼 C++ 1.5도 갖추고 있어서 이걸로 돌려도 되지만
32비트로 포팅을 해 보고 싶어서 최신 개발툴로 프로젝트를 만들고 빌드를 해 봤습니다.
당연히 바로 빌드는 안 되고 수백여 군데에서 에러가 나는데...
16비트 윈도우 코드의 특징을 한눈에 알 수 있었습니다.

1. precompiled header가 없었는지 매 소스 파일마다 <windows.h> 인클루드.

2. 말로만 듣던 far, huge 포인터의 압박. 메모리 모델별로 malloc이라든가 포인터를 다루는 함수도 따로 존재. _fmalloc 같은.

3. POINT 구조체. 옛날엔 POINT 구조체의 x,y 멤버가 16비트 크기였기 때문에 32비트 long 하나로 POINT를 나타내는 게 관행이었으며, 심지어 lParam *을 POINT *로 바로 캐스트하는 MAKEPOINT 같은 매크로까지 존재했습니다. 하지만 지금은 좌표계가 32비트로 커지고 이것 때문에 MoveTo, SetWindowOrg, SetViewportExt 같은 함수들은 모두 Ex가 붙은 형태로 프로토타입이 바뀌게 됐죠.

4. 옛날에는 핸들(HANDLE, HINSTANCE, HGDIOBJ, HWND 등등)은 전부 void *의 typedef였고, 아무 형변환 없이 마음대로 섞어 썼습니다. 이 폐해를 막으려고 지금은 STRICT(엄격한 타입 구분)라는 개념이 추가됐지만 어마어마한 분량의 레거시 코드를 컴파일시키려면 그 옵션을 꺼야 하죠.

5. WM_CTLCOLOR 메시지. 옛날에는 이 메시지 하나만 왔지만 지금은 WM_CTLCOLORBTN, DLG, EDIT, LISTBOX 등으로 세분화됐습니다. 다만, 16비트 관행을 물려받은 MFC는 여전히 OnCtlColor 라는 한 함수로 이 메시지들을 모두 처리합니다.

6. 멀건 윈도우 3.1 대화상자에다가 은빛 3차원 효과를 입혀 주는 ctl3d.dll과 교신을 하는 흔적. 그러고 보니 그때는 이런 효과가 지금의 공용 컨트롤 6.0 매니페스트 같은 그런 매개체였던 것 같습니다. MFC에도 CWinApp 클래스에 Enable3dControls 같은 멤버 함수가 있을 정도였는데, 이제는 완전히 deprecated로 처리되죠.

7. DLL도 아니고 EXE에 웬 export 속성이 지정된 함수? 그것도 __declspec(dllexport) 같은 지금 통용되는 문법으로 작성된 것도 아닙니다.
16비트 윈도우 EXE는 헥사 에디터로 들여다보면, 윈도우/대화상자 프로시저처럼 운영체제로부터 호출을 받는 콜백 함수들의 이름을 따로 name table에다 등재를 해 놓는 경우가 많더군요. 꼭 그렇게 할 필요는 없는데 왜 그러는지 궁금.. 디버깅 정보와 관련이 있는지, 아니면 속도를 높이려고 그러는지 이유는 모르겠습니다.

8. C++ 문법이 바뀌어서 옛날에는 허용되었으나 지금은 허용되지 않는 몇몇 문법들

맥이나 리눅스 같은 다른 플랫폼들은 도스 같은 극악의 호환성 발목은 없었겠지만, 16비트를 겪은 시절조차 전혀 없었는지가 문득 궁금해지네요.

참고로 저는 C/C++은 32비트 도스 익스텐더 환경에서(왓콤, DJGPP) 처음 시작했고 16비트는 거의 접한 적이 없는 세대입니다. ^^

Posted by 사무엘

2010/01/11 09:58 2010/01/11 09:58
,
Response
No Trackback , No Comment
RSS :
http://moogi.new21.org/tc/rss/response/79

비행기의 추억

1. 공항 가는 길: 드넓은 공항 고속도로와 늘 텅 비어 다니는 공항 철도. 주변 갯벌과 영종 대교의 경치가 무척 인상적이다. 서울에 살면서 짐이 별로 없이 혼자 비행기 탈 때야 싸고 쾌적한 공항 철도가 짱이지만, 공항 철도 수혜권의 밖에 있는 사람이 훨씬 더 많은 게 문제.

2. 으리으리한 인천 공항 여객 터미널: 리무진으로 공항에 갔다면 3층인 출발층에 코앞에서 내리겠지만, 자가용을 갖고 갔다면 지하 주차장, 그리고 철도를 이용했다면 역시 지하에서 내리므로 터미널까지 한참을 걷고 올라가야 한다.
돈 뽑기, 환전이나 휴대전화 로밍 같은 시설은 널렸으니 전혀 걱정할 필요 없다. 전세계에서 통용되는 만능 콘센트 같은 것도 면세점에 가면 다 있다. 하지만 환전은 인터넷으로 미리 해 가야 싸다. 시계 같은 건 군부대 앞에 있는 사제품을 사는 것보다야 미리 챙겨 가는 게 더 나은 것과 같은 이치.

3. 출국 수속: 맨 윗층(3층)인 출국층으로 올라가, 내가 타는 비행기가 소속되어 있는 항공사의 부스로 간다. 짐이 많으면 카트 하나 끌고 긴 줄을 따라 기다린 후, 자기 차례가 되면 출국 수속을 받는다. 미리 프린트해 놓은 E티켓과 여권을 제시하면 되는데, 항공사에 따라서는 아예 E티켓은 보지도 않고 여권만 주면 되는 경우도 있더라.

이 시점에서 항공권이 발권된다. 직원이 어디 앉고 싶냐고 보통 묻는다. 나는 늘 창가 쪽 좌석을 달라고 했고 그럼 그렇게 티켓이 나왔다. 신체 건강한 성인이라면 비상구 쪽 좌석을 달라고 해도 된다. 발을 길게 뻗을 수 있어 무척 편한 자리인 반면, 여기 앉은 승객은 사고가 났을 때 승무원과 같이 다른 승객들 구조를 도와야 할 의무가 있다. 이건 항공업계에 법으로 규정된 사항이며, 이 때문에 비상구 좌석은 그렇게 할 능력이 있고 그 의무에 동의하는 승객에게만 발권된다.

4. 소지품: 고속버스의 내부에 짐칸과 객실 내 선반이 따로 있듯이, 비행기를 탈 때도 승객은 큰 짐은 따로 부칠 수 있으며, 작은 짐은 그냥 기내에 갖고 들어갈 수 있다. 부치는 짐은 출국 수속을 할 때 무게를 재고 간단히 보안 검사를 한 후, 항공사 측으로 인계하게 된다. 옷가지나 세면도구, 책처럼 당장은 없어도 되면서 싸고 부피가 비교적 크고, 잃어버려도 그렇게 큰 손해가 아닌 짐은 응당 부치면 된다.

부치는 짐은 수송하는 과정에서 컨베이어 벨트 위에 쿵쿵 떨어지기도 하고 직원들이 막 던지기도 한다. 수송 과정을 직접 눈으로 보면 정말 '식겁'을 할 거라던데.. 그러므로 충격에 약한 물품은 부칠 때 각별히 주의해야 한다. 또한 승객들끼리 짐이 뒤바뀌는 불상사를 막기 위해 가방 손잡이 같은 데에다 나만 식별할 수 있는 색깔의 손수건을 묶거나 표식을 미리 해 두는 게 좋다. 무게도 미리 재어서 테스트해 보는 것 역시 상식.

비행기에는 기내에 휴대 반입이 가능한 짐이 있고, 기내 반입이 안 되어 부쳐야만 하는 짐이 있으며, 아예 부치지도 못하는 짐도 있다. 참고로 기내에는 손톱깎이나 커터 같은 작은 쇠붙이도 갖고 들어갈 수 없으며 이런 건 부쳐야 한다. 비행기에 실을 수 없는 물품에 대해서는 소지를 그냥 포기하고 불우이웃 시설에 기증(?)하라는 물품 포기함도 공항 내부에 있다. ^^;;
이런 것과는 반대로 디지털 카메라, 노트북 같은 고가의 전자 기기들은 부치지 말고 기내에서 개인이 직접 휴대해야 한다.

5. paid 구역으로: 이제 탑승권을 받았으므로 paid 구역으로 들어간다. 돌아올 수 없는 강을 건너는 것이다. 철도처럼 자동 개집표기 같은 건 없고, 입구를 지키고 있는 직원에게 여권과 탑승권을 제시하면 바로 들어갈 수 있다. 곧바로 우리를 기다리고 있는 건 보안 검색대이다. 가방, 주머니 속의 소지품, 웃옷 다 꺼내서 바구니에 얹고, 본인도 신발 벗고 검색대를 통과하면 된다.

6. 출국 심사: 검색대를 통과한 후 출국 심사를 받는다. 출국 금지된 블랙리스트 등재 인물이 아닌지만 파악하는 과정이므로 우리 같은 사람에게는 해당 사항 없다. -_-
여권과 비행기 탑승권을 제시하면 직원이 여권에다가 우리 공항을 이용하여 출국했다는 도장을 찍어 준다.

7. 대기: 출국 심사까지 마쳤으니 남은 것은, 면세점 쇼핑을 즐기다가 내가 타는 탑승구를 찾아가 비행기에 타는 것뿐이다. 타는곳이 확장 탑승동에 있다면 아직 갈 길이 한참 머니 지하로 가서 셔틀 전철을 타야 한다. 이 구역 내부는 무선 인터넷도 무료로 잘 돌아가고 있으니, 노트북을 갖고 있고 아직 시간이 많이 남았으면 인터넷을 즐겨도 좋다. 비행기 안에서는 인터넷이 안 되므로 어차피 배터리 다 쓸 거면 지금 쓰는 게 낫다.

8. 탑승: 각 게이트별로 아담한 대기실(?)이 있고 승객들이 앉아서 게이트가 열리기를 기다리고 있을 것이다. 그러다 게이트가 열리면 비행기로 탑승이 시작되는데, 보통 1등석 승객과 노약자 장애인부터 가장 먼저 들어가고 일반실 승객도 좌석 번호에 따른 구역별로 승무원의 통제에 따라 탑승하게 된다. 1등석 승객과 다른 승객들은 들어가는 길이 분리되어 있기 때문에 일반실 승객은 2등석까지는 잠시 구경할 수 있어도 1등석을 구경할 일은 잘 없다.
좁은 통로를 지나서 드디어 비행기 내부에 들어간다. 일반실은 좌석이 굉장히 작아서 KTX 일반실 내지 일반과 비슷하다. 버스처럼 안전 벨트가 있고, 다른 교통수단에는 없던 담요가 있다. 그리고 식수가 비치되어 있다.

9. 출발: 비행기를 타는 건 굉장히 큰 일이다. 보통 승객들도 예상 시각보다 훨씬 더 일찍 맞춰서 공항에 알아서 오고 대비를 한다. 작은 공항의 경우 타기로 예정된 승객들만 다 타면 예정 시각보다 먼저 비행기가 출발해 버리는 경우도 있는 있다. 하지만 비행기가 엄청 많이 드나들고 활주로를 조직적으로 사용해야 하는 인천 같은 큰 공항은 그러지는 못할 것이다.

비행기가 활주로까지 이동하는 것은 꼭 버스가 출발하는 것과 별 차이 없는 느낌이다. 이 동안 우리 항공사를 이용해 줘서 고맙다는 안내 방송과 함께 비상시 대처 요령 같은 게 비디오로 흘러나올 것이다. 그리고 곧 이륙을 할 것이므로 안전 벨트 채우고 전자 기기를 다 꺼 달라는 당부가 나온다. 비행기 내부에서는 이착륙 중엔 안전을 위해 일체의 전자 기기 사용이 금지되며, 순항 중일 때에나 통신 기능이 없는 기기만 사용할 수 있다. 따라서 기내에서 비행기의 이착륙 중에 창밖 풍경을 찍은 동영상은(유튜브에도 있다) 마치 예비군 훈련장 내부 사진(역시 블로그에 나돈다)만큼이나 규정을 어기고 몰래 찍은 것이다.

10. 이륙: 이륙이 시작되면 비행기의 엔진 소리 옥타브가 급증하고 바람 가르는 소리가 거칠게 나기 시작한다. 짜릿하다. 비행기는 정말 이 맛에 탄다. 그리고 갑자기 지구의 중력 가속도의 값이 바뀐 듯한 느낌과 함께 비행기는 공중으로 뜨고 경사감이 느껴진다. 바깥 건물과 도로들이 장난감처럼 작아져 보이기 시작하며 구름마저도 아래로 보이게 된다.

본인의 경험상 인천 공항에서 갓 출발한 비행기가 이륙하기까지 걸리는 시간은 거의 15~20분 정도로 일정했다. 택싱 내지 대기 시간이 그만치 걸린다는 뜻이다.

11. 순항: 이제 비행기 안에서 즐거운 시간을 보내는 일만 남았다. 거리에 따라서 기내식이 한두 번 나올 것이고, 일부 노선의 경우 면세품을 파는 카트도 돌 것이다. 기내식은 식사도 있고 음료수+과자 간식도 있다.
아 그리고, 입국 신고서도 여행 중에 배부된다. 당신이 불법 체류자가 아닌 정당한 여행객인지(님의 신분은? 입국 후 어디 체류할 예정?), 생물학적으로 위험한 물품을 반입하고 있는지, 세관에 신고해야 할 귀중품이 있는지 등을 아주 형식적으로 조사하는 것이다. 대부분 해당 사항이 없는 질문들에 답변하여 입국 심사 때 제출하면 된다.

비행기에도 승객이 바깥 경치 좀 구경하라고 창문이 있다. 하지만 비행기 창문은 모든 교통수단들 중 가장 작으며 그 이유는 더 설명할 필요가 없을 것이다. 이착륙 중일 때는 승무원들이 돌아다니면서 창문을 다 열어 달라고 하며, 반대로 긴 시간 순항 모드일 때는 자는 승객도 있고 하니 창문을 닫아 놓고 기내를 전반적으로 깜깜하게 해 놓는다. 따라서 객실 조명에 관한 한 비행기는 고속버스와 비슷한 셈이다.
(당연한 말이지만 비행기 창문을 연다는 말은 블라인드로 가려졌던 유리창을 보이게 한다는 뜻하는 말이지, 바깥 공기와 객실 공기 사이를 개방한다는 뜻은 절대 아님. ㅋㅋㅋ)

지금 모든 대중교통들이 그렇듯이 비행기 내부에서도 흡연은 엄격히 금지이다. 특히 화장실 안에서 몰래 피우는 건 금기 1순위이다. 담배 연기가 화재로 오인이라도 됐다간 망신 톡톡히 당한다. 아예 담배 자체를 기내 반입 금지 물품으로 분류하는 건 아닌가 모르겠다. 라이터는 말할 것도 없고!
몇십 년 전만 해도 간접 흡연 때문에 폐암 걸린 스튜어디스가 소송 제기까지 했었는데 세상 참 많이 변했다.

※ 글을 맺으며

비행기 몇 번 타 보지도 않았는데 그래도 생생한 기억이 남아 있어서 몇 자 정리해 보았다. 착륙 쪽은 쓰자니 너무 힘들어서.. 여기까지만. -_-

그 집채만한 배가 바다에 어떻게 떠 다니는지는 솔직히 이해가 된다. 배만 중력이 있는 게 아니라 유체에도 중력이 있으며, 근본적으로 물도 그렇게 호락호락 가벼운 물질이지는 않기 때문이다. 하지만, 그 집채만한 비행기가 어떻게 하늘로 뜰 수 있는지는 나는 아직까진 도저히 이해를 못 하겠다. 그냥 무슨무슨 법칙과 수학 공식으로 설명을 하더라도 내 마음으로 "실감"이 가지는 않는다. 더구나 그냥 뜨는 것도 모자라 전투기 에어쇼 같은 건 도대체 어떻게 하는지??

오늘날의 고정익 비행기는 정말 잘 통제된 아슬아슬한 조건 하에서만 뜰 수 있다. 새처럼 자기만 혼자 곱게 뜨는 게 아니라 주변에 온갖 side effect를 남기기 때문에 정말 깔끔하게 잘 정돈된 활주로도 필요하며 주변에 아무것도 없어야 한다.

조류 충돌 같은 건 상상도 하기 싫은 악몽이다. 엔진이 풀로 돌아가고 있는 팬으로 불순물이 빨려 들어갔다간 작살 난다. 그래서 화산이 폭발해도 화산재와 먼지가 무서우니 그쪽은 피해서 비행해야 하고, 심지어 비행기 위에 쌓인 눈도 깨끗이 청소해야 한다. 눈 때문에 무거워서가 아니라, 눈이 쌓임으로써 비행기 날개의 표면 외형을 왜곡하여 날개가 만들어내는 양력 효율을 크게 떨어뜨리기 때문이다.

비행기 활주로는 무거운 비행기의 착륙 충격을 견딜 수 있게 일반 도로보다 훨씬 더 튼튼하고 특수하게 건설된다. 비행기 타이어도 자동차 타이어보다 훨씬 더 비싸고 고급 재질로 만들어지며 교환 주기가 짧다. 타이어 내부에는 화재의 요인을 원천 봉쇄하기 위해, 산소가 전혀 없이 비활성 기체인 질소만으로 100% 주입한다. 물론 지구 대기도 이미 80%가 질소이긴 하지만.
비행기 타이어가 터지면 터진 부분만 땜질한다는 건 있을 수 없는 일이며, 전체를 교체해야 한다. 한번 착륙을 수행한 비행기는 타이어가 굉장히 열과 무리를 많이 받아 있기 때문에, 몇 시간씩 식히고 쉬게 해 줘야 한다.

V1 속도를 넘어서면 이륙을 중단할 수 없이 무조건 떠야 하며, 연료 소비를 감안하여 이륙할 때와 착륙할 때의 허용 무게도 다 정해져 있다. 그래서 이륙했다가 곧장 다시 착륙하면 아직 연료 때문에 비행기가 많이 무거운 상태인지라 활주로와 비행기에 심한 무리를 줄 수 있다.
이런 이유로 인해 비행기는 긴급 환자 발생 같은 비상 사태로 인해 목적지에 도달하지 못하고 조기 착륙할 경우, 선회 비행을 하면서 아깝지만 연료를 버려야 한다. 어떻게든 정상 운항 후 착륙할 때와 같은 무게를 맞춰야 하기 때문에.

정말 복잡하지 않은가?
이래서 사람이 만든 날개는 역시 신이 만든 날개보다는 불완전한 건지도 모르겠다.
사냥꾼의 총에 맞아 추락한 새가 땅에 떨어지면서 폭발과 화재를 일으키지는 않는다는 게 대단하다. =_=;;

사용자 삽입 이미지
사용자 삽입 이미지

Posted by 사무엘

2010/01/11 09:57 2010/01/11 09:57
, , ,
Response
No Trackback , No Comment
RSS :
http://moogi.new21.org/tc/rss/response/78

가는달, 굵은달, 버금달, 둥근모, 뻗음, 짧은둥근모, 짧은뻗음 (도깨비):
  모두 90년대 김 중태 님의 작품이다. 도스용 PC 통신 프로그램 이야기에도 이런 계보의 글꼴을 다수 볼 수 있었다.
특히 둥근모와 뻗음 류의 글꼴은 개인적으로도 무척 좋아하며, 심지어 전철 전광판에서도 볼 수 있다.

바탕, 가는돋움, 가는샘물, 필기 (custom):
  도스용 아래아한글 1.x가 제공하던 화면용 글꼴의 명조, 고딕, 샘물, 필기에 각각 해당한다. 고정된 도깨비 식 조합 테이블이 아니라 <날개셋> 5.3에서 첫 도입된 custom 조합 테이블을 사용했으며, 바탕과 샘물은 아래아한글 1.x 수준의 간단한 옛한글도 표현할 수 있다.
글꼴에 맞게 튜닝된 조합 테이블을 내장하고 있을 뿐더러 상업용 프로그램에서 사용되기도 한 만큼 글꼴의 품질은 무척 좋은 편이다. 다만, 다음에 나올 5.31에서 가는돋움은 아래아한글의 그 고딕체과 유사한 느낌이면서 더 깔끔하고 보기 좋은 다른 글꼴로 대체될 예정이다.

이야기체 (도깨비):
  한메 타자교사와 이야기 5.3이 사용하여 아주 널리 알려진 그 글꼴이다. 식상한 명조 고딕 류에서 탈피했고 나름 가독성도 좋아서 무척 잘 만든 글꼴이란 생각이 든다.

한솔바탕 (도깨비):
  도스용 수채화 2.x에서 유일하게 본 걸로 기억한다. 이것도 꽤 참신한 디자인이고 그럭저럭 쓸 만하다.

파도, 가는파도, 흘린둥근고딕 (도깨비):
  이 글꼴들은 화면용 16*16뿐만 아니라 출력용 자형도 있어서 아래아한글 HFT로도 변환되어 쓰였던 것 같다.

마소바탕 (custom):
  과거 MSHBIOS가 내부적으로 사용하던 글꼴을 완벽하게 재현한 것으로, 윈도우 3.1의 완성형 바탕체 글꼴의 짝퉁이라 할 수 있다. 조합 규칙이 도깨비와 살짝 다른 면이 있다. 미려한 것 같으면서도 철저하게 테스트를 안 하고 대충 어설프게 디자인을 끝냈다는 느낌을 지울 수 없다. 뭔가 2% 부족한 게 느껴지는 글꼴이다.

샘물2 (custom):
  박 정만 님이 제작한 2*1*2벌 샘물 계열 글꼴로, 도깨비 조합 규칙도 너무 널널하기 때문에 자체 조합 테이블을 내장시켜 글꼴 파일의 크기를 4KB가 채 안 되게 줄였다. 정사각형 안에서 공간을 최대한 활용하다 보니 다른 샘물 계열 글꼴에 비해 글자가 좀 납작하다는 인상은 받는다. 현재 <날개셋> 한글 입력기의 내장 글꼴은 정 재민 님이 이 글꼴을 다듬어 굵기를 줄이고 옛한글 자모를 추가한 것이다.

굽은샘물 (custom):
  도깨비 조합 규칙을 쓰는 공개 글꼴인데 실제로 사용되는 벌수는 3*1*2벌밖에 되지 않기 때문에 자체 조합 테이블 방식으로 파일 구조를 대체했다. 글자의 전반적인 느낌은 무척 깔끔하고 참신하지만 ㅔ, ㅐ, ㅗ 같은 모음과 자음을 변별하기 어려운 점이 좀 아쉽다.

타자기 (custom):
  무려 2*1*1벌로, <날개셋> 한글 입력기가 제공하는 글꼴 중 구조가 가장 초단순하다. 아래아한글 1.x 수준의 옛한글 자모까지 일부 있음에도 불구하고 크기는 겨우 4KB밖에 되지 않는다.

굴림옛한글 (custom):
  트루타입 글꼴의 내부에 있는 옛한글 비트맵 자형을 추출한 것으로, <날개셋> 5.x가 지원하는 유니코드 5.2 옛한글을 거의 다 그것도 네모꼴 글꼴로 표현할 수 있는 유일한 글꼴이다. 물론 초중종 벌수는 6*2*4벌로, 도깨비보다도 벌 수가 적으며 글자가 전반적으로 좀 엉성하긴 하다.

유사굴림 (custom):
  다음 5.31 버전에서 추가될 예정인 글꼴로, "굴림체" 16픽셀을 얼추 조합형 글꼴로 본뜬 짝퉁이다. 현대 한글 11172자밖에 표현할 수 없지만 크기는 무려 40KB를 넘어서 "굴림 옛한글" 수준에 육박하는데, 이는 조합 테이블의 크기가 굉장히 크며 초성 하나, 모음 하나가 10여 벌, 20여 벌에 달하는 경우도 있기 때문이다. 가장 정교하고 복잡한 조합 테이블을 사용하는 글꼴이다.
다른 글꼴들은 초성은 겨우 ㄱㅋ, 종성은 ㄴ 정도만 따로 분리하여 그룹을 나누는 반면 이 글꼴은 거의 모든 자소들이 분할되어 있으며 자형 활용의 폭이 가장 크다. 가령 다른 글꼴들은 농과 논, 통과 톤에서 ㅗ의 위치가 다 같지만, 이 글꼴은 다 다르다. 그렇기 때문에 글자 하나의 완성도 하나는 이 글꼴이 가장 뛰어나다.

도깨비 방식,
그리고 도깨비보다 간단한 글꼴 내지 더 복잡한 글꼴.
<날개셋> 편집기는 한글 입력 방식뿐만 아니라 출력 방식도 과거와 현재의 만남의 장이 되고 있다.

Posted by 사무엘

2010/01/11 09:56 2010/01/11 09:56
,
Response
No Trackback , No Comment
RSS :
http://moogi.new21.org/tc/rss/response/77

« Previous : 1 : ... 210 : 211 : 212 : 213 : 214 : 215 : 216 : 217 : 218 : ... 221 : Next »

블로그 이미지

그런즉 이제 애호박, 단호박, 늙은호박 이 셋은 항상 있으나, 그 중에 제일은 늙은호박이니라.

- 사무엘

Archives

Authors

  1. 사무엘

Calendar

«   2024/12   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31        

Site Stats

Total hits:
3047849
Today:
1011
Yesterday:
2058