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

VC++: 77. C++ 숫자형 값이 범위를 벗어나는 경우의 출력 사례 모음
; https://www.sysnet.pe.kr/2/0/1660

오류 유형: 476. 음수의 음수는 여전히 음수가 되는 수(절대값이 음수인 수)
; https://www.sysnet.pe.kr/2/0/11647




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

비밀번호

댓글 작성자
 



2025-05-22 10시48분
32비트 값을 64비트 레지스터에 넣을 때, 상위 32비트에 대한 처리는 CPU마다 정책을 달리합니다. ("https://www.sysnet.pe.kr/2/0/11188#17318")

On how different Windows ABIs choose how to pass 32-bit values in 64-bit registers
; https://devblogs.microsoft.com/oldnewthing/20250324-00/?p=110988

우리가 보통 사용하는 x86-64 프로세서는 (기존 상태를 유지하므로 개발자가 예측할 수 없는) 쓰레기 값이 존재하게 됩니다.

그런 탓에 컴파일러들은 32비트 값을 64비트 레지스터에 넣어야 할 때 부호 확장을 하는 명령어를 거치도록 합니다.

// 32bit 값을 부호 확장해 64bit 레지스터에 전달
movsx rdi, edi

그런데 만약... (현실적으로 그럴 경우가 거의 없을 테지만) 혹시라도 상위 32비트의 값이 어떤 값으로 채워져 있어도 상관 없는 경우라면 저 단계를 생략하고 싶을 텐데요, 이럴 때 gcc 등의 컴파일러는 확장 문법을 사용해 그렇게 할 수 있다고 합니다.

Silly parlor tricks: Promoting a 32-bit value to a 64-bit value when you don’t care about garbage in the upper bits
; https://devblogs.microsoft.com/oldnewthing/20250521-00/?p=111205

int64_t int32_to_64_garbage(int32_t i32)
{
    int64_t i64;
    __asm__("" : // do nothing
            "=r"(i64) : // produces result in register
            "0"(i32)); // from this input
    return i64;
}

참고로, 저런 용도의 확장 문법은 Visual C++에서는 제공하지 않습니다.
정성태

... 46  47  48  49  50  51  52  53  54  55  [56]  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12632정성태5/7/202123220기타: 80. (WACOM도 지원하는) Tablet 공통 디바이스 드라이버 - OpenTabletDriver
12631정성태5/5/202122136사물인터넷: 60. ThingSpeak 사물인터넷 플랫폼에 ESP8266 NodeMCU v1 + 조도 센서 장비 연동파일 다운로드1
12630정성태5/5/202123260사물인터넷: 59. NodeMCU v1 ESP8266 보드의 A0 핀 사용법 - CdS Cell(GL3526) 조도 센서 연동파일 다운로드1
12629정성태5/5/202125449.NET Framework: 1057. C# - CoAP 서버 및 클라이언트 제작 (UDP 소켓 통신) [1]파일 다운로드1
12628정성태5/4/202122780Linux: 39. Eclipse 원격 디버깅 - Cannot run program "gdb": Launching failed
12627정성태5/4/202122193Linux: 38. 라즈베리 파이 제로 용 프로그램 개발을 위한 Eclipse C/C++ 윈도우 환경 설정
12626정성태5/3/202123099.NET Framework: 1056. C# - Thread.Suspend 호출 시 응용 프로그램 hang 현상 (2)파일 다운로드1
12625정성태5/3/202120056오류 유형: 714. error CS5001: Program does not contain a static 'Main' method suitable for an entry point
12624정성태5/2/202124581.NET Framework: 1055. C# - struct/class가 스택/힙에 할당되는 사례 정리 [10]파일 다운로드1
12623정성태5/2/202121627.NET Framework: 1054. C# 9 최상위 문에 STAThread 사용 [1]파일 다운로드1
12622정성태5/2/202117563오류 유형: 713. XSD 파일을 포함한 프로젝트 - The type or namespace name 'TypedTableBase<>' does not exist in the namespace 'System.Data'
12621정성태5/1/202121920.NET Framework: 1053. C# - 특정 레지스트리 변경 시 알림을 받는 방법 [1]파일 다운로드1
12620정성태4/29/202126904.NET Framework: 1052. C# - 왜 구조체는 16 바이트의 크기가 적합한가? [1]파일 다운로드1
12619정성태4/28/202126984.NET Framework: 1051. C# - 구조체의 크기가 16바이트가 넘어가면 힙에 할당된다? [2]파일 다운로드1
12618정성태4/27/202124722사물인터넷: 58. NodeMCU v1 ESP8266 CP2102 Module을 이용한 WiFi UDP 통신 [1]파일 다운로드1
12617정성태4/26/202120957.NET Framework: 1050. C# - ETW EventListener의 Keywords별 EventId에 따른 필터링 방법파일 다운로드1
12616정성태4/26/202120504.NET Framework: 1049. C# - ETW EventListener를 상속받았을 때 초기화 순서파일 다운로드1
12615정성태4/26/202117598오류 유형: 712. Microsoft Live 로그인 - 계정을 선택하는(Pick an account) 화면에서 진행이 안 되는 문제
12614정성태4/24/202123375개발 환경 구성: 570. C# - Azure AD 인증을 지원하는 ASP.NET Core/5+ 웹 애플리케이션 예제 구성 [4]파일 다운로드1
12613정성태4/23/202121277.NET Framework: 1048. C# - ETW 이벤트의 Keywords에 속한 EventId 구하는 방법 (2) 관리 코드파일 다운로드1
12612정성태4/23/202120497.NET Framework: 1047. C# - ETW 이벤트의 Keywords에 속한 EventId 구하는 방법 (1) PInvoke파일 다운로드1
12611정성태4/22/202117895오류 유형: 711. 닷넷 EXE 실행 오류 - Mixed mode assembly is build against version 'v2.0.50727' of the runtime
12610정성태4/22/202117895.NET Framework: 1046. C# - 컴파일 시점에 참조할 수 없는 타입을 포함한 이벤트 핸들러를 Reflection을 이용해 구독하는 방법파일 다운로드1
12609정성태4/22/202122416.NET Framework: 1045. C# - 런타임 시점에 이벤트 핸들러를 만들어 Reflection을 이용해 구독하는 방법파일 다운로드1
12608정성태4/21/202123520.NET Framework: 1044. C# - Generic Host를 이용해 .NET 5로 리눅스 daemon 프로그램 만드는 방법 [9]파일 다운로드1
12607정성태4/21/202118190.NET Framework: 1043. C# - 실행 시점에 동적으로 Delegate 타입을 만드는 방법파일 다운로드1
... 46  47  48  49  50  51  52  53  54  55  [56]  57  58  59  60  ...