C에서 음수를 처리하는 방법 (feat. 2의 보수, 2's compliment)
1. 우선 2의 보수가 무엇인지 알아보자.
2의보수란 어떤 수를 커다란 2의 제곱수에서 빼서 얻은 이진수이다. 2의 보수는 프로그래밍 언어에서 음수처럼 취급된다. 여기서 말하는 음수는 이러하다. 기본적으로 프로그래밍은 0과 1로 표현할 수 밖에 없는데 그렇다면 음수를 표현할 수가 없어서 2의 보수를 음수로 사용하는 것이다. 음수를 사용할때는 MSB는 부호를 표현하는 bit로 남겨두고 나머지 bit를 통해 수를 표현한다.
2. 2의 보수 구하는걸 해보자.
2의 보수는 1의 보수를 통해 구하면 된다. 6자리의 이진수(011100)의 2의보수를 구해보자.
2.1 한자리수 큰 2진수로 2의보수 구하기
1000000 (64) --> 7자리 2진수
-) 011100 (28)
------------------
100100 (36)
2.2 1의보수를 이용하여 2의보수 구하기
모든 자리수를 반전한다. 이를 1의 보수라고 한다. 여기에 1을 더하면 2의보수가 된다.
011100 -> 100011 -> 100100
* 보수를 구하며 한 자리가 더 길어진 경우 MSB bit를 버린다.
3. C에서 어떻게 사용되는지 (다른 프로그래밍 언어들)
C에는 다양한 변수들이 있는데 unsigned를 안사용하는 변수는 음수를 표현할 수 있는 변수들이다.
예를들어 int같은 경우는 32bit인데 MSB는 부호를 나타내는 것이고 나머지는 수를 나타낼 수 있다.
즉 unsigned byte 같은 경우 0~255 byte는 -127~127 까지 표현이 가능하다.