모바일 오유 바로가기
http://m.todayhumor.co.kr
분류 게시판
베스트
  • 베스트오브베스트
  • 베스트
  • 오늘의베스트
  • 유머
  • 유머자료
  • 유머글
  • 이야기
  • 자유
  • 고민
  • 연애
  • 결혼생활
  • 좋은글
  • 자랑
  • 공포
  • 멘붕
  • 사이다
  • 군대
  • 밀리터리
  • 미스터리
  • 술한잔
  • 오늘있잖아요
  • 투표인증
  • 새해
  • 이슈
  • 시사
  • 시사아카이브
  • 사회면
  • 사건사고
  • 생활
  • 패션
  • 패션착샷
  • 아동패션착샷
  • 뷰티
  • 인테리어
  • DIY
  • 요리
  • 커피&차
  • 육아
  • 법률
  • 동물
  • 지식
  • 취업정보
  • 식물
  • 다이어트
  • 의료
  • 영어
  • 맛집
  • 추천사이트
  • 해외직구
  • 취미
  • 사진
  • 사진강좌
  • 카메라
  • 만화
  • 애니메이션
  • 포니
  • 자전거
  • 자동차
  • 여행
  • 바이크
  • 민물낚시
  • 바다낚시
  • 장난감
  • 그림판
  • 학술
  • 경제
  • 역사
  • 예술
  • 과학
  • 철학
  • 심리학
  • 방송연예
  • 연예
  • 음악
  • 음악찾기
  • 악기
  • 음향기기
  • 영화
  • 다큐멘터리
  • 국내드라마
  • 해외드라마
  • 예능
  • 팟케스트
  • 방송프로그램
  • 무한도전
  • 더지니어스
  • 개그콘서트
  • 런닝맨
  • 나가수
  • 디지털
  • 컴퓨터
  • 프로그래머
  • IT
  • 안티바이러스
  • 애플
  • 안드로이드
  • 스마트폰
  • 윈도우폰
  • 심비안
  • 스포츠
  • 스포츠
  • 축구
  • 야구
  • 농구
  • 바둑
  • 야구팀
  • 삼성
  • 두산
  • NC
  • 넥센
  • 한화
  • SK
  • 기아
  • 롯데
  • LG
  • KT
  • 메이저리그
  • 일본프로야구리그
  • 게임1
  • 플래시게임
  • 게임토론방
  • 엑스박스
  • 플레이스테이션
  • 닌텐도
  • 모바일게임
  • 게임2
  • 던전앤파이터
  • 마비노기
  • 마비노기영웅전
  • 하스스톤
  • 히어로즈오브더스톰
  • gta5
  • 디아블로
  • 디아블로2
  • 피파온라인2
  • 피파온라인3
  • 워크래프트
  • 월드오브워크래프트
  • 밀리언아서
  • 월드오브탱크
  • 블레이드앤소울
  • 검은사막
  • 스타크래프트
  • 스타크래프트2
  • 베틀필드3
  • 마인크래프트
  • 데이즈
  • 문명
  • 서든어택
  • 테라
  • 아이온
  • 심시티5
  • 프리스타일풋볼
  • 스페셜포스
  • 사이퍼즈
  • 도타2
  • 메이플스토리1
  • 메이플스토리2
  • 오버워치
  • 오버워치그룹모집
  • 포켓몬고
  • 파이널판타지14
  • 배틀그라운드
  • 기타
  • 종교
  • 단어장
  • 자료창고
  • 운영
  • 공지사항
  • 오유운영
  • 게시판신청
  • 보류
  • 임시게시판
  • 메르스
  • 세월호
  • 원전사고
  • 2016리오올림픽
  • 2018평창올림픽
  • 코로나19
  • 2020도쿄올림픽
  • 게시판찾기
  • 게시물ID : programmer_22748
    작성자 : ★☆
    추천 : 2
    조회수 : 1491
    IP : 222.233.***.246
    댓글 : 1개
    등록시간 : 2018/12/22 00:30:15
    http://todayhumor.com/?programmer_22748 모바일
    const 한정자는 좋은 코딩 습관의 기초
    좋은 코딩 습관은 무엇일까요? 그것이 무엇인지 잘 모르겠지만 아마 이런 것을 만족할 것 같습니다.
    • 적절한 수준에서 적확한 동작을 보증한다
    • 같은 결과를 낸다면 작성자의 의도를 잘 드러낸다

    일반적으로 C 언어의 구조체를 선언할 때 자료형의 크기로 몰아서 위쪽으로 배치하는 것이 좋은 습관입니다. 대부분의 C 언어 구현에서 컴파일러가 가장 쉽고 빠르게 구조체의 멤버들에 접근할 수 있도록 크기가 큰 멤버를 기준으로 삼습니다. 이것을 C 언어 컴파일러와 프로그래머 사이의 일종의 "계약"이라고 생각해볼 수도 있습니다. 이러한 계약을 실행할 때 자료형의 크기가 제각각인 멤버들이 흩어져있으면 메모리의 낭비가 생깁니다. 또, 특별히 압축하라고 지정하지 않은 구조체에서는 각각의 멤버 사이에 낭비되는 공간이 있을 수도 있습니다. 이러한 "계약조건"은 프로그래머가 반드시 이해하고 있어야 합니다.

    특별히 압축하라고 지정하지 않은 구조체에서 각각의 멤버가 낭비되는 메모리 공간 없이 연속되어 있을것이라는 "추측" 또는 "기대"로 프로그래머가 메모리에 접근한다면, 컴파일러의 관점에서 프로그래머가 "계약을 위반"하는 것입니다. 컴파일러는 프로그래머의 의도를 추측해서 동작하지 않습니다. 구조체가 차지하는 메모리의 낭비를 없애거나 줄이려면, 프로그래머는 구조체를 압축하라고 특별히 지시하거나 또는 메모리 낭비를 줄이도록 수동으로 멤버들의 위치를 지정해야 합니다. 따라서, 자료형의 크기로 몰아서 위쪽으로 배치하는 것은 일반적으로 좋은 프로그래밍 습관입니다.

    이 습관은 언제나 좋은 것일까요? C 언어의 구조체 멤버들은 단 한개의 예외를 제외하고 모든 자료형의 크기가 고정되어 있습니다. (그 단 한개의 예외도 비교적 최신 규약에서야 포함된 것입니다.) 그 예외를 사용하지 않는 일반적인 C 언어의 구조체 크기는 고정되어 있습니다. C++ 의 클래스는 C 언어의 구조체에 해당합니다. 그것도, 크기를 쉽게 알 수 없는 다른 클래스들이 중첩되어 포함된 구조체라고 생각해도 됩니다. 상속으로 물려받은 메모리 공간을 생각하지 않더라도, 그 내부에서 접근성이 다른 여러 멤버가 있습니다. 메모리 낭비를 줄여보겠다고 프라이빗 멤버들과 퍼블릭 멤버들을 뒤섞어서 배치하면 이해하기 어려운 코드가 될 수도 있습니다. 메모리 낭비를 많이 줄일 수 있는 것도 아니고요. C 언어의 좋은 습관이 C++ 에서는 크게 유용하지 않습니다.

    좋은 습관에 대한 평가는 상황에 따라 바뀝니다. 대단히 오래동안 저는 변수의 사용을 억제하는 것이 좋은 습관이라고 믿어왔습니다. 적절히 이름을 붙이는 것, 즉 변수를 사용하면 코드를 쉽게 읽을 수 있습니다. 그러나 컴퓨터는 한정된 레지스터만을 가지고 있고 메모리의 내용을 레지스터에 적재하고 필요할 때 레지스터를 교체하는 것, 즉 변수를 사용하는 것에 비용이 듭니다. 성능을 생각한다면 변수의 사용을 억제하는 것이 좋은 습관인 것 같습니다. 그렇지 않습니다!! 컴파일러가 최적화 과정을 거치면서 불필요한 레지스터 사용을 스스로 조절합니다. 또한, 프로그램은 대개 최적화 컴파일 과정을 거친 다음 실행됩니다. 최적화 컴파일을 일부러 하지 않는 경우가 아니라면 프로그래머가 변수의 사용에 제약을 받을 이유가 없습니다. 프로그래머의 의도를 잘 드러내는 이름을 주는 것이 더 좋은 습관입니다.

    함수의 사용은 어떨가요? 일반적으로 함수 호출은 변수 사용보다 더 큰 비용이 듭니다. 따라서, 함수 호출을 억제하고 지역 변수로 복사해서 쓰는 것이 더 좋은 습관인 것 같습니다. 여기에 미묘한 점이 있습니다. 복사본의 값이 계속 유효한 것이라면 지역 변수를 쓰는 것이 이득입니다. 그런데, 복사본의 값이 언제까지 유효한 것인지에 대한 고려가 필요합니다. 복사본의 값이 유효하지 않는 일이 생기지 않는다는, 즉 "기대"가 어긋나거나 "계약"에 위배되는 상황이 없을 것이란 "확신" 또는 "확인"이 필요합니다. 이것을 확인하려고 다시 그 함수를 호출해야한다면 배보다 배꼽이 큰 일입니다. 누군가 믿을만한 존재가 그것을 보증해주는 것이 좋겠습니다.

    보증을 하려해도 확인이 필요합니다. 어떤 것을 변경하지 않았다는 보증을 하려면 그 전의 상태와 지금의 상태가 같다는 것을 확인해야합니다. 변경할 능력이 없는 경우는 어떨까요? 확인할 필요도 없을 것입니다.

    예를 들어...
    int const SIZE = 10;
    로 선언된 SIZE 라는 변수는 일반적으로 그 함수 내부에서 변경할 능력이 없습니다. SIZE = 20 란 구문은 에러를 냅니다. 포인터의 경우는 어떨까요?
    int size1 = 10;
    int size2 = 20;
    int* const SIZE_PTR = &size1;
    로 선언된 변수들 사이에서 SIZE_PTR = &size2 는 에러를 냅니다. 그런데, *SIZE_PTR = size2 는 허용되는 구문입니다. SIZE_PTR 이 size1 을 가르켜야 된다는 것은 const 로 한정했지만, 그 내용을 바꾸는 것을 한정하지는 않았습니다. 가르키고있는 size1 도 변경이 가능한, 즉 const 로 한정되지 않은 변수입니다.

    조금 다른 예 입니다.
    int const SIZE1 = 10;
    int const SIZE2 = 20;
    const int* size_ptr = &SIZE1;
    이 경우 size_ptr = &SIZE2 는 허용되지만, *size_ptr = SIZE2 는 에러를 냅니다. 한정사 const 가 int* 를 한정하고 있지만 포인터 변수 자체의 변경을 제한하고 있지는 않기 때문입니다. 만일, const int* const SIZE_PTR = &SIZE1 이었다면 모두 금지되었을 것입니다. 이렇게 지역 변수들을 한정하는 것은 의도를 명백하게해서 실수를 방지하는 효과가 있습니다. 조금 관점을 달리하죠.

    size_t getSize (struct MY* const THIS) { THIS->size = 10; return THIS->size; }
    라는 함수는 THIS 의 size 라는 멤버를 변경하고 그 값을 돌려줍니다. 그런데,
    size_t getSize (const struct MY* const THIS) { THIS->size = 10; return THIS->size; }
    는 허용되지 않습니다. 오직,
    size_t getSize (const struct MY* const THIS) { return THIS->size; }
    만 허용됩니다. (const 를 주의해서 보세요.) 따라서, 이런 종류의 함수만 사용한다면 THIS 의 멤버들이 변경되지 않는다는 것을 확신할 수 있습니다. 물론, 예외는 있습니다. 내부적으로 캐스트 연산을 해서 const 한정을 벗어난다거나...

    다시 말하지만 C++ 의 클래스는 C 의 구조체에 해당합니다. 만일 MY 가 구조체가 아니라 클래스였다면 getSize() 매소드가 이런 식으로 쓰였을 것입니다. (같은 기능을 하는 함수가 어떻게 표현되는지 const 의 위치를 비교해보세요.)
    size_t MY::getSize (void) const { return this->size; }

    이런 종류의 다른 const 함수를 사용하는 동안은 지역 변수로 복사한 값은 확인할 필요도 없이 계속 유효합니다. 함수 호출을 하지 않는만큼 이득이겠죠. 그런데, 또... 만일 getSize() 함수가 인라인 된다면 그리 큰 이득을 볼 수는 없습니다. 그게 그거니까요 :)

    어쨌든, 실수를 방지하고 확신을 줄 수 있다는 점에서 const 한정자를 적극적으로 쓰는 것은 분명히 좋은 코딩 습관입니다.

    이 게시물을 추천한 분들의 목록입니다.
    [1] 2018/12/26 02:21:49  39.117.***.159  파다기  153687
    [2] 2018/12/27 15:03:29  125.128.***.86  봄아  636602
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

    죄송합니다. 댓글 작성은 회원만 가능합니다.

    번호 제 목 이름 날짜 조회 추천
    23461
    로또 [2] 까망사투리 25/02/12 13:13 429 2
    23459
    C++ 입문전 초보자입니다. Qt / wxWidgets / FLTK 어떤 [6] OMG! 24/12/07 00:28 943 0
    23458
    [KOCCA] 2024 게임콘텐츠 제작지원 이용자평가 체험단모집 장파랑 24/11/26 16:56 926 0
    23457
    [한국콘텐츠진흥원] 2024 게임콘텐츠 제작지원 이용자평가 이용자 모집 장파랑 24/11/18 14:02 959 0
    23456
    [한국콘텐츠진흥원] 2024 게임콘텐츠 제작지원 이용자평가 이용자 모집 장파랑 24/10/28 18:24 1358 0
    23455
    논문 읽는 사람들을 위한 문서 번역 서비스 rWhale 24/10/10 13:06 1688 2
    23453
    로또번호 [2] 까망사투리 24/09/19 11:10 2317 2
    23452
    AI와 함께가는 코딩 업계 [1] 펌글 우가가 24/09/02 22:19 2563 9
    23451
    Switch문 도배된 2100줄 짜리 함수 [4] 펌글 우가가 24/08/26 22:37 2426 4
    23450
    개인정보 수집 없는 이미지 리사이즈 사라밍 24/08/23 20:31 1833 0
    23449
    디자인 패턴의 템플릿 메소드 패턴 실무 적용 사례 [1] 써니썬 24/08/23 16:47 1843 1
    23448
    TMDB API Key 얻을 때 동의하게 되는 면책 및 포기 조항 우가가 24/08/18 16:07 1848 1
    23447
    펌) 아무튼 개쩌는 번역기를 국내기술로 개발완료 했다는 소식 [1] 펌글 우가가 24/08/15 17:30 2114 2
    23446
    쿠팡 가격 변동 추적 알림 서비스 피드백 요청 (제발) 창작글펌글 애오옹 24/08/10 14:30 2063 0
    23445
    넥사크로 17.1 관련 [2] 본인삭제금지 나르하나 24/08/01 12:30 2050 0
    23444
    개밯자 의자에 머리받침 없어 [2] 까망사투리 24/07/25 13:32 2442 1
    23443
    안드로이드 EditText 리스너 연동 문의드립니다. - 해결됨 [1] 창작글 상사꽃 24/07/01 17:47 2314 2
    23442
    펌) 파이어폭스 엔진이 신인 이유 [1] 펌글 우가가 24/06/30 23:25 2916 2
    23441
    예전에는 함수 하나에 대한 기능에 고민을 많이 했는데.. ssonacy 24/05/21 09:45 2680 0
    23440
    c++ 에서 DB 쿼리문처럼 사용할 방법이 있을까요? [8] 상사꽃 24/05/19 11:10 2836 0
    23439
    쉬운 배터리 알림 창작글 언젠가아자 24/05/14 10:47 2970 0
    23438
    아후 서터레스 [1] NeoGenius 24/04/02 17:52 2654 1
    23436
    로또 [3] 까망사투리 24/03/11 15:53 3336 4
    23434
    copilot 기업유료버전 intelliJ에 붙여서 쓰고있는데 지리네요 안녕월드 24/02/22 00:15 3342 0
    23433
    코딩마을 대나무숲 [6] cocoa 24/02/20 14:50 3509 5
    23432
    (질문) 프로그래머분들은 싱글PC게임 레벨제한 풀수 있죠?? [23] 본인삭제금지 할배궁디Lv2 24/02/13 13:36 3519 1
    23431
    Freemium NeoGenius 24/02/13 13:23 2951 0
    23429
    부산에서 프로그래머 구인하는데 연봉 6천에서 8천 작은건가 [3] 폴팡 24/02/04 20:50 3861 1
    23427
    chatgpt? bard? [3] 별빛러브 24/01/25 06:24 3086 0
    23426
    Next.js로 만들어봤어요~ [2] 창작글 sonnim 24/01/24 12:52 3323 3
    [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [다음10개▶]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈