모바일 오유 바로가기
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도쿄올림픽
  • 게시판찾기
  • 오유인페이지
    개인차단 상태
    ★☆님의
    개인페이지입니다
    가입 : 17-07-17
    방문 : 493회
    닉네임변경 이력
    회원차단
    회원차단해제
    게시물ID : programmer_22748
    작성자 : ★☆
    추천 : 2
    조회수 : 1375
    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 초과시 해당없음)

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

    번호 제 목 이름 날짜 조회 추천
    897
    윈도우 원격 데스크톱과 Xrdp 서버 사이에 클립보드 공유 실패 ★☆ 19/01/19 03:39 116 0
    896
    [emacs] 글꼴 설정 [2] ★☆ 19/01/18 08:52 83 1
    895
    [emacs] EXWM 간단히 맛보기(?), 냄새 맡기(?), 암튼 소개 ★☆ 19/01/08 05:59 116 1
    894
    나의 기본 Makefile [2] ★☆ 18/12/29 06:24 120 4
    893
    [gcc] 적용되는 옵션 플래그 확인하기 ★☆ 18/12/26 22:51 73 0
    892
    [gcc] 어셈블리 코드 보기 [11] ★☆ 18/12/26 18:08 104 0
    const 한정자는 좋은 코딩 습관의 기초 [1] ★☆ 18/12/22 00:30 78 2
    890
    [gcc] 의미없어 보이지만 의미심장한 (X)+0 그리고 함수 오버로딩 [6] ★☆ 18/12/21 07:40 108 2
    889
    재미있는 상황?? [1] ★☆ 18/10/12 18:23 63 0
    888
    아빠가 너무 나대요... [5] 펌글 ★☆ 18/10/12 15:29 2104 12
    887
    저금통 샀다고 와잎한테 쳐맞은 남편... [4] 펌글 ★☆ 18/10/11 18:44 2099 19
    886
    관악산에 노루가 뛰논다를 영어로?(feat. 서울대 법대 합격하는 법) [5] 펌글 ★☆ 18/10/10 23:58 1662 12
    885
    ㅈ간지 연출 [6] 펌글 ★☆ 18/10/10 23:53 2018 10
    884
    뒤틀린 학구열 [2] 펌글 ★☆ 18/10/10 23:50 1667 14
    883
    웃대가 오유 먹었다 야호 [4] 펌글 ★☆ 18/10/10 23:38 1127 17
    882
    귀여운 약사를 만난 루리웹 유저 [6] 펌글 ★☆ 18/10/10 23:26 1497 18
    881
    미대생의 농락 ㅋㅋㅋㅋㅋㅋㅋㅋㅋ [2] 펌글 ★☆ 18/10/10 23:11 1622 15
    880
    군필자가 세금으로 배워온 기술 [6] 펌글 ★☆ 18/10/10 23:01 1618 16
    879
    마법사 세계에서 포켓몬이 금지인 이유 [1] 펌글 ★☆ 18/10/10 22:51 1197 5
    878
    조별과제 침대 빌런 [7] 펌글 ★☆ 18/10/10 22:39 1420 15
    877
    이거 방울토마토 맞음? 펌글 ★☆ 18/10/10 22:30 883 5
    876
    입뺀 당한 김희철 [2] 펌글 ★☆ 18/10/10 22:23 1133 10
    875
    32살이나 먹고 똥을 지린 남자 [12] 펌글 ★☆ 18/10/10 22:15 1554 11
    874
    무술의 천재 [2] 펌글 ★☆ 18/10/10 22:11 1190 11
    873
    환장의 호흡 feat.웃대 [10] 펌글 ★☆ 18/10/10 22:04 872 10
    872
    북한 야동사이트 접속기록 통계 [10] 펌글 ★☆ 18/10/10 21:53 1741 10
    871
    북서유럽과 동남유럽의 차이 [2] 펌글 ★☆ 18/10/10 21:42 1287 7
    870
    경계가 너무 심한 중고나라 [3] 펌글 ★☆ 18/10/10 21:38 1446 19
    869
    소개팅 직업 레전드 [2] 펌글 ★☆ 18/10/10 21:34 1411 10
    868
    흔한 뇌가 히토미류 甲 [14] 펌글 ★☆ 18/10/10 21:23 1415 14
    [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [다음10개▶]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈