일반적인 문제 C 언어에서 왼쪽 시프트 및 오른쪽 시프트 연산자를 이해하는 방법

C 언어에서 왼쪽 시프트 및 오른쪽 시프트 연산자를 이해하는 방법

Mar 11, 2019 pm 05:28 PM
c 언어

C 언어의 왼쪽 시프트는 왼쪽 시프트 연산자를 의미합니다. 이는 가장 높은 비트를 버리고 가장 낮은 비트를 0으로 채우는 것을 의미하며, C 언어의 오른쪽 시프트는 왼쪽 시프트와 반대되는 오른쪽 시프트 알고리즘입니다. 몇 곳을 옮겨보세요.

C 언어에서 왼쪽 시프트 및 오른쪽 시프트 연산자를 이해하는 방법

C 언어에서 왼쪽 시프트 및 오른쪽 시프트 연산자 사용: 왼쪽 시프트 연산자는 가장 높은 비트를 삭제한 다음 가장 낮은 비트에 0을 추가합니다. 오른쪽 시프트 알고리즘은 왼쪽 시프트와 반대이며 몇 비트를 이동합니다. to the right

C 언어의 왼쪽 시프트 연산자와 오른쪽 시프트 연산자는 C 언어의 연산자입니다. 다음 글에서는 이 두 연산자의 사용법을 자세히 소개하겠습니다. 이는 모두에게 도움이 되기를 바랍니다

【추천 과정: C 언어 튜토리얼

먼저 왼쪽 시프트에 대해 이야기해 보겠습니다. 왼쪽 시프트는 숫자의 모든 비트를 특정 자리만큼 왼쪽으로 이동하는 것을 의미합니다. << 예:

int i = 1;
i = i << 2;  //把i里的值左移2位
로그인 후 복사

즉, 1의 이진 시스템은 000...0001입니다(여기서 1 앞에 있는 0의 수는 int, 32비트 시스템의 자릿수와 관련이 있습니다. 31 0s in gcc), 왼쪽 시프트 2자리 이후에는 000...0100이 되며, 이는 10진수로 4이므로 1자리를 왼쪽으로 이동하는 것은 2를 곱한 것과 같습니다. 그런 다음 n자리를 왼쪽으로 이동하는 것은 2의 n제곱을 곱합니다(부호 있는 숫자는 완전히 적용 가능하지 않습니다. 왜냐하면 왼쪽 시프트로 인해 부호가 변경될 수 있기 때문입니다. 이유는 아래에 설명되어 있습니다.)
주의가 필요한 한 가지 문제는 m 끝의 부호 비트와 int 유형의 가장 왼쪽 버스에서는 시프트 아웃이 보고되지 않습니다. 우리는 int가 부호 정수를 가지며, 가장 왼쪽 1비트가 부호 비트, 즉 0은 양수이고 1은 음수라는 것을 알고 있습니다. 그러면 이동 시 오버플로가 발생합니다. 예:

int i = 0x40000000; //16进制的40000000,为2进制的01000000...0000
i = i << 1;
로그인 후 복사

그러면 i는 왼쪽으로 1비트 이동한 후 0x80000000이 됩니다. 즉, 이진수에서는 100000...0000이고 부호 비트는 1로 설정되고 나머지 비트는 모두 0이 됩니다. int 유형이 나타낼 수 있는 최소값은 -2147483648이며 이는 오버플로입니다. 만약 i가 1비트만큼 왼쪽으로 이동하면 어떻게 될까요? 1을 버리면 i의 값은 0이 됩니다.
왼쪽 시프트의 특별한 경우는 왼쪽으로 시프트된 자릿수가 숫자 유형의 최대 자릿수를 초과하는 경우 컴파일러는 왼쪽으로 시프트된 자릿수를 사용합니다. 유형의 최대 자릿수를 모듈로로 나눈 다음 나머지만큼 이동합니다. 예:

int i = 1, j = 0x80000000; //设int为32位
i = i << 33;   // 33 % 32 = 1 左移1位,i变成2
j = j << 33;   // 33 % 32 = 1 左移1位,j变成0,最高位被丢弃
로그인 후 복사


gcc 사용 이 프로그램을 컴파일할 때 컴파일러는 왼쪽 이동 횟수 >= 유형 길이라는 경고를 표시합니다. .실제로 i와 j는 33%32 이후의 나머지 부분만큼 이동합니다.

gcc에서 다음은 이 규칙입니다.

간단히 말하면 왼쪽입니다. Shift의 의미: 최상위 비트를 버리고 최하위 비트를 0으로 채웁니다

오른쪽 Shift에 대해 이야기해 보겠습니다. 왼쪽 Shift의 원리를 이해하면 오른쪽 Shift가 더 이해하기 쉽습니다.

오른쪽 Shift의 개념은 반대입니다. 왼쪽 시프트, 즉 오른쪽으로 몇 비트 이동하는 것입니다. 연산자는 >>입니다.

오른쪽 시프트의 부호 비트는 왼쪽 시프트와 다릅니다. 부호 비트는 변경되지 않습니다. 예:

int i = 0x80000000;
i = i >> 1;  //i的值不会变成0x40000000,而会变成0xc0000000
로그인 후 복사

즉, 부호 비트가 오른쪽으로 이동한 후 양수에는 0이 추가되고 음수에는 1이 추가됩니다. 이는 어셈블리 언어의 산술 오른쪽 이동입니다. , 이동된 비트 수가 해당 유형의 길이를 초과하면 나머지가 취해진 다음 나머지가 이동됩니다.

负数10100110 >>5(假设字长为8位),则得到的是  11111101
로그인 후 복사

간단히 C에서 왼쪽 시프트는 논리/산술 왼쪽 시프트입니다(둘은 정확히 동일) 및 오른쪽 시프트 부호 비트를 변경하지 않고 유지하는 산술 오른쪽 시프트입니다. 실제 응용 프로그램에서는 왼쪽/오른쪽 시프트를 사용하여 상황에 따라 빠른 곱셈/나눗셈 연산을 수행할 수 있습니다.

반복보다 효율적입니다.

위 내용은 C 언어에서 왼쪽 시프트 및 오른쪽 시프트 연산자를 이해하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

C 언어 데이터 구조 : 나무 및 그래프의 데이터 표현 및 작동 C 언어 데이터 구조 : 나무 및 그래프의 데이터 표현 및 작동 Apr 04, 2025 am 11:18 AM

C 언어 데이터 구조 : 트리 및 그래프의 데이터 표현은 노드로 구성된 계층 적 데이터 구조입니다. 각 노드에는 데이터 요소와 하위 노드에 대한 포인터가 포함되어 있습니다. 이진 트리는 특별한 유형의 트리입니다. 각 노드에는 최대 두 개의 자식 노드가 있습니다. 데이터는 structtreenode {intdata; structtreenode*왼쪽; structReenode*오른쪽;}을 나타냅니다. 작업은 트리 트래버스 트리 (사전 조정, 인 순서 및 나중에 순서) 검색 트리 삽입 노드 삭제 노드 그래프는 요소가 정점 인 데이터 구조 모음이며 이웃을 나타내는 오른쪽 또는 무의미한 데이터로 모서리를 통해 연결할 수 있습니다.

C 언어 파일 작동 문제의 진실 C 언어 파일 작동 문제의 진실 Apr 04, 2025 am 11:24 AM

파일 작동 문제에 대한 진실 : 파일 개방이 실패 : 불충분 한 권한, 잘못된 경로 및 파일이 점유 된 파일. 데이터 쓰기 실패 : 버퍼가 가득 차고 파일을 쓸 수 없으며 디스크 공간이 불충분합니다. 기타 FAQ : 파일이 느리게 이동, 잘못된 텍스트 파일 인코딩 및 이진 파일 읽기 오류.

C 언어 기능의 기본 요구 사항은 무엇입니까? C 언어 기능의 기본 요구 사항은 무엇입니까? Apr 03, 2025 pm 10:06 PM

C 언어 기능은 코드 모듈화 및 프로그램 구축의 기초입니다. 그들은 선언 (함수 헤더)과 정의 (기능 본문)로 구성됩니다. C 언어는 값을 사용하여 기본적으로 매개 변수를 전달하지만 주소 패스를 사용하여 외부 변수를 수정할 수도 있습니다. 함수는 반환 값을 가질 수 있거나 가질 수 있으며 반환 값 유형은 선언과 일치해야합니다. 기능 명명은 낙타 또는 밑줄을 사용하여 명확하고 이해하기 쉬워야합니다. 단일 책임 원칙을 따르고 기능 단순성을 유지하여 유지 관리 및 가독성을 향상시킵니다.

C 언어로 카운트 다운을 출력하는 방법 C 언어로 카운트 다운을 출력하는 방법 Apr 04, 2025 am 08:54 AM

C에서 카운트 다운을 출력하는 방법? 답변 : 루프 명령문을 사용하십시오. 단계 : 1. 변수 n을 정의하고 카운트 다운 번호를 출력에 저장합니다. 2. n이 1보다 작을 때까지 n을 지속적으로 인쇄하려면 while 루프를 사용하십시오. 3. 루프 본체에서 n의 값을 인쇄하십시오. 4. 루프가 끝나면 n을 1 씩 빼기 위해 다음 작은 상호 상호를 출력합니다.

C 언어 멀티 스레드 프로그래밍 : 초보자 안내서 및 문제 해결 C 언어 멀티 스레드 프로그래밍 : 초보자 안내서 및 문제 해결 Apr 04, 2025 am 10:15 AM

C 언어 멀티 스레딩 프로그래밍 안내서 : 스레드 생성 : pthread_create () 함수를 사용하여 스레드 ID, 속성 및 스레드 함수를 지정합니다. 스레드 동기화 : 뮤텍스, 세마포어 및 조건부 변수를 통한 데이터 경쟁 방지. 실제 사례 : 멀티 스레딩을 사용하여 Fibonacci 번호를 계산하고 여러 스레드에 작업을 할당하고 결과를 동기화하십시오. 문제 해결 : 프로그램 충돌, 스레드 정지 응답 및 성능 병목 현상과 같은 문제를 해결합니다.

CS 주 3 CS 주 3 Apr 04, 2025 am 06:06 AM

알고리즘은 문제를 해결하기위한 일련의 지침이며 실행 속도 및 메모리 사용량은 다양합니다. 프로그래밍에서 많은 알고리즘은 데이터 검색 및 정렬을 기반으로합니다. 이 기사에서는 여러 데이터 검색 및 정렬 알고리즘을 소개합니다. 선형 검색은 배열 [20,500,10,5,100,1,50]이 있으며 숫자 50을 찾아야한다고 가정합니다. 선형 검색 알고리즘은 대상 값이 발견되거나 전체 배열이 통과 될 때까지 배열의 각 요소를 하나씩 점검합니다. 알고리즘 플로우 차트는 다음과 같습니다. 선형 검색의 의사 코드는 다음과 같습니다. 각 요소를 확인하십시오. 대상 값이 발견되는 경우 : true return false clanue 구현 : #includeintmain (void) {i 포함

C 언어로 파일 처리를위한 팁 문제 해결 C 언어로 파일 처리를위한 팁 문제 해결 Apr 04, 2025 am 11:15 AM

C 언어 처리 파일에 대한 팁 문제 해결 C 언어로 파일을 처리 할 때 다양한 문제가 발생할 수 있습니다. 다음은 일반적인 문제와 해당 솔루션입니다. 문제 1 : 파일 코드를 열 수 없음 : 파일*fp = fopen ( "myfile.txt", "r"); if (fp == null) {// 파일 열기 실패} 이유 : 파일 경로 오류 파일이 존재하지 않으면 파일을 확인하여 파일에 실패한 문제 : 파일 읽기 문제 2 : 코드를 확인하십시오. charbuffer [100]; size_tread_bytes = fread (버퍼, 1, siz

C 언어 기능의 개념 C 언어 기능의 개념 Apr 03, 2025 pm 10:09 PM

C 언어 기능은 재사용 가능한 코드 블록입니다. 입력, 작업을 수행하며 결과를 반환하여 모듈 식 재사성을 향상시키고 복잡성을 줄입니다. 기능의 내부 메커니즘에는 매개 변수 전달, 함수 실행 및 리턴 값이 포함됩니다. 전체 프로세스에는 기능이 인라인과 같은 최적화가 포함됩니다. 좋은 기능은 단일 책임, 소수의 매개 변수, 이름 지정 사양 및 오류 처리 원칙에 따라 작성됩니다. 함수와 결합 된 포인터는 외부 변수 값 수정과 같은보다 강력한 기능을 달성 할 수 있습니다. 함수 포인터는 함수를 매개 변수 또는 저장 주소로 전달하며 함수에 대한 동적 호출을 구현하는 데 사용됩니다. 기능 기능과 기술을 이해하는 것은 효율적이고 유지 가능하며 이해하기 쉬운 C 프로그램을 작성하는 데 핵심입니다.