Microsoft MVP성태의 닷넷 이야기
.NET Framework: 345. C# 부호(+, -)에 대한 비트 변환 [링크 복사], [링크+제목 복사],
조회: 23560
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

C# 부호(+, -)에 대한 비트 변환

오늘은 기초적인 것에 대해 한번 설명해 볼까 합니다. 꼭 C# 에만 해당하는 것은 아니고 (-)를 2의 보수로 표현하는 모든 컴퓨터 프로그래밍 언어가 이런 변환을 거치게 됩니다.

자... 일단 Int32의 178을 예로 들어 보면 2진수로 다음과 같이 표현됩니다.

178 == 10110010

그런데, 이것을 signed byte (sbyte)로 변환하면 -78로 표현됩니다. 왜 그럴까요? 이에 대해서는 178을 2의 보수로 연산했던 것을 역으로 다시 계산해 주면 됩니다. (참고로 C#은 byte가 unsigned이지만, 자바는 byte가 signed 입니다.)

Int32 == 178       == 10110010

      ==> 1을 빼고 == 10110001
      ==> 1의 보수 == 01001110 ==> 78

다시 78을 음수 -78로 변환해 볼까요? 이제 2의 보수를 사용해 주면 됩니다.

78                 == 01001110

   ==> 1의 보수    == 10110001
   ==> 1을 더하면  == 10110010 ==> -78 ==> Int32의 178과 동일

2진수 변환 없이 간단하게 변환하려면 이런 규칙으로 하시면 됩니다.

byte.MaxValue == 256

129가 음수로 표현되는 수 == -(byte.MaxValue - 129 + 1) == -127
178이 음수로 표현되는 수 == -(byte.MaxValue - 178 + 1) == -78
250이 음수로 표현되는 수 == -(byte.MaxValue - 250 + 1) == -6




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 9/12/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12827정성태9/4/20218580스크립트: 27. 파이썬 - 웹 페이지 데이터 수집을 위한 scrapy Crawler 사용법 요약
12826정성태9/3/202110792.NET Framework: 1113. C# 10 - (12) 문자열 보간 성능 개선 [1]파일 다운로드1
12825정성태9/3/20218400개발 환경 구성: 603. GoLand - WSL 환경과 연동
12824정성태9/2/202117514오류 유형: 760. 파이썬 tensorflow - Dst tensor is not initialized. 오류 메시지
12823정성태9/2/20217065스크립트: 26. 파이썬 - PyCharm을 이용한 fork 디버그 방법
12822정성태9/1/202112319오류 유형: 759. 파이썬 tensorflow - ValueError: Shapes (...) and (...) are incompatible [2]
12821정성태9/1/20217947.NET Framework: 1112. C# - .NET 6부터 공개된 ISpanFormattable 사용법
12820정성태9/1/20218187VC++: 147. Golang - try/catch에 대응하는 panic/recover [1]파일 다운로드1
12819정성태8/31/20218323.NET Framework: 1111. C# - FormattableString 타입
12818정성태8/31/20217541Windows: 198. 윈도우 - 작업 관리자에서 (tensorflow 등으로 인한) GPU 연산 부하 보는 방법
12817정성태8/31/202110215스크립트: 25. 파이썬 - 윈도우 환경에서 directml을 이용한 tensorflow의 AMD GPU 사용 방법
12816정성태8/30/202115560스크립트: 24. 파이썬 - tensorflow 2.6 NVidia GPU 사용 방법 [2]
12815정성태8/30/20218646개발 환경 구성: 602. WSL 2 - docker-desktop-data, docker-desktop (%LOCALAPPDATA%\Docker\wsl\data\ext4.vhdx) 파일을 다른 디렉터리로 옮기는 방법
12814정성태8/30/202111029.NET Framework: 1110. C# 11 - 인터페이스 내에 정적 추상 메서드 정의 가능 (DIM for Static Members) [2]파일 다운로드1
12813정성태8/29/20219172.NET Framework: 1109. C# 10 - (11) Lambda 개선파일 다운로드1
12812정성태8/28/20218806.NET Framework: 1108. C# 10 - (10) 개선된 #line 지시자
12811정성태8/27/20219011Linux: 44. 윈도우 개발자를 위한 리눅스 fork 동작 방식 설명 (파이썬 코드)
12810정성태8/27/20217809.NET Framework: 1107. .NET Core/5+에서 동적 컴파일한 C# 코드를 (Breakpoint도 활용하며) 디버깅하는 방법 - #line 지시자파일 다운로드1
12809정성태8/26/20218477.NET Framework: 1106. .NET Core/5+에서 C# 코드를 동적으로 컴파일/사용하는 방법 [1]파일 다운로드1
12808정성태8/25/20219695오류 유형: 758. go: ...: missing go.sum entry; to add it: go mod download ...
12807정성태8/25/20219703.NET Framework: 1105. C# 10 - (9) 비동기 메서드가 사용할 AsyncMethodBuilder 선택 가능파일 다운로드1
12806정성태8/24/20217344개발 환경 구성: 601. PyCharm - 다중 프로세스 디버깅 방법
12805정성태8/24/20218578.NET Framework: 1104. C# 10 - (8) 분해 구문에서 기존 변수의 재사용 가능파일 다운로드1
12804정성태8/24/20219262.NET Framework: 1103. C# 10 - (7) Source Generator V2 APIs
12803정성태8/23/20219014개발 환경 구성: 600. pip cache 디렉터리 옮기는 방법
12802정성태8/23/20219229.NET Framework: 1102. .NET Conf Mini 21.08 - WinUI 3 따라해 보기 [1]
... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...