inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C언어

3.6 정수의 오버플로우

signed int의 오버플로우 질문입니다

262

이승환

작성한 질문수 11

0

8비트를 예를 들어 8비트의 최댓값이 127이므로 +1을 하면  

1000/0000이 되야하는데 부호가있는 8비트 정수에서는 앞이 1이면 안되지 않나요? 근데 컴파일해보니 1000/0000이렇게 뜨는데 이건 부호가있는 정수에서는 -128아닌가요? 헷갈립니다( 32비트를 8비트로 줄여서 말씀드립니다)

c

답변 1

1

안소

안녕하세요.

-128 맞습니다. -128이 나오는 이 현상이 바로 오버플로우입니다.

가장 왼쪽의 비트를 부호 비트로 쓰는 signed인 8비트의 최대값은 127이고 최소값은 -128입니다. 즉 음수를 표현할 수 있는 8비트로는 [-128, 127] 범위를 가지는 것입니다.

이때 char같은 8비트 크기의 자료형에 최대값 127을 넘는 127 + 1 인 128을 넣어준다고 가정해보겠습니다. signed한 8bit로는 128을 표현할 수 없기 때문에 오버플로우가 발생하여 오히려 표현할 수 있는 범위의 최소값인 -128로 돌아가 -128가 되는 것입니다. 최대값 범위를 벗어나면 그 값을 표현할 수가 없어 오히려 최소값으로 다시 순환되는 이러한 현상이 바로 오버플로우입니다. 그래서 127+1을 8bit 공간에 넣으면 오히려 최저값인 -128, 즉 10000000 이 되버리는 것이 맞습니다.

만약 127+4 = 131 를  8bit 자료형에 입력했으면 4만큼 오버플로우가 된 것이니까 최저값으로 돌아가서 -128에서 네번째인 -125가 되겠습니다. 

완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.

1

50

3

main 함수에서 왜 int만 선언이 되는걸까요

1

54

2

8비트 2진수 변환시 왜 1을 더해야하나요?

1

54

2

혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?

1

48

1

프로토타입과 함수간의 인자 불일치

1

72

2

12.12 헤더 관련 질문

1

59

2

Visual Studio Community 2026 사용 문의

1

136

2

Q. 15:30, 부호가 있는 8비트 정수 질문

1

59

2

getchar(), putchar()

1

92

3

강의자리ㅛ

1

78

2

비주얼스튜디오코드로 공부해도 상관없나요?

1

112

2

소스파일안에 여러 파일

1

75

2

F5와 F7의 차이

1

75

2

c = TWO * (a+b); 에서 a와 b는?

1

58

2

; 세미콜론을 붙이는 기준에 문의

1

68

1

Step over 기능 문의

1

53

2

2.6 강의 따옴표 출력 규칙 문의

1

74

2

int main 함수 관련 오류 문의

1

67

2

13.4 words[0]

0

60

2

11.7 함수를 구현해 봤습니다.

1

62

2

11.6 직접 strcmp와 strncmp를 구현해 보았습니다.

1

64

2

11.6 my_strcat과 my_strncat을 구현해봤습니다.

1

53

2

11.6 fit_str함수를 구현해 봤습니다.

1

53

2

11.5 코드 구현

1

67

2