모바일 오유 바로가기
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
    조회수 : 1380
    IP : 222.233.***.246
    댓글 : 1개
    등록시간 : 2018/12/22 00:30:15
    http://todayhumor.com/?programmer_22748 모바일
    const 한정자는 좋은 코딩 습관의 기초
    좋은 코딩 습관은 무엇일까요? 그것이 무엇인지 잘 모르겠지만 아마 이런 것을 만족할 것 같습니다.<br><ul><li>적절한 수준에서 적확한 동작을 보증한다</li> <li>같은 결과를 낸다면 작성자의 의도를 잘 드러낸다</li></ul><br>일반적으로 C 언어의 구조체를 선언할 때 자료형의 크기로 몰아서 위쪽으로 배치하는 것이 좋은 습관입니다. 대부분의 C 언어 구현에서 컴파일러가 가장 쉽고 빠르게 구조체의 멤버들에 접근할 수 있도록 크기가 큰 멤버를 기준으로 삼습니다. 이것을 C 언어 컴파일러와 프로그래머 사이의 일종의 "계약"이라고 생각해볼 수도 있습니다. 이러한 계약을 실행할 때 자료형의 크기가 제각각인 멤버들이 흩어져있으면 메모리의 낭비가 생깁니다. 또, 특별히 압축하라고 지정하지 않은 구조체에서는 각각의 멤버 사이에 낭비되는 공간이 있을 수도 있습니다. 이러한 "계약조건"은 프로그래머가 반드시 이해하고 있어야 합니다.<br><br>특별히 압축하라고 지정하지 않은 구조체에서 각각의 멤버가 낭비되는 메모리 공간 없이 연속되어 있을것이라는 "추측" 또는 "기대"로 프로그래머가 메모리에 접근한다면, 컴파일러의 관점에서 프로그래머가 "계약을 위반"하는 것입니다. 컴파일러는 프로그래머의 의도를 추측해서 동작하지 않습니다. 구조체가 차지하는 메모리의 낭비를 없애거나 줄이려면, 프로그래머는 구조체를 압축하라고 특별히 지시하거나 또는 메모리 낭비를 줄이도록 수동으로 멤버들의 위치를 지정해야 합니다. 따라서, 자료형의 크기로 몰아서 위쪽으로 배치하는 것은 일반적으로 좋은 프로그래밍 습관입니다.<br><br>이 습관은 언제나 좋은 것일까요? C 언어의 구조체 멤버들은 단 한개의 예외를 제외하고 모든 자료형의 크기가 고정되어 있습니다. (그 단 한개의 예외도 비교적 최신 규약에서야 포함된 것입니다.) 그 예외를 사용하지 않는 일반적인 C 언어의 구조체 크기는 고정되어 있습니다. C++ 의 클래스는 C 언어의 구조체에 해당합니다. 그것도, 크기를 쉽게 알 수 없는 다른 클래스들이 중첩되어 포함된 구조체라고 생각해도 됩니다. 상속으로 물려받은 메모리 공간을 생각하지 않더라도, 그 내부에서 접근성이 다른 여러 멤버가 있습니다. 메모리 낭비를 줄여보겠다고 프라이빗 멤버들과 퍼블릭 멤버들을 뒤섞어서 배치하면 이해하기 어려운 코드가 될 수도 있습니다. 메모리 낭비를 많이 줄일 수 있는 것도 아니고요. C 언어의 좋은 습관이 C++ 에서는 크게 유용하지 않습니다.<br><br>좋은 습관에 대한 평가는 상황에 따라 바뀝니다. 대단히 오래동안 저는 변수의 사용을 억제하는 것이 좋은 습관이라고 믿어왔습니다. 적절히 이름을 붙이는 것, 즉 변수를 사용하면 코드를 쉽게 읽을 수 있습니다. 그러나 컴퓨터는 한정된 레지스터만을 가지고 있고 메모리의 내용을 레지스터에 적재하고 필요할 때 레지스터를 교체하는 것, 즉 변수를 사용하는 것에 비용이 듭니다. 성능을 생각한다면 변수의 사용을 억제하는 것이 좋은 습관인 것 같습니다. 그렇지 않습니다!! 컴파일러가 최적화 과정을 거치면서 불필요한 레지스터 사용을 스스로 조절합니다. 또한, 프로그램은 대개 최적화 컴파일 과정을 거친 다음 실행됩니다. 최적화 컴파일을 일부러 하지 않는 경우가 아니라면 프로그래머가 변수의 사용에 제약을 받을 이유가 없습니다. 프로그래머의 의도를 잘 드러내는 이름을 주는 것이 더 좋은 습관입니다.<br><br>함수의 사용은 어떨가요? 일반적으로 함수 호출은 변수 사용보다 더 큰 비용이 듭니다. 따라서, 함수 호출을 억제하고 지역 변수로 복사해서 쓰는 것이 더 좋은 습관인 것 같습니다. 여기에 미묘한 점이 있습니다. 복사본의 값이 계속 유효한 것이라면 지역 변수를 쓰는 것이 이득입니다. 그런데, 복사본의 값이 언제까지 유효한 것인지에 대한 고려가 필요합니다. 복사본의 값이 유효하지 않는 일이 생기지 않는다는, 즉 "기대"가 어긋나거나 "계약"에 위배되는 상황이 없을 것이란 "확신" 또는 "확인"이 필요합니다. 이것을 확인하려고 다시 그 함수를 호출해야한다면 배보다 배꼽이 큰 일입니다. 누군가 믿을만한 존재가 그것을 보증해주는 것이 좋겠습니다.<br><br>보증을 하려해도 확인이 필요합니다. 어떤 것을 변경하지 않았다는 보증을 하려면 그 전의 상태와 지금의 상태가 같다는 것을 확인해야합니다. 변경할 능력이 없는 경우는 어떨까요? 확인할 필요도 없을 것입니다.<br><br>예를 들어...<br><code>int const SIZE = 10;</code><br>로 선언된 SIZE 라는 변수는 일반적으로 그 함수 내부에서 변경할 능력이 없습니다. <code>SIZE = 20</code> 란 구문은 에러를 냅니다. 포인터의 경우는 어떨까요?<br><code>int size1 = 10;</code><br><code>int size2 = 20;</code><br><code>int* const SIZE_PTR = &size1;</code><br>로 선언된 변수들 사이에서 <code>SIZE_PTR = &size2</code> 는 에러를 냅니다. 그런데, <code>*SIZE_PTR = size2</code> 는 허용되는 구문입니다. SIZE_PTR 이 size1 을 가르켜야 된다는 것은 const 로 한정했지만, 그 내용을 바꾸는 것을 한정하지는 않았습니다. 가르키고있는 size1 도 변경이 가능한, 즉 const 로 한정되지 않은 변수입니다.<br><br>조금 다른 예 입니다.<br><code>int const SIZE1 = 10;</code><br><code>int const SIZE2 = 20;</code><br><code>const int* size_ptr = &SIZE1;</code><br>이 경우 <code>size_ptr = &SIZE2</code> 는 허용되지만, <code>*size_ptr = SIZE2</code> 는 에러를 냅니다. 한정사 const 가 int* 를 한정하고 있지만 포인터 변수 자체의 변경을 제한하고 있지는 않기 때문입니다. 만일, <code>const int* const SIZE_PTR = &SIZE1</code> 이었다면 모두 금지되었을 것입니다. 이렇게 지역 변수들을 한정하는 것은 의도를 명백하게해서 실수를 방지하는 효과가 있습니다. 조금 관점을 달리하죠.<br><br><code>size_t getSize (struct MY* const THIS) { THIS->size = 10; return THIS->size; }</code><br>라는 함수는 THIS 의 size 라는 멤버를 변경하고 그 값을 돌려줍니다. 그런데,<br><code>size_t getSize (const struct MY* const THIS) { THIS->size = 10; return THIS->size; }</code><br>는 허용되지 않습니다. 오직,<br><code>size_t getSize (const struct MY* const THIS) { return THIS->size; }</code><br>만 허용됩니다. (const 를 주의해서 보세요.) 따라서, 이런 종류의 함수만 사용한다면 THIS 의 멤버들이 변경되지 않는다는 것을 확신할 수 있습니다. 물론, 예외는 있습니다. 내부적으로 캐스트 연산을 해서 const 한정을 벗어난다거나...<br><br>다시 말하지만 C++ 의 클래스는 C 의 구조체에 해당합니다. 만일 MY 가 구조체가 아니라 클래스였다면 getSize() 매소드가 이런 식으로 쓰였을 것입니다. (같은 기능을 하는 함수가 어떻게 표현되는지 const 의 위치를 비교해보세요.)<br><code>size_t MY::getSize (void) const { return this->size; }</code><br><br>이런 종류의 다른 const 함수를 사용하는 동안은 지역 변수로 복사한 값은 확인할 필요도 없이 계속 유효합니다. 함수 호출을 하지 않는만큼 이득이겠죠. 그런데, 또... 만일 getSize() 함수가 인라인 된다면 그리 큰 이득을 볼 수는 없습니다. 그게 그거니까요 :)<br><br>어쨌든, 실수를 방지하고 확신을 줄 수 있다는 점에서 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 초과시 해당없음)

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

    번호 제 목 이름 날짜 조회 추천
    23195
    [질문] riscv32-unknown-elf-gcc memory map 본인삭제금지 어린이바이엘 20/11/09 11:24 628 0
    23194
    sql 디벨로퍼 질문이있습니다..ㅠㅜㅠ [1] 따까디스코 20/11/08 17:32 875 0
    23193
    c# wpf 의 그리드에 관한질문입니다 [2] 본인삭제금지 뭐꼬 20/11/08 11:03 922 0
    23192
    유니티 어디서 배울까요 [2] Dev_땅콩 20/11/07 22:58 704 0
    23191
    Visual Studio에서 NuGet 패키지관리 오류.. [3] 달려라하니~ 20/11/04 11:43 2275 0
    23189
    안녕하세요 제가 국비지원 6개월학원다니고 취업준비중인데 조언좀요.. ㅜㅜ [11] 딱다구리마요 20/10/29 13:25 1728 1
    23185
    안녕하세요 초보 개발자 입니다. C# 메모리 Exception질문드립니다 [3] 부산영 20/10/20 16:29 772 0
    23184
    안녕하세요 프로그래머지망생입니다. 상담받고 싶어서 이렇게 글씁니다. [10] 초co 20/10/19 21:18 1075 0
    23183
    파이썬 질문입니다. se1251 20/10/16 20:28 789 0
    23180
    자료구조 책 추천 부탁드립니다. 본인삭제금지 Minion 20/09/17 23:26 959 0
    23176
    redis 오류 관련 문의드립니다. [3] 본인삭제금지 순정있는남자 20/09/07 16:21 872 0
    23175
    크롬 버그(파란색 커서) [3] 마지막연금술 20/09/05 18:09 1156 0
    23173
    sendmail 설정 관련 질문 있습니다! [5] 본인삭제금지 소독제 20/09/03 10:23 762 0
    23172
    1 나를읽어줘 20/09/03 00:40 828 1
    23171
    1인개발한 소프트웨어, 어떻게 홍보하면 좋을까요ㅠㅠ & adobe CEP [8] 빠라빠라 20/09/02 17:21 1319 2
    23170
    음성관련 프로그램 공부를 해보려고 하는데 막막하네요;; [2] 임당이 20/09/02 00:57 700 0
    23169
    비쥬얼 스튜디오 2015 Professional 설치 파일 있으신분.. [2] 야광눈 20/08/27 16:21 923 0
    23168
    C언어 쌉초보자입니다. 이 코드 왜 안되는지 모르겠습니다. [4] llallin 20/08/27 13:15 1440 1
    23167
    닷넷 c# winform 에 콘솔창을 붙일수있는방법 없을까요? [2] 본인삭제금지 엿먹이기 20/08/19 22:41 1113 0
    23165
    윈도우 hosts 파일에 대한 질문 [1] 본인삭제금지 dbf62 20/08/12 15:15 860 0
    23163
    C# 하드코딩으로 사운드 만드는법??? [2] 한시운 20/08/08 17:46 1198 0
    23162
    앱을 만들려고 하는데, 어떤 프로그램이 좋을까요? [4] 본인삭제금지 endwhy 20/08/07 19:45 1099 0
    23160
    jsp 네이버 로그인 연동하고 있는데 토큰 관련 질문 있습니다 ㅠㅠㅠ [1] 토왕 20/08/06 13:44 734 0
    23159
    전역 후 공무원 준비냐 학부 공부 준비냐 고민중입니다. [5] 본인삭제금지 삶은토마토 20/07/31 17:25 861 0
    23158
    어떤프로세스에서 알림광고를 띄우는지 알아내는방법있으면 [1] 본인삭제금지 뭐꼬 20/07/29 06:26 793 0
    23157
    초보의 클레스에 대한 딜레마 존.(feat.Winform With C#) [2] 창작글펌글베스트금지베오베금지 꽃게뢍 20/07/27 15:37 995 0
    23154
    네이버 아이디 로그인 연동 질문 ... ㅠㅠ 본인삭제금지 토왕 20/07/15 12:26 731 0
    23153
    c# 에서의 날짜 디비저장 과 웹에서 날짜 표시... [3] 베스트금지베오베금지본인삭제금지 뭐꼬 20/07/12 00:32 1246 0
    23152
    mysql 한글 300글자는 컬럼을 varchar,text 중 뭘로.. [2] 레드워터 20/07/11 15:58 990 0
    23151
    프로그래밍 노트북... 3개중 하나 정해주십쇼...ㅠㅠ [30] 본인삭제금지 삶은토마토 20/07/08 18:33 1836 2
    [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [다음10개▶]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈