모바일 오유 바로가기
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도쿄올림픽
  • 게시판찾기
  • 오유인페이지
    개인차단 상태
    ansi5120님의
    개인페이지입니다
    가입 : 13-04-28
    방문 : 1490회
    닉네임변경 이력
    회원차단
    회원차단해제
    게시물ID : programmer_5206
    작성자 : ansi5120
    추천 : 3/8
    조회수 : 2714
    IP : 72.53.***.30
    댓글 : 27개
    등록시간 : 2014/08/29 11:06:00
    http://todayhumor.com/?programmer_5206 모바일
    왜 C에서 bool을 쓰면 안 되는가?


    문제는 C++에서 bool을 쓰던 사람들이 C 코드를 만질 때 일어납니다.

    32비트 시스템을 상정하면,

    int는 보통 32비트 즉 4바이트의 메모리를 차지합니다.
    char는 8비트 즉 1바이트의 메모리를 차지합니다.
    bool도 8비트 즉 1바이트의 메모리를 차지합니다.

    C에서는 bool이 없습니다. 

    스탠다드 라이브러리를 써보신 분들은 아시겠지만 리턴값은 대부분 size_t(unsigned int)입니다.
    C99 스탠다드인 stdbool.h에선 _Bool에 대한 마스크로 씁니다. 이는 unsigned int로 치환됩니다.

    사실 여기까지는 괜찮습니다. 이것도 굳이 필요 없는데 C++의 영향으로 많이들 후술할 매크로를 쓰니 어쩔 수 없이 우겨넣은 겁니다.


    제가 문제를 제기하는 bool을 쓰는 사람들은 이런 매크로를 씁니다.

        typedef char bool;

    그리고 이런 식으로 사용합니다.
        bool foo = strfind(strarg, strcontext);

    만일 strfind가 포인터를 리턴하고, 찾은 포인터의 제일 뒷 8 비트가 0이라면 문제가 됩니다.
    가령 0xffae4200같은 포인터가 나온다면, 8비트로 변환했을 때는 0x00이 나옵니다.

    재미있는 건 이런 매크로를 쓰는 사람들은 십중팔구는 이런 매크로와 같이 쓰거든요.

        #define true 1        #define false 0       ....         if (foo == true)         ....         /* do_something */

    C에 bool을 넣는 건, 주지하다시피 C++에서 bool을 쓰기 시작함으로서입니다.
    많은 사람들이 참/거짓을 쓸 때 4바이트(2바이트)짜리 int를 쓰다가 공간을 아낌과 동시에 쓰임새도 뚜렷한(BOOLean) 타입을 선호하게 됐습니다.
    그러다 보니 C에서도 bool을 쓰려는 시도가 잦아졌고, 결국 stdbool.h이 탄생했던 겁니다.

    문제는 이 컨벤션이 너무 늦게 나왔습니다.
    엔간한 라이브러리는 죄다 C89 스탠다드일 때 쓰여졌습니다.
    참/그름을 밝히는 라이브러리 함수나 포인터를 리턴하는 함수들을 찾아보세요.

    전부
        #define NULL 0
    이나
        #define NULL ((void*)0)
    을 씁니다.

    C에서 참과 그름을 밝히는 컨벤션은 거의 없습니다.
    그르거나(NULL) 그르지 않은(포인터가 있는) 걸 분간해낼 뿐입니다.
    그렇지 않은 건 죄다 99년 이후에 쓰여진 코드가 많습니다.


    물론, C++에선 bool을 쓰는 게 옳습니다.
    하지만 C에선 역사적 이유도 있을 뿐더러, 생각 않고 쓰다간 치명적인 버그를 낼 위험성이 있습니다.

    그냥 쓰지 마세요.


    물론 임베디드 등 메모리 비트 하나하나까지 다 써야 하는 경우가 있긴 있습니다.
    비트 필드나 유니온이 바로 그럴 때 쓰이는 겁니다.
    굳이 쓰고 싶으시면 char가 아닌 int,
    혹은 uint32, 가장 권장되는 방법은 size_t가 되겠습니다.

    뭐 string 오퍼레이션에 쓰는 경우라면 unitptr_t을 써도 되긴 합니다만...

    여하튼 BOOLEAN의 뜻은 애초에 TRUE와 FALSE로 나뉘는 이분법입니다.
    C에선 FALSE와 NOT FALSE로 나뉘는 이분법입니다.

    BOOLEAN의 정의가 부합하지 않아요. 학구적으로도 이건 아닙니다.



    (전에 썼던 글 수정 조금 해서 C&P해왔습니다.)

    이 게시물을 추천한 분들의 목록입니다.
    [1] 2014/08/29 11:17:54  121.143.***.81  황금비  483546
    [2] 2014/08/29 13:49:47  180.231.***.96  HTML소스보기  102953
    [3] 2014/08/29 16:15:01  175.120.***.226  슝슝3  284767
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

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

    번호 제 목 이름 날짜 조회 추천
    79
    허위 무고가 왜 문제냐면 [3] ansi5120 17/08/03 11:15 72 12
    78
    왜 StringBuilder가 필요한가? [7] ansi5120 15/04/05 17:31 53 5
    77
    Java를 쓰면서 들이면 곤란한 습관들 [18] ansi5120 15/04/05 06:54 103 8/4
    76
    그러니까 퀄리티가 떨어지는 질문은 무시하는게 상책이죠. [7] ansi5120 15/04/04 23:55 46 4/9
    75
    워드프레스는 좋은 코드가 아니죠 [18] ansi5120 15/02/21 00:38 54 5/5
    74
    멍청한 질문이 보기 싫으면 [3] ansi5120 15/02/06 14:45 58 3
    73
    시한폭탄 (수정) [14] ansi5120 15/02/06 13:05 69 2/5
    72
    음 그러니까 C로 시작할 필요 없다니까요. [14] ansi5120 15/02/03 15:55 100 4
    71
    한국어 스택오버플로우 좋죠. [11] ansi5120 15/02/03 11:18 83 4
    70
    마테마티카 평가 [6] ansi5120 15/01/25 13:18 53 13
    69
    굳이 C로 시작할 필요 없습니다. [11] ansi5120 15/01/10 16:46 69 6
    68
    광고알바도 온 김에 아이티뱅크 홍보해보죠. [5] ansi5120 15/01/09 16:26 24 10
    67
    네 반박해보죠. [23] ansi5120 15/01/09 13:41 94 11
    66
    베오베 갈 '흥했으나 몰락의 길을 걸었던 나라...' 로마사 반박. [4] ansi5120 14/12/18 12:41 124 50
    65
    이제는 싫어하는 것도 대세인가 [6] ansi5120 14/11/22 16:12 153 6
    64
    미성년때 야겜이야 다들 한번씩은 해봤겠죠. [5] ansi5120 14/10/01 03:31 152 4
    63
    캐나다는 유토피아가 아닙니다. [10] ansi5120 14/09/12 00:43 67 17
    62
    대학 다니던 때 유일하게 알고 지내던 한국사람 왈. ansi5120 14/09/11 23:07 62 4
    왜 C에서 bool을 쓰면 안 되는가? [27] ansi5120 14/08/29 11:06 94 3/8
    60
    그러니까 그냥 답을 하지 말아요. [1] ansi5120 14/08/26 02:49 80 0
    59
    혹시 창룡전 개정판 중고 매물 아시는 분 있으십니까. ansi5120 14/01/07 09:12 22 0
    58
    '책 몇권이나 읽었냐'와 비길 정도로 신경질나는 질문은 ansi5120 14/01/07 09:03 58 7/5
    57
    2005년 페이스북에서 누출된 서버사이드 코드 ansi5120 13/11/01 11:39 51 0
    56
    개발자의 권익 옹호라던지 거창한 말이 가끔 나오는데 [3] ansi5120 13/10/30 10:52 74 1
    55
    소달구지씨에게 [1] ansi5120 13/10/29 12:09 54 0
    54
    프로그래머가 되는데 학위는 필수불가결이 아닙니다. [7] ansi5120 13/10/27 23:01 68 2
    53
    오늘의덕담씨에게 ansi5120 13/10/27 22:48 23 0
    52
    도고씨에게 ansi5120 13/10/24 09:32 44 0
    51
    건담 대화. [7] ansi5120 13/10/21 13:33 78 3
    50
    확실히 영웅 삼국지 이후로는 [1] ansi5120 13/10/21 13:30 24 0
    [1] [2] [3]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈