Offcanvas

애플리케이션 / 오픈소스 / 자기계발

개발자가 애용하는 나쁜 프로그래밍 습관 9가지

2015.11.03 Peter Wayner  |  InfoWorld


프로그래밍 습관 7 : 중간에 루프 탈피
언제인가 루프에는 루프 안에서 항상 '참'이 되는 논리 명령문을 일컫는 '불변식(invariant)'이 있어야 한다는 규칙이 생겼다. 불변식이 더 이상 '참'이 아닐 경우 루프가 끝난다. 복잡한 루프를 생각하면 좋다. 그러나 우리를 미치게 만드는 제약이다. 루프 중간에 Return이나 Break를 사용할 수 없도록 만든다. Goto 명령문을 금지하는 규칙의 하위 규칙이다.

이론으로는 그럴듯하다. 그러나 통상 코드를 복잡하게 만든다. 테스트를 통과한 엔트리 어레이 스캔을 생각해보자.

while (i<a.length){
...
if (test(a[i]) then return a[i];
...
}


루프 불변식을 좋아하면 itnotFound 같은 Boolean 변수를 다음 방식으로 추가해 이용할 것이다.

while ((notFound) && (i<a.length){
...
if (test(a[i])) then notFound=false;
...
}


Boolean의 이름이 좋다면, 좋은 자가 문서화 코드가 된다. 누구나 쉽게 이해할 수 있다. 그러나 코드가 더 복잡해진다. 여기에 또 다른 로컬 변수를 할당, 컴파일러가 수정할 수 없을지도 모르는 레지스터의 복잡성이 초래된다. 때론 Goto나 Jump가 더 깔끔한 코드를 만든다.

프로그래밍 습관 8 : 짧은 변수 이름 이용(i와 x라면 타당)
에드가 알렌 포우는 모든 단어에 하나의 결론이 있어야 한다고 말했다. 이에 그의 글에 담긴 단어는 모두 독자에게 뭔가를 말한다. 코딩에 관한 규칙도 동일하다. 각 변수의 이름은 기능과 이유를 설명해야 한다. 자바 프로그래머는 변수가 하는 일을 자세히 설명하기 위해 아주 긴 이름을 사용하고 있다. 단어 5개 이상으로 변수 이름을 짓는 프로그래머들도 있다.

그러나 때론 한 글자의 변수명이 더욱 간편한 상황도 있다. 때론 Iteration과 Loop를 설명하기 위해 i나 j를 사용하는 것이 더욱 간편한 상황도 있다. 때론 Array와 List에 각각 a와 I(1과 구분이 힘들어질 경우라도)를 사용하는 것이 더욱 간편한 상황도 있다.

앞부분에서 긴 주석 대신 자가 문서화 코드를 사용할 것을 장려했다. 이 경우 한 글자의 변수명이 자가 문서화 기능을 한다. Iterator를 가리키는 변수명은 예외 없이 i이다. 현명한 프로그래머라면 이를 즉시 알 것이다.

프로그래밍 습관 9 : Operator와 Function 재정의
가장 흥미로운 언어 가운데 일부는 정말 이상한 일을 할 수 있도록 허용하고 있다. 확실해 보이는 요소의 값을 재정의하는 것을 의미한다. 예를 들어, 파이썬(Python) 2.7 이전 버전의 경우 TRUE=FALSE라고 입력할 수 있었다. 이로 인해 논리가 붕괴되지 않는다. 단지 'True and False'를 대체한 표현일 뿐이다. C 전처리기와 다른 언어에도 이런 '위험한 게임'이 있다. 플러스 기호 같은 Operator를 재정의할 수 있는 언어들도 있다.

소위 확실한 표현을 하나 이상 재정립하는 것이 빠른 상황들이 있다. 때론 상사가 완전히 다른 방식으로 기능하는 코드를 원할 수 있다. 물론 코드 곳곳을 살펴 바꿀 수 있다. 이는 개발자를 천재처럼 보이도록 만들 것이다. 그러나 방대한 라이브러리를 바꾸는 대신 반대의 일을 할 수 있다.

여기에서 선을 긋는 것이 좋다. 집에서는 이를 시도하지 말기 바란다. 솔직히 말해 너무 위험하다.  editor@itworld.co.kr

CIO Korea 뉴스레터 및 IT 트랜드 보고서 무료 구독하기
Sponsored
추천 테크라이브러리

회사명:한국IDG 제호: CIO Korea 주소 : 서울시 중구 세종대로 23, 4층 우)04512
등록번호 : 서울 아01641 등록발행일자 : 2011년 05월 27일

발행인 : 박형미 편집인 : 천신응 청소년보호책임자 : 한정규
사업자 등록번호 : 214-87-22467 Tel : 02-558-6950

Copyright © 2024 International Data Group. All rights reserved.