디시인사이드 갤러리

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

갤러리 본문 영역

유지 보수가 어렵게 코딩 하는 방법 읽어봣냐?

허허벌판갤로그로 이동합니다. 2011.09.09 11:21:30
조회 195 추천 0 댓글 8



이 책을 보고 웃는 사람은 프로그래머 밖에 없을듯

여튼 재밌다 ㅋㅋㅋㅋ 한번 읽어봐





이름 짓기

험프티 덤프티(Humpty Dumpty)는 다소 경멸적인 어조로 말했다. "내가 단어를 사용할 때에는 더도 덜도 아닌 딱 그 의미를 전달하려는 것이다."
- Through the Looking Glass, 6 장 중에서(루이스 캐롤(Lewis Carroll) 지음)
변수와 메소드의 이름을 짓는 방법은 유지보수 할 수 없는 코드를 작성하는데 있어 상당히 중요한 기술이다. 이름은 컴파일러에 영향을 주지 않는다. 이름 짓기 기술로 유지보수 프로그래머의 정신을 혼미하게 만들 수 있다.

태아 작명법의 새로운 용도

태아 작명법 서적을 구입하자. 그러면 변수명을 뭐로 지어야 할지에 대한 고민을 덜 수 있을 것이다. Fred는 멋진 이름이며 입력하기도 쉽다. 입력이 쉬운 변수명을 원한다면 asdf를 사용해 보기 바란다.

단일 문자 변수명

변수명을 a, b, c 등으로 정한다면 간단한 텍스트 편집기로 해당 인스턴스를 검색하는데 애를 먹게 된다. 뿐만 아니라 그 변수가 무엇에 쓰이는 것인지 추측할 수 없게 방지하는 역할도 한다. 포트란(FØRTRAN)에서는 오랫동안 I, j, k를 인덱스 변수로 사용해왔다. 혹시라도 이러한 훌륭한 전통을 조금이라도 깨뜨리려는(예를 들어, ii, jj, kk 등으로 이름을 변경하려는) 사람이 있는가? 스페인 종교재판에서 이교도에게 어떠한 형벌을 가했는지를 그에게 경고하자.

창의적 오타

어쩔 수 없이 뭔가를 설명하는 변수명이나 함수명을 사용해야 하는 상황이라면 오타라는 무기를 선택하자. 몇몇 함수명과 변수명에 오타를 내고 다른 곳에서는 오타를 사용하지 않는다면(예를 들어, SetPintleOpening과 SetPintalClosing처럼) grep이나 IDE 검색 기술을 효과적으로 무력화할 수 있다. 이 방법은 생각보다 놀라운 효과를 발휘한다. 각기 다른 theatres/theaters(둘 다 극장을 의미)에 tory나 tori같이 국제적인 취향도 추가해본다.

추상화하라

가능한 한 it, everything, data, handle, stuff, do, routine, perform, 숫자 등과 같이 추상적인 단어를 변수명이나 함수명에 많이 사용하자(좋은 예, routineX48, PerformDataFunction, DoIt, HandleStuff, do_args_method).

머.리.글.자.

머리글자로 코드를 간결하게 만든다. 진짜 사나이는 머리글자를 풀어 설명하지 않고 있는 그대로를 선천적(유전적)으로 이해한다.

진화한 유의어 사전

유의어 사전에서 되도록이면 많은 단어가 같은 동작(예를 들어, 뭔가를 보여준다는 의미를 가진 display, show, present 등과 같은)을 가리키도록 하는 것도 지루함을 달랠 좋은 방법 중 하나다. 실제 의미상 차이가 없는 단어라 할지라도 알 듯 말듯하게 모호한 힌트를 제공하는 것도 잊지 말자. 때로는 비슷한 두 함수가 완전 다른 동작을 하는 경우가 있다. 이러한 경우에는 두 함수를 같은 단어로 설명한다(예를 들면, "파일 기록", "종이에 잉크 칠하기", "화면에 보여주기"를 print라는 한 단어로 설명할 수 있다). 어떤 경우에도 명확한 어휘를 사용해 특수 프로젝트에 사용할 용어집을 만들어 달라는 요구에 굴복하지 말아야 한다. 이러한 요구에 굴복하는 행위는 정보 은닉(information hiding)이라는 구조화된 디자인 원칙을 위반하는 프로답지 못한 행동이다.

다른 언어의 복수형을 사용하라

VMS 스크립트는 "Vaxen(Vax 컴퓨터의 복수형)"에서 반환하는 다양한 "statii(status의 복수형)"를 추적한다. 에스페란토(현재는 거의 쓰이지 않는 인공어), Klington(스타 트렉에 등장하는 전사 종족의 언어), Hobbitese(소설에 등장하는 가상 종족 호빗의 언어) 등을 사용하면 보다 효율적이다. Pluraloj와 같이 단어 뒤에 oj를 추가해서 에스페란토 어를 모방할 수 있다. 이러한 에스페란토를 사랑하는 작은 노력이 세계 평화에 기여하는 것임을 기억하자.

새로운 개념의 낙타표기법(CapiTaliSaTion)

무작위로 단어의 중간 음절 첫 글자를 대문자로 표기하자. 예를 들면 ComputeRasterHistoGram()처럼 메소드 명을 정할 수 있다.

이름을 재사용하라

언어의 규칙이 허용하는 범위 내에서 클래스, 생성자, 메소드, 멤버 변수, 파라미터, 지역 변수에 같은 이름을 사용하자. 이에 안주하지 말고 더 나아가서 {} 블록 내에서 이미 사용되고 있는 지역 변수명을 재사용할 수 있는지 고민하자. 이렇게 함으로써 유지보수를 담당하는 프로그래머가 모든 인스턴스의 범위를 유심히 살펴보도록 만들 수 있다. 특히 자바 언어에서는 일반 메소드를 생성자처럼 보이게 할 수 있다.

강세가 있는 단어

변수명에 강세가 표시된 단어를 사용하자. 아래 코드를 살펴보면,

typedef struct { int i; } int;
두 번째 int에서 i 에 강세가 있다. 간단한 텍스트 편집기로는 미묘한 차이를 구별하는 것이 거의 불가능하다.
컴파일러의 이름 길이 제한을 악용하라

컴파일러가 인식할 수 있는 변수명의 길이는 정해져 있다. 만약 변수명의 8글자만을 인식할 수 있는 컴파일러가 있다면, var_unit_update()과 var_unit_setup()처럼 마지막 부분만 살짝 바꿔보자. 그럼 컴파일러는 두 이름을 동일한 var_unit으로 인식할 것이다.

밑줄(underscore)은 진정한 친구다

_와 __를 식별자로 사용하자.

언어를 혼용하라

두 언어(사람의 언어나 컴퓨터의 언어)를 무작위로 배치하자. 만약 상사가 자신의 언어를 사용할 것을 강요한다면 어떻게 할 것인가? 상사에게 나만의 언어를 사용해야 생각을 더 잘 정리할 수 있다고 설명하자. 신사적인 설명으로 해결되지 않는다면? 언어 차별 행위에 대해 이의를 제기하고, 당장 고용주를 고소를 할 수도 있으며 거액의 배상금을 내야 하는 상황에 처할 수 있다고 협박하자.

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 모태 솔로도 구제해 줄 것 같은 연애 고수 스타는? 운영자 25/07/21 - -
AD 곧 휴가!! 홈캉스, 바캉스 SALE 운영자 25/07/21 - -
269617 디씨어플 그렇게 만만하게 보이나?? [2] 시불라미갤로그로 이동합니다. 11.09.04 132 0
269616 선심쓴다. 요번 플젝만 끝나면 디씨 어플하나 만들어주마. [1] 쵸쵸(219.251) 11.09.04 56 0
269613 오 드디어 제대로 깔렸다 비쥬얼 스튜디오 아오 2010호환성 맛이갔어 [2] 사고편향형ADHD갤로그로 이동합니다. 11.09.04 86 0
269612 있잖아 형들 군대가는데 [1] (121.188) 11.09.04 59 0
269611 조공] 프로그래머한테 어떤 인맥이 중요하냐? [5] t(222.107) 11.09.04 275 0
269610 여자들이 제일 좋아하는 화장품.jpg [1] ㅇㅇ(222.107) 11.09.04 170 0
269609 조만간 spring light 버젼이 나올거 같다. 쵸쵸(219.251) 11.09.04 44 0
269608 디씨어플 병맛이쩌네 [2] 쵸쵸(219.251) 11.09.04 100 0
269607 프갤은 정전 로하로하알로하갤로그로 이동합니다. 11.09.04 49 0
269606 MFC로 멀티스레드 프로그램을 만들어보려 하는데. [1] 쩡꾸갤로그로 이동합니다. 11.09.04 121 0
269605 동정깨고 싶은 형들 봐봐 [3] (121.188) 11.09.04 163 0
269604 디바이드 앤 컨쿼 알고리즘 질문좀 할게여 헿 [4] 라솔갤로그로 이동합니다. 11.09.04 148 0
269603 3d 테트리스 [12] 뇌지랄갤로그로 이동합니다. 11.09.04 215 0
269602 고슬링은 왜 더빠른 jvm을 만들려하지않음? 박구갤로그로 이동합니다. 11.09.04 81 0
269601 리눅스에서 notepad++ 쓸수 없나? [9] devdev(180.228) 11.09.04 152 0
269600 SI 업계랑 게임 업계랑 비교하면, 어디가 더 매출이 많나요? [2] ㅇㅇ(222.107) 11.09.04 184 0
269598 죄송한데 이것좀 [2] ㅠㅠ(118.37) 11.09.04 54 0
269596 방금전 c질문올린거 답안인데요 [5] CCCC(121.172) 11.09.04 65 0
269595 프겔에 오신것을 환영합니다 낯선 라솔이여 [4] 생각놀이갤로그로 이동합니다. 11.09.04 99 0
269594 풀 ajax 사이트를 만들어볼테다. 쵸쵸(219.251) 11.09.04 60 0
269593 헠헠 형들 한국어로 다시 설명함 새로운 조공 [11] 라솔갤로그로 이동합니다. 11.09.04 186 0
269592 C로간단하게 주사위굴리는거 하나 만들고싶은데 어떻게하는지점 가르쳐줘형들 [6] 우하하(122.37) 11.09.04 114 0
269591 개강이라 그런지 [2] 막장갤신학생갤로그로 이동합니다. 11.09.04 62 0
269590 형들 흔한 컴공 3학년인데여 과제하다가 간단한거 질문좀 ㅠ 조공있어여 [7] 라솔갤로그로 이동합니다. 11.09.04 250 0
269589 자바 경로설정이요ㅠㅠ [1] r(211.246) 11.09.04 85 0
269588 Backtrack4는 무슨프로그램? [3] 바크갤로그로 이동합니다. 11.09.04 77 0
269587 C질문이여 [9] CCCC(121.172) 11.09.04 89 0
269586 겜공과... 게임 만드는거 좋아하는데 어떤가요? [15] 조언좀여(211.52) 11.09.04 315 0
269585 C언어 비트자리수가 몇인지 알수 있는 함수 있냐? [2] 나도밥줘용(180.70) 11.09.04 145 0
269583 울집 인터넷속도 이거 광랜 맞음? [4] asdf(182.213) 11.09.04 102 0
269582 심형래닮은 쉑이 또와서 설치네 ㅋㅋㅋ 쵸쵸(219.251) 11.09.04 60 0
269580 사람들 진짜 재밌네.. 1(121.182) 11.09.04 56 0
269578 진저브래드의 G메일 앱 있자나 분당살람갤로그로 이동합니다. 11.09.04 55 0
269577 프밍은 역시 독학이 甲인듯 ㅎㅎ [2] ㅎㅎ(115.23) 11.09.04 246 0
269576 한가한 일요일 오후네 [5] monoless갤로그로 이동합니다. 11.09.04 102 0
269572 asp.net 에서 컴파일 된 소스들 만 있는데 DB 연결부분이 어디인지 [1] ㅜㅠ(112.219) 11.09.04 63 0
269571 결국 32bit 윈도우로 설치합니다 ㄴㅁ(210.107) 11.09.04 44 0
269569 컴퓨터공학 은 어떤 책으로 공부해야 할까요? [21] cool하니갤로그로 이동합니다. 11.09.04 201 0
269567 실내건축으로 전과 하기로 맘 먹음 [1] 찌질이23(121.140) 11.09.04 81 0
269566 학교에서 c++로 자료구조 하는데 이책'C로배우는 알고리즘'사도 돼? [2] cool하니갤로그로 이동합니다. 11.09.04 163 0
269564 자바 기초질문 한번만 더 봐주세영 [5] 우뮤갤로그로 이동합니다. 11.09.04 103 0
269563 해커들은 찌질이들 같아요. [1] (221.143) 11.09.04 130 0
269562 C++에 대한 저의 생각과 미래 [2] 읗헣(210.101) 11.09.04 153 0
269561 어셈코드 보는데 스택부분 이해가 잘안되네 [16] 어셈(175.116) 11.09.04 215 0
269559 새 집 구했다. [2] 외계달팽갤로그로 이동합니다. 11.09.04 98 0
269558 프갤형님들 저 자바스크립트 입문하는 찌레기인데 질문좀 [3] 우뮤갤로그로 이동합니다. 11.09.04 93 0
269557 64bit 운영체제에서 32bit 라이브러리 사용하기 ㄴㅁ(210.107) 11.09.04 98 0
269556 오늘 날씨 무지 좋다 나가자 [1] 거칠게갤로그로 이동합니다. 11.09.04 74 0
269555 진짜 신이란게 존재할까? [3] 우ㅈ갤로그로 이동합니다. 11.09.04 124 0
269554 그와중에 2011 8월 프로그래밍 언어 순위 [1] 어쩌다가(221.155) 11.09.04 210 0
뉴스 우디, 23일 '대충 입고 나와' 일본어 버전 발매…감성 고백송으로 설렘 전한다  디시트렌드 07.22
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2