C 언어 논리 및 비트 연산자 이해하기

  • 2 minutes to read

논리 및 비트 연산자 이해하기

C 언어에서 논리 연산자와 비트 연산자를 사용하여 복잡한 조건 및 계산을 수행할 수 있습니다. 이 아티클에서는 간단한 예제 코드를 통해 이러한 연산자들의 사용법을 설명하고, 코드의 출력 결과를 예측해 보겠습니다.

소스 코드 분석 및 변형

주어진 코드는 다음과 같은 변수와 연산자를 사용합니다:

코드: logical_and_bitwise_operations.c

#include <stdio.h>

main()
{
   int a = 5, b = 4, c = 9, d = 10;

   printf("%d\n", a < b || c > d);     // 논리 OR 연산
   printf("%d\n", (!d - 10) << 2);    // 비트 왼쪽 시프트 연산
   printf("%d\n", (5 < b) & (c != d)); // 비트 AND 연산
   printf("%d\n", c == 9);             // 등호 연산
   printf("%d\n", ++d >> 3 | 6);       // 비트 OR 연산과 비트 오른쪽 시프트 연산
}

코드 출력 결과 예측

  1. 논리 OR 연산 (a < b || c > d):

    • a < b5 < 4이므로 false (0).
    • c > d9 > 10이므로 false (0).
    • 둘 중 하나라도 참이면 참: 0 || 00.

    출력: 0

  2. 비트 왼쪽 시프트 연산 ((!d - 10) << 2):

    • !d!10, 즉 0 (논리 NOT 연산).
    • 0 - 10-10.
    • -10 << 2-10을 왼쪽으로 2비트 시프트. 2의 보수 표현에서 -10은 대략적으로 32비트 정수로 11111111 11111111 11111111 11110110. 이를 왼쪽으로 2비트 시프트하면 11111111 11111111 11111111 11011000.

    출력: -40 (이진수 11011000의 2의 보수)

  3. 비트 AND 연산 ((5 < b) & (c != d)):

    • 5 < b5 < 4이므로 false (0).
    • c != d9 != 10이므로 true (1).
    • 둘 다 참일 때만 참: 0 & 10.

    출력: 0

  4. 등호 연산 (c == 9):

    • c9, c == 9true.

    출력: 1

  5. 비트 OR 연산과 비트 오른쪽 시프트 연산 (++d >> 3 | 6):

    • ++dd를 먼저 1 증가시켜 11이 됩니다.
    • 11 >> 311을 오른쪽으로 3비트 시프트, 즉 1.
    • 1 | 60111, 즉 7.

    출력: 7

VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com