Microsoft MVP성태의 닷넷 이야기
타입의 범위를 넘어서는 연산의 개념을 모르겠습니다. [링크 복사], [링크+제목 복사],
조회: 16538
글쓴 사람
거북이
홈페이지
첨부 파일
 

안녕하세요.

우선! 비전공자입니다. 객체지향이 처음입니다만 질문내용은 그것과 상관이 없네요 ㅎㅎㅎ

3장에서 명시적 변환 할때도 질문을 드려볼까 하다가 넘어갔는데 두번째 나오니까 안되겠습니다;;;

int n = 40000;
short n = (short)n;

//제가 생각했던 결과 n = 32767
//실제 결과 n = -25536


4장 checked, unchecked 를 보니 이게 다시 비트연산과 관련이 있어 보입니다.

short c = 32767

32767 = 2진수 : 01111111 11111111
여기에 1을 더한 결과 : 01111111 11111111 + 1 = 10000000 00000000 (?????????????????????)

흐름을 보면 MaxValue를 넘어서는 명시적형변환은 형식의 가장 MinValue로 변환되어 +수를 더한다??? 라는 결론이 되더군요

다시 3장의 예를 보면

int n = 40000;
short n = (short)n; //short.MinValue : -32768
// -32768 + (-32768 + 40000) = -25536
// 헌데 이건 다시 비트연산과 관계없어 보입니다.


다시 4장에서 예에서 보면 C#은 음수를 2의 보수로 표현하기 때문에 값이 -32768이 된다.


"01111111 11111111 + 1 = 10000000 00000000"

이 부분 살짝 설명 부탁드립니다.






 








[최초 등록일: ]
[최종 수정일: 11/4/2018]


비밀번호

댓글 작성자
 



2018-11-04 02시51분
아래의 말은 틀립니다.

"흐름을 보면 MaxValue를 넘어서는 명시적형변환은 형식의 가장 MinValue로 변환되어 +수를 더한다??? 라는 결론이 되더군요"

숫자형에서의 명시적 형변환은, 단순히 대상 타입의 바이트 수에 맞게 비트를 잘라내거나 확장하는 것에 불과합니다. 그리고, 잘려졌든/확장했든지에 상관없이 결과는 대상 타입의 숫자 표현에 따릅니다. 가령 2의 보수 표현이라면 4바이트에 보관된 32768 값은 2바이트 정수에서는 (순수하게 2의 보수 표현에 따른 비트값에 따라) -32768이 되는 것입니다. 2의 보수에 대해서는 다음의 글을 참고하세요.

C# 부호(+, -)에 대한 비트 변환
; http://www.sysnet.pe.kr/2/0/1379

그렇게 보면, "5.1.3.1 연산 범위 확인: checked, unchecked"의 "01111111 11111111 + 1 = 10000000 00000000" 코드를 이해할 수 있을 것입니다.

int n = 32768;

위의 코드는 n에 00000000 00000000 10000000 00000000 4바이트를 할당합니다. 하지만, 이것을 signed 2byte로 표현하면 상위 2바이트가 그냥 잘려나가 10000000 00000000 값으로 되고, 이것은 2바이트 정수형에서 2의 보수 표현으로 -32768에 해당합니다. 관련해서 다음의 글도 읽어보시면 도움이 될 것입니다.

음수의 음수는 여전히 음수가 되는 수(절대값이 음수인 수)
; http://www.sysnet.pe.kr/2/0/11647

책에서는 "2의 보수"가 어떤 것이라는 설명까지는 하지 않았는데, 그 표현 방식이 뭔지 확실히 이해하시면 당연하게 이해가 되실 것입니다. ^^
정성태
2018-11-07 03시34분
[거북이] 때려맞추기 식으로 이해가 아니라 암기하고 앞만 보고 갑니다 헉헉

일반적(?)인 실무에서 이런 비트변환이 자주 사용되나요??? 암울합니다 ㅜㅜ
[guest]
2018-11-07 03시46분
사실 "그 값이 2의 보수로 정확히 어떤 값이다"라는 식으로는 몰라도 됩니다. 어차피 의도하지 않은 오버플로우는 발생 자체가 오류이기 때문에 그것을 수정하기 위해 좀 더 큰 자료형을 쓰든지 아니면 if 문을 이용한 min, max 값 처리를 하는 것이 보통입니다. (아마, 개발자 세미나에 가서 즉석으로 2의 보수를 물어보면 대답 못하는 개발자도 제법 있을 것입니다.)
정성태
2018-11-07 04시10분
[거북이] 오잉!! 아직 계시는군요!!!
정말 정말 암울했는데, 해보고 싶었던 Thread가 드디어 나왔습니다!!!

번호도 좋네요!! 6.6 스레딩!

기본적인 C#공부하면서, 관심두던 작은 프로그램 개발 이렇게 투트랙으로 하고 있는데 적용할 상상하니 기분 업인데...시간이 집에 갈시간이군요 ㅜㅜ

다시 한번 답변 감사드립니다!!
[guest]

[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5968orion4/30/2025171winform DataSet.xsd의 암호화 된 ConnectionString 사용 질문 [1]
5966GM B4/30/2025186C#과 python 연동 질문 [1]
5962SunN...4/21/2025532Contextmenu margin 조절 [1]파일 다운로드2
5961GM B4/10/2025930winform => wpf 마이그레이션 방법 질문 [4]파일 다운로드1
5960Kim ...4/9/20251181안녕하세요.. 혹 AI & C# 에 대해서도 다루시나요? [1]
5959vict...2/10/20251881비주얼 스투디오 CLR 코드 탑색 질문입니다. [1]
5958Supe...1/18/20252857C#으로 DLL을 만들때 WebVeiw2을 이용하여 Vb6에서 사용할수 있는지 문의드립니다. [2]
5956fc1/11/20252858한국투자증권 KIS Developers OpenAPI의 C# 래퍼 버전 - eFriendOpenAPI NuGet 패키지 [1]
5955tree...11/8/20244507C#12 책 179 페이지 문의 사항 [2]
5954SunN...10/10/20244974textbox에서 글자입력후 textBox1_KeyUp함수에서listBox1_SelectedIndexChanged 강제호출방법 [1]
5953Roya10/4/20244924c# com host dll을 c++에서 사용할 때, sdk 관련 runtime 을 설치 안하고 제공할수 있을까요?? [1]
5952우광현9/5/20246071서버용 소켓 포트 동적포트 적용시 클라이언트가 호출하는 방법? [2]
5951Kun ...8/21/20245682c++에서 복합데이터 Struct를 .NET Framework에서 구현할 수 있는 방법이 있을까요? [2]
5950SunN...8/18/20246237정석대로 한다면 response.Close() 해야되는지요? [4]
5949SunN...8/16/20246326SqlConnection Open()에서 에러가나면 Close()하는 시점 [3]
5948SunN...8/14/20246206WebRequestMethods.Ftp.MakeDirectory 해제 [3]
5947Roya8/7/20246986c# dll을 cpp lib에서 사용을 할려고 하는데요. CoCreateInstance 에서 지정된 파일을 찾을수 없다고 나오는대요. [4]
5946SunN...8/5/20247091TaskDefinition 에서 사용저가로그온상관없이실행 [3]파일 다운로드1
5945SunN...8/3/20246956윈도우 작업스케줄러 [1]
5944roya8/1/20246902C# dll을 C++ 프로젝트에서 사용을 하고 싶은데, 레지스트리 등록 없이 가능한걸까요?? [2]
5943SunN...8/1/20246761윈도우C#에서 리눅스FTP로 업로드 및 리눅스에 폴더생성(WindowsOS에서C#으로) [3]
5942vict...7/24/20246810dll 을 c#에서 쓰고 싶습니다 [1]
5941vict...7/17/20248287DependencyObject와 같은 스레드에서 DependencySource를 만들어야 합니다. 오류 [2]
5940ckm7/16/20248705선생님 안녕하세요 async await 교착 관련 질문입니다 [1]
5939괴물신인7/9/20248411템플릿 대체할수있는방법이 있을까요? [6]
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...