부호있는 숫자에 대해 부호와 크기보다 2의 보수를 선호하는 이유는 무엇입니까?


201

이진수로 -1을 나타 내기 위해 2의 보수가 사용되는 이유가 있다면 궁금합니다. 비트를 뒤집고 1을 추가합니까?

-1은 (보다 직관적으로) 10000001이 아니라 11111111 (2의 보수)로 표시됩니다. 10000001은 첫 번째 비트를 음의 플래그로 사용하는 이진 1입니다.

면책 조항 : 나는 직업에 이진 산술에 의존하지 않습니다!


6
FWIW에서는 부호 비트를 사용하는 "직관적 인"방법이 가끔 사용됩니다. 예를 들어 대부분의 컴퓨터는 부동 소수점 숫자를 나타낼 때 부호 비트를 사용합니다.
Adisak

2
@Adisak 그것은 서명 된 크기라고합니다
Cole Johnson

2
부동 소수점 숫자에는 부호, 지수 및 가수 (종종 암시 적 '1')의 세 가지 구성 요소가 포함되어 있기 때문에 부호와 크기 표현을 항상 정수와 연관 시켰습니다. 그러나 지수와 가수를 엄격하게 선형이 아니라는 것을 인식하는 한 지수와 가수를 처리하는 것이 쉽다고 생각합니다.
Adisak

@Adisak의 발언에 관심이있는 사람들을 위해 부동 소수점 숫자를 이진수로 저장하는 방법을 설명하는 기사 가 있습니다.
GDP2

그냥이 설명하는 좋은 비디오를 보았다 youtube.com/watch?v=dHB7jFjESLY
allenlinli

답변:


333

음수를 처리하기 위해 추가에 특별한 논리가 필요하지 않도록 완료되었습니다. Wikipedia 기사를 확인하십시오 .

2와 -1의 두 숫자가 있다고 가정 해보십시오. 숫자를 나타내는 "직관적 인"방법으로 숫자는 각각 0010이고 1001(크기는 4 비트를 고수합니다). 에서 2의 보수 방법, 그들은은 00101111. 이제 그것들을 추가하고 싶다고합시다.

2의 보수 추가는 매우 간단합니다. 일반적으로 숫자를 추가하면 끝에있는 캐리 비트가 삭제됩니다. 따라서 다음과 같이 추가됩니다.

  0010
+ 1111
=10001
= 0001 (discard the carry)

0001 "2 + (-1)"의 예상 결과 인 1입니다.

그러나 "직관적 인"방법에서는 추가가 더 복잡합니다.

  0010
+ 1001
= 1011

어느 것이 -3입니까? 이 경우 단순 추가는 작동하지 않습니다. 숫자 중 하나는 음수이며 다른 경우 다른 알고리즘을 사용해야합니다.

이 "직관적 인"저장 방법의 경우 뺄셈은 덧셈과 다른 연산이므로 덧셈하기 전에 숫자를 추가로 확인해야합니다. 가장 기본적인 연산 (더하기, 빼기 등)을 가능한 빨리하기를 원하므로 가능한 가장 간단한 알고리즘을 사용할 수있는 방식으로 숫자를 저장해야합니다.

또한 "직관적 인"저장 방법에는 두 가지 0이 있습니다.

0000  "zero"
1000  "negative zero"

직관적으로 같은 숫자이지만 저장시 두 개의 다른 값이 있습니다. 모든 응용 프로그램은 0이 아닌 값도 음의 0이 아닌지 확인하기 위해 추가 단계를 수행해야합니다.

이 방법으로 ints를 저장하면 또 다른 보너스가 있습니다.이 경우 값이 저장되는 레지스터의 너비를 확장해야합니다. 2의 보수로 8 비트 레지스터에 4 비트 숫자를 저장하면 반복됩니다. 가장 중요한 비트 :

    0001 (one, in four bits)
00000001 (one, in eight bits)
    1110 (negative two, in four bits)
11111110 (negative two, in eight bits)

작은 단어의 부호 비트를보고 더 큰 단어의 너비에 닿을 때까지 반복하면됩니다.

이 방법을 사용하면 기존 비트를 지워야합니다. 이는 패딩 외에도 추가 작업입니다.

    0001 (one, in four bits)
00000001 (one, in eight bits)
    1010 (negative two, in four bits)
10000010 (negative two, in eight bits)

두 경우 모두 4 비트를 추가로 설정해야하지만 "직관적 인"경우 5 번째 비트도 지워야합니다. 모든 애플리케이션에 존재하는 가장 기본적이고 일반적인 작업 중 하나에서 아주 작은 단계입니다.


13
나는 동의한다. 2의 보수 작업. 그러나 처음에는 어떻게 도착 했습니까? 이 표기법에 도달해야한다면 사고 과정은 어떻게됩니까? 나는 2의 보수에 도달하는 것이 단순히 운 이상의 것이 아니라고 생각합니까?
Lazer

1
또한 왜 수레에 대한 2의 보수 대응 물이 없는가?
Lazer

6
@Lazer cs.cornell.edu/~tomf/notes/cps104/twoscomp.html을 알기 how we arrived at 2s compliment the first place. 위해이
Ankit

1
Java는 내가 아는 한 정수 유형 만 서명했기 때문에 항상 2의 보수 해석으로 처리합니다. 다른 언어에서는 값이 처리되는 방식이 코드가 처리하는 방식에 따라 다릅니다. 메모리 블록이 부호있는 또는 부호없는 정수 또는 더블 또는 문자열 또는 다른 것임을 알 수있는 것은 없습니다. 원시 데이터는 데이터를 해석하기 위해 선택한 모든 유형입니다.
Welbog

3
@Suraj, 나는 완전한 대답을위한 2의 보완에 관한 Wikipedia 기사를 볼 것을 제안합니다 : en.wikipedia.org/wiki/Two%27s_complement . 짧은 대답은 MSB이다 1나타내고 -8, 나머지 3 개 1(S)은 표시 4, 21따라서 각각 -8+4+2+1 = -1.
Welbog

18

Wikipedia 는 모든 것을 말합니다.

2의 보수 시스템은 덧셈과 뺄셈 회로가 피연산자의 부호를 조사하여 뺄셈을 뺄 것인지 결정할 필요가 없다는 장점이 있습니다. 이 속성을 사용하면 시스템을보다 간단하게 구현할 수 있으며 고정밀 산술을 쉽게 처리 할 수 ​​있습니다. 또한, 0은 단일 표현만을 가지므로 1의 보수 시스템에 존재하는 음의 0과 관련된 미묘함을 피할 수 있습니다.

다시 말해, 더하기는 같지만 숫자는 음수입니다.


내가 char a = 12라고 쓰면 unsigned char b = 12는 기본 비트 패턴이 동일하며 실제로 어떤 일이 발생합니까?
Suraj Jain

쓰거나 읽을 때 아무것도 바뀌지 않습니다. 더하기 또는 빼기에만 적용 가능합니다.
Talespin_Kit

12

이 질문이 오래되었지만 2 센트를 넣겠습니다.

이것을 설명하기 전에 기본으로 돌아가 봅시다. 2 '보수는 1의 보수 + 1입니다. 이제 1의 보수는 무엇이고 또한 그 의미는 무엇입니까?

n 비트 수와 1의 보수의 합은 해당 n 비트로 표시 할 수있는 가장 높은 수를 제공합니다. 예:

 0010 (2 in 4 bit system)
+1101 (1's complement of 2)
___________________________
 1111  (the highest number that we can represent by 4 bits)

이제 결과에 1을 더 추가하면 어떻게 될까요? 오버플로가 발생합니다.

결과 1 0000는 0입니다 (4 비트 숫자로 작업 할 때 (왼쪽의 1은 오버플로입니다))

그래서

Any n-bit number + its 1's complement = max n-bit number
Any n-bit number + its 1'complement + 1 = 0 ( as explained above, overflow will occur as we are adding 1 to max n-bit number)

그런 다음 누군가 1의 보수 + 1을 2의 보수로 부르기로 결정했습니다. 따라서 위의 진술은 다음과 같습니다 : n 비트 수 + 2의 보수 = 0은 2의 보수 = = (해당 숫자)를 의미합니다.

이 모든 것이 하나의 질문을 낳습니다. 왜 우리는 n 비트의 (n-1) 만 사용하여 양수를 나타낼 수 있으며 가장 왼쪽의 n 번째 비트가 부호를 나타냅니다 (가장 왼쪽 비트의 0은 + ve 숫자를 의미하고 1은 -ve 번호). 예를 들어 32 비트가 1 인 경우 -ve 숫자 인 경우 양수를 나타 내기 위해 Java에서 int의 처음 31 비트 만 사용하는 이유는 무엇입니까?

 1100 (lets assume 12 in 4 bit system)
+0100(2's complement of 12)
___________________________

1 0000 (캐리 1 오버플로로 결과는 0입니다)

따라서 (n + 2'complement of n) = 0의 시스템은 여전히 ​​작동합니다. 여기에서 유일한 모호성은 12의 2의 보수는 0100이며 2의 보수 시스템에서 -12를 나타내는 것 외에는 모호하게도 +8을 나타냅니다.

이 문제는 양수가 가장 왼쪽 비트에 항상 0 인 경우 해결됩니다. 이 경우 2의 보수는 항상 가장 왼쪽 비트에 1을 가지며 2의 보수 숫자와 + ve 숫자를 나타내는 동일한 비트 세트의 모호성이 없습니다.


1
+1했습니다. 그것은 정보 였지만 결국 당신이 왜 양수인지 음수인지를 나타 내기 위해 가장 중요한 비트의 접근 방식을 원했던 이유는 확실하지 않습니다. 0에는 0000 (+) 및 1000 (-)의 두 가지 표현이 있습니다. 또한 같은 알고리즘을 사용하여 더하기 및 빼기를 수행 할 수 없습니다. 보통 0100이라고하면 +8이고, 2의 보수 0100이라고하면 -12입니다.
hagrawal

8

2의 보수 는 부호가없는 숫자로 감는 것처럼 정상적인 방법으로 덧셈과 뺄셈을 수행 할 수있게합니다. 또한 -0 (일반적인 비트 단위 비교 방법으로 0과 같지 않은 0을 나타내는 별도의 방법)을 방지합니다.


6

이것은 숫자의 합과 차이를 단순화하는 것입니다. 2의 보수로 체계화 된 음수와 양수의 합은 정상적인 방법으로 합산하는 것과 같습니다.


5

연산의 일반적인 구현은 "비트를 뒤집고 1을 더하는 것"이지만, 근거를보다 명확하게 만드는 다른 방법이 있습니다. 2의 보수는 각 비트가 다음 2의 제곱을 제어하는 ​​일반적인 부호없는 표현을 취하고 가장 중요한 항을 음수로 만들면 얻을 수있는 형태입니다.

8 비트 값 취하기 a 7 a 6 a 5 a 4 a 3 a 2 a 1 a 0

일반적인 부호없는 이진 해석은 다음과 같습니다.
2 7 * a 7 + 2 6 * a 6 + 2 5 * a 5 + 2 4 * a 4 + 2 3 * a 3 + 2 2 * a 2 + 2 1 * a 1 + 2 0 * a 0
11111111 = 128 + 64 + 32 + 16 + 8 + 4 + 2 + 1 = 255

2의 보수 해석은 다음과 같습니다.
-2 7 * a 7 + 2 6 * a 6 + 2 5 * a 5 + 2 4 * a 4 + 2 3 * a 3 + 2 2 * a 2 + 2 1 * a 1 + 2 0 * a 0
11111111 = -128 + 64 + 32 + 16 + 8 + 4 + 2 + 1 = -1

다른 비트는 전혀 의미를 변경 하지 않으며 7을 전달하는 것은 "오버플로"이며 작동하지 않을 것으로 예상되므로 거의 모든 산술 연산이 수정없이 작동합니다 (다른 사람들이 지적했듯이). 부호 크기는 일반적으로 부호 비트를 검사하고 다른 논리를 사용합니다.


4

2의 보수는 특별한 논리없이 음수와 양수를 더할 수 있습니다.


10000001 (-1)
+00000001 (1) 방법을 사용하여 1과 -1을 추가하려고
하면
10000010 (-2) 를 얻습니다.

대신 2의 보수를 사용하여

11111111 (-1)
+00000001 (1) 얻을
00000000 (0)

빼기의 경우에도 마찬가지입니다.

또한 6에서 2를 빼려고하면 (2 개의 양수) 2를 4로 보완하고 2를 더할 수 있습니다 6 + (-4) = 6-4 = 2

즉, 양수와 음수 모두 빼기와 덧셈을 모두 CPU의 동일한 회로에서 수행 할 수 있습니다.


4

다른 답변을 확장하려면 다음을 수행하십시오.

2의 보수

  • 덧셈은 일반 양의 정수 덧셈과 같은 메커니즘입니다.
  • 빼기도 변경되지 않습니다
  • 곱셈도!

부서에는 다른 메커니즘이 필요합니다.

2의 보수는 단지 모듈 식 산술이기 때문에 모듈러스를 빼서 일부 숫자를 음수로 보도록 선택하기 때문에이 모든 것이 사실입니다.


비확산 곱셈 만 같은 것은 아닙니다 . 그러나 대부분의 고급 언어는 명시 적 캐스트없이 확장 곱셈을 지원하지 않으므로 결과는 해당 언어에서 동일합니다.
phuclv

@ LưuVĩnhPhúc : 확대 곱셈은 일반적으로 동일하지만 부호있는 곱셈과 부호없는 곱셈의 결과는 부호있는 정수 범위에 맞는 경우에만 동일하게 보장됩니다. gcc와 같은 일부 컴파일러는 unsigned mul(unsigned short x, unsigned short y) { return x*y; }[16 비트 short; 32 비트 int]는 때때로 제품이 2147483647보다 큰 경우 작동하지 않을 코드를 생성합니다.
supercat

2

이 질문에 대한 답을 읽으면서 나는이 의견을 발견했다.

2의 0100 (4)의 보수는 1100입니다. 이제 정상적으로 말하면 1100은 12입니다. 따라서 1100을 말하면 12이지만 2의 보수 1100을 말하면 -4입니까? 또한 Java에서 1100 (현재 4 비트로 가정)이 저장되면 +12 또는 -4인지 어떻게 결정됩니까 ?? – hagrawal 7 월 2 일 16:53

내 의견으로는,이 의견에서 제기 된 질문은 매우 흥미 롭습니다. 그래서 우선 그것을 바꾸고 대답과 예를 제시하고 싶습니다.

질문 – 시스템은 하나 이상의 인접 바이트를 해석하는 방법을 어떻게 설정할 수 있습니까? 특히, 시스템은 주어진 바이트 시퀀스가 ​​일반 이진수인지 또는 2의 보수 숫자인지 어떻게 확인할 수 있습니까?

답변 – 시스템은 유형을 통해 바이트 시퀀스를 해석하는 방법을 설정합니다. 유형 정의

  • 고려해야 할 바이트 수
  • 그 바이트를 해석하는 방법

예 – 아래에서는

  • char의 길이는 1 바이트입니다
  • short의 길이는 2 바이트입니다
  • intfloat의 길이는 4 바이트입니다.

이 크기는 내 시스템에 따라 다릅니다. 꽤 일반적이지만 시스템마다 다를 수 있습니다. 시스템에 무엇이 있는지 궁금하다면 sizeof operator를 사용하십시오 .

우선 4 바이트를 포함하는 배열을 정의 10111101하고 16 진수에 해당하는 모든 이진수로 초기화합니다 BD.

// BD(hexadecimal) = 10111101 (binary)
unsigned char   l_Just4Bytes[ 4 ]   =   { 0xBD, 0xBD, 0xBD, 0xBD };

그런 다음 다른 유형을 사용하여 배열 내용을 읽습니다.

unsigned charsigned char

// 10111101 as a PLAIN BINARY number equals 189
printf( "l_Just4Bytes as unsigned char  -> %hi\n", *( ( unsigned char* )l_Just4Bytes ) );

// 10111101 as a 2'S COMPLEMENT number equals -67
printf( "l_Just4Bytes as signed char    -> %i\n", *( ( signed char* )l_Just4Bytes ) );

unsigned shortshort

// 1011110110111101 as a PLAIN BINARY number equals 48573
printf( "l_Just4Bytes as unsigned short -> %hu\n", *( ( unsigned short* )l_Just4Bytes ) );

// 1011110110111101 as a 2'S COMPLEMENT number equals -16963
printf( "l_Just4Bytes as short          -> %hi\n", *( ( short* )l_Just4Bytes ) );

unsigned int, intfloat

// 10111101101111011011110110111101 as a PLAIN BINARY number equals 3183328701
printf( "l_Just4Bytes as unsigned int   -> %u\n", *( ( unsigned int* )l_Just4Bytes ) );

// 10111101101111011011110110111101 as a 2'S COMPLEMENT number equals -1111638595
printf( "l_Just4Bytes as int            -> %i\n", *( ( int* )l_Just4Bytes ) );

// 10111101101111011011110110111101 as a IEEE 754 SINGLE-PRECISION number equals -0.092647
printf( "l_Just4Bytes as float          -> %f\n", *( ( float* )l_Just4Bytes ) );

RAM ( l_Just4Bytes[ 0..3 ]) 의 4 바이트는 항상 동일하게 유지됩니다. 변화하는 유일한 것은 우리가 그것들을 해석하는 방법입니다.

다시, 우리 는 시스템에게 타입을 통해 그것들을 해석하는 방법 을 알려줍니다 .

예를 들어, 위에서 우리는 l_Just4Bytes배열 의 내용을 해석하기 위해 다음 유형을 사용했습니다

  • unsigned char: 일반 이진에서 1 바이트
  • signed char: 2의 보수에서 1 바이트
  • unsigned short: 일반 이진 표기법으로 2 바이트
  • short: 2의 보수에서 2 바이트
  • unsigned int: 일반 이진 표기법으로 4 바이트
  • int: 2의 보수로 4 바이트
  • float: IEEE 754 단정도 표기법의 4 바이트

[편집]이 게시물은 user4581301 님의 댓글 이후에 수정되었습니다. 도움이되는 몇 줄을 삭제 해 주셔서 감사합니다!


이 코드 블롭에는 편집이 필요하므로 독자는 계속 스크롤 할 필요가 없습니다. 더군다나 상단에있는 방대한 주석은 평범한 오래된 텍스트가되어 렌더러가 형식을 처리하도록해야합니다. 크기가 고정되어 있지 않기 때문에 크기와 형식에 대해 논의하는 마지막 부분에주의를 기울여야합니다.
user4581301

+1. @ mw215는이 질문 / 응답 쌍을 자체 커뮤니티 위키 항목으로 만드는 것이 좋습니다. 왜냐하면 2의 보수 수학의 맥락 밖에서 원시 바이트 해석에 관심이있는 사람들에게 유용하기 때문입니다.
Welbog

나는 단지 2의 보수가 항상 따르는 지 알고 싶습니다. 내가 가지고 있다면 의미합니다 int x = -4. 그리고 printf("%d" , x)어떻게 해석됩니까? 또한 unsigned intand signed intand %dand 의 차이점은 무엇입니까 %u? 이것은 오랫동안 오랫동안 나를 괴롭 혔습니다. 감사합니다.
Suraj Jain

@Suraj Jain int유형을 사용 하는 경우 signed수정자가 기본값입니다. 이것은 int그리고 signed int정확히 같은 유형입니다. 따라서이 정의 int i = -4;signed int i = -4;같은 의미를 가지고있다.
mw215

@Suraj Jain 시스템은 유형을 통해 바이트 시퀀스를 해석하는 방법을 설정합니다. 유형 정의 : 고려해야 할 바이트 수와 해당 바이트를 해석해야하는 방법. 는 int4 바이트 2의 보수 와는 unsigned int4 바이트 일반 이진 표기법합니다 (사용하여 시스템의 실제 타입의 크기를 확인 sizeof연산자).
mw215

1

스탠포드의 Jerry Cain 교수는 Standford의 YouTube 채널에서 시청할 수있는 프로그래밍 패러다임이라는 일련의 강의에서 두 번째 강의 (2의 보완에 대한 설명이 13:00 쯤 시작됨)에서 두 개의 보완을 설명하는 것을 볼 수 있습니다. 다음은 강의 시리즈에 대한 링크입니다 http://www.youtube.com/view_play_list?p=9D558D49CA734A02은 .


0

2의 보수는 회로에서 구현하기가 더 쉽고 음의 제로를 허용하지 않기 때문에 사용됩니다.

x 비트가 있으면 2의 보수 범위는 + (2 ^ x / 2 + 1)에서-(2 ^ x / 2)입니다. 1의 보수는 + (2 ^ x / 2)에서-(2 ^ x / 2)까지 실행되지만 음수 0을 허용합니다 (4 비트 1의 보수 시스템에서 0000은 1000과 같습니다).


0

글쎄, 당신의 의도는 실제로 이진수의 모든 비트를 뒤집는 것이 아닙니다. 실제로 각 숫자를 1에서 빼는 것입니다. 1에서 1을 빼면 0이되고 1에서 0을 빼면 1이됩니다. 따라서 비트를 뒤집는 것이이 빼기를 효과적으로 수행합니다.

그러나 왜 1과 다른 숫자의 차이를 발견합니까? 당신은 아니에요 실제 의도는 자릿수가 같지만 1 만 포함하는 다른 이진수와 주어진 이진수의 차이를 계산하는 것입니다. 예를 들어 숫자가 10110001 인 경우 모든 비트를 뒤집 으면 효과적으로 계산됩니다 (11111111-10110001).

이것은 2의 보수 계산의 첫 번째 단계를 설명합니다. 이제 그림에 1을 추가하는 두 번째 단계를 포함시킵니다.

위의 이진 방정식에 1을 더하십시오.

11111111-10110001 + 1

무엇을 얻습니까? 이:

100000000-10110001

이것이 마지막 방정식입니다. 그리고이 두 단계를 수행 함으로써이 차이점을 찾으려고 노력합니다. 최종의 차이 : 이진수는 다른 이진수에서 하나의 추가 숫자를 빼고 가장 부호있는 비트 위치를 제외하고 0을 포함합니다.

그러나 왜 우리는이 차이를 겪고 있습니까? 자, 여기서부터 Wikipedia 기사 를 읽으면 더 좋을 것 같습니다 .


0

덧셈과 뺄셈 모두에 더하기 연산 만 수행합니다. 추가를 위해 두 번째 피연산자를 첫 번째 피연산자에 추가합니다. 빼기 위해 두 번째 피연산자의 2의 보수를 첫 번째 피연산자에 추가합니다.

2의 보수 표현으로 뺄셈을 위해 별도의 디지털 컴포넌트가 필요하지 않습니다. 덧셈기와 덧셈기 만 사용됩니다.


0

디지털 컴퓨터가 사용되기 전에 일부 초기 기계를 추가 할 때는 각 키에 다른 색상의 범례 세트를 사용하여 값을 입력하여 빼기를 수행 할 수 있습니다 (따라서 각 키는 빼고) 특수 버튼을 누르면 계산이 수행됩니다. 따라서 6 자리 컴퓨터에서 값에서 1234를 빼기 위해 작업자는 일반적으로 "998,765"를 나타내는 키를 누르고 해당 값에 1을 더한 계산에 추가하는 버튼을 누릅니다. 2의 보수 산술은 단순히 이전 "10의 보수"산술과 이진입니다.


0

보수 방법에 의한 감산의 이점은 하드웨어
복잡도 감소입니다. 가산과 감산을 위해 서로 다른 디지털 회로가 필요하지 않습니다.


0

아직 언급되지 않은 2의 보수 표현의 주요 장점은 2의 보수 합, 차이 또는 곱의 하위 비트가 종속적이라는 것입니다 피연산자의 해당 비트 에만 한다는 것입니다. 8 비트 부호 값이 -1 이유는 11111111감산이다 어느 누구의 최하위 8 비트 정수이다 00000001그의 최저 8 비트이다 다른 정수에서를0000000 최하위 8 비트들이 정수를 산출 할 것이다11111111. 수학적으로 -1 값은 1의 무한 문자열이지만 특정 정수 유형의 범위 내의 모든 값은 특정 지점을지나 1 또는 0이 될 수 있으므로 컴퓨터에서 "sign-extend"하는 것이 편리합니다. 1 또는 0의 무한한 수를 나타내는 것처럼 숫자의 가장 중요한 비트.

2의 보수는 이진 기계의 자연 단어 크기보다 큰 유형을 처리 할 때 잘 작동하는 유일한 부호있는 숫자 표현입니다. 더하기 또는 빼기를 수행 할 때 코드는 각 피연산자의 가장 낮은 청크를 가져올 수 있고 가장 낮은 청크를 계산할 수 있기 때문에 결과를 저장 한 다음 각 피연산자의 다음 청크를로드하고 결과의 다음 청크를 계산 한 후 저장합니다. 따라서 모든 덧셈과 뺄셈이 단일 8 비트 레지스터를 통과해야하는 프로세서도 32 비트 부호있는 숫자를 합리적으로 효율적으로 처리 할 수 ​​있습니다 (물론 32 비트 레지스터보다 느리지 만 여전히 작동 가능합니다).

C 표준에서 허용하는 다른 부호있는 표현을 사용하는 경우 결과의 모든 비트가 임의의 피연산자에 의해 영향을받을 수 있으므로 레지스터의 전체 값을 한 번에 유지하거나 추가로 계산을 수행해야합니다. 적어도 일부 경우에, 결과의 각 청크를 읽고, 수정하고, 다시 써야하는 단계.


답변의 형식을 지정하십시오. 단락 및 코드를 코드로 표시하면 더 읽기 쉽고 투표권이 생깁니다.
Suraj Jain

@SurajJain : 더 낫습니까?
supercat

예, 이전의 것보다 낫습니다. 부호있는 문자 a = 1과 부호없는 문자 a = 1의 차이점이 무엇인지 한 가지 묻고 싶습니다. 어떻게 메모리에 표현되어 있습니까?
Suraj Jain

@SurajJain : "char"가 "int"보다 작은 두 개의 보수 시스템 (즉, 대부분의 시스템)에서 부호있는 및 부호없는 char 유형은 부호있는 유형이 읽거나 부호없는 유형일 때 부호 확장되는 것을 제외하고 동일하게 동작합니다. 습관. 이러한 시스템에서, 값 194 또는 -62를 부호있는 문자에 저장하면 부호 194 또는 -62를 부호없는 문자 (예 : 11000010)에 저장하는 것과 동일한 비트 패턴을 씁니다. 부호있는 문자에서 해당 비트 패턴을 읽으면 -62가 생성되고 부호가없는 문자에서 읽은 비트 패턴은 194가됩니다.
supercat

부호 확장 수단?
Suraj Jain

0

다음과 같은 다양한 유형의 표현이 있습니다.

  1. 부호없는 숫자 표현
  2. 부호있는 숫자 표현
  3. 보완 표현
  4. 2의 보수 표현

양의 숫자만을 나타내는 데 사용되는 부호없는 숫자 표현

-음수뿐만 아니라 양수를 나타내는 데 사용되는 부호있는 숫자 표현. 부호있는 숫자 표시에서 MSB 비트는 부호 비트를 나타내고 나머지 비트는 숫자를 나타냅니다. MSB가 0이면 숫자는 양수이고 MSB가 1이면 숫자는 음수입니다.

부호있는 숫자 표시의 문제점은 0에 대해 두 개의 값이 있다는 것입니다.

보수 표현의 문제점은 0에 대해 두 개의 값이 있다는 것입니다.

그러나 2의 보수 표현을 사용하는 경우 0에 대해 하나의 값만 있으므로 2의 보수 형태로 음수를 나타냅니다.

출처 : 음수가 2의 보수 형태 인 바이트의 기가 바이트로 저장되는 이유


-1

Two2의 ​​보수가 One의 보수 시스템이 아닌 음수를 나타내는 데 사용되는 이유에 대한 하나의 만족스러운 대답은 Two의 보수 시스템 이 0다중 표현 문제를 해결하고 end-around-carry 가 필요하다는 것입니다 음수를 나타내는 1의 보수 시스템에 존재하는 번호.

자세한 내용은 방문 https://en.wikipedia.org/wiki/Signed_number_representations를 참조하십시오.

End-around-carry의 경우 https://en.wikipedia.org/wiki/End-around_carry를 방문 하십시오.


실제로 소수점이 있고 모든 비트가 무엇인지에 대해 명백한 경우 : "0..0000.1111..1"은 가장 왼쪽에있는 모든 unstated 비트가 0이고 가장 오른쪽에있는 모든 unstated 비트가 1임을 의미합니다. "..1"은 캐리가 트리거되었음을 의미합니다. 따라서 (기계적으로) "0.0001.0000..0"입니다. "1..1111.1111..1"은 0과 같습니다! 이것은 또한 정수를 부정하기 위해 실제로 비트를 뒤집는 것을 의미합니다. 그러나 이제는 표현 가능한 분수에 적용됩니다.
Rob
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.