백엔드 개발 C#.Net 튜토리얼 C 언어에서 매크로 정의를 정의하는 방법

C 언어에서 매크로 정의를 정의하는 방법

May 05, 2019 am 10:19 AM
c 언어

매크로 정의는 일반적으로 사용되는 전처리 명령으로, "식별자"를 사용하여 "대체 목록"의 내용을 나타냅니다. 식별자를 매크로 이름이라고 합니다. 전처리 과정에서 전처리기는 소스 프로그램의 모든 매크로 이름을 매크로 정의의 대체 목록에 있는 내용으로 바꿉니다.

C 언어에서 매크로 정의를 정의하는 방법

두 가지 일반적인 매크로 정의, 즉 매개변수가 없는 매크로 정의와 매개변수가 있는 매크로 정의가 있습니다.

매크로 정의는 오류 방지, 코드 이식성 및 가독성 향상 등에 도움이 될 수 있습니다.
소프트웨어 개발 프로세스에는 일반적으로 사용되거나 일반적인 기능이나 코드 세그먼트가 있는 경우가 많습니다. 이러한 기능은 함수로 작성되거나 매크로 정의로 캡슐화될 수 있습니다. 그렇다면 함수나 매크로 정의를 사용하는 것이 더 낫습니까? 이를 위해서는 둘 사이에서 합리적인 선택을 해야 합니다.
 두 숫자 또는 표현식의 크기를 비교하는 예를 살펴보겠습니다. 먼저 이를 매크로 정의로 작성합니다.

  #define MAX( a, b) ( (a) > (b) (a) : (b) )  
  # 其次,把它用函数来实现:
  int max( int a, int b)
  {
  return (a > b a : b)
  }
로그인 후 복사

 분명히 두 가지 이유 때문에 이 작업을 완료하기 위해 함수를 사용하지 않을 것입니다. , 함수 호출은 추가 오버헤드를 가져옵니다. 스택 공간을 열고, 반환 주소를 기록하고, 형식 매개변수를 스택에 푸시하고, 함수에서 반환할 때 스택을 해제해야 합니다. 이러한 오버헤드는 코드 효율성을 감소시킬 뿐만 아니라 코드 양을 크게 증가시킵니다. 둘째, 함수의 매개변수는 특정 유형으로 선언되어야 합니다. 따라서 이는 적절한 유형의 표현식에만 사용할 수 있습니다. 두 부동 소수점 유형의 크기를 비교하려면 특히 부동 소수점 유형에 대한 비교 함수를 작성해야 합니다. 반대로 위의 매크로 정의는 정수, 긴 정수, 단일 부동 소수점 유형, 이중 부동 소수점 유형 및 ">" 연산자를 사용하여 값의 크기를 비교할 수 있는 모든 유형에 사용할 수 있습니다. , 매크로는 유형과 무관합니다.
함수 사용과 비교했을 때 매크로 사용의 단점은 매크로를 사용할 때마다 매크로 정의 코드의 복사본이 프로그램에 삽입된다는 것입니다. 매크로가 매우 짧지 않은 한 매크로를 사용하면 프로그램 길이가 크게 늘어날 수 있습니다.

위 내용은 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를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

C 언어에서 typedef 구조체 사용법 C 언어에서 typedef 구조체 사용법 May 09, 2024 am 10:15 AM

typedef struct는 C 언어에서 구조 사용을 단순화하기 위해 구조 유형 별칭을 만드는 데 사용됩니다. 구조 별칭을 지정하여 기존 구조에 새 데이터 유형의 별칭을 지정합니다. 향상된 가독성, 코드 재사용 및 유형 확인 등의 이점이 있습니다. 참고: 별칭을 사용하기 전에 구조를 정의해야 합니다. 별칭은 프로그램에서 고유해야 하며 선언된 범위 내에서만 유효해야 합니다.

C 언어에서 strcpy와 strcat의 차이점 C 언어에서 strcpy와 strcat의 차이점 May 08, 2024 pm 01:03 PM

strcpy는 문자열을 다른 문자열에 복사하고, strcat는 문자열을 다른 문자열에 추가합니다. 주요 차이점은 다양한 목적, 다양한 dst 매개변수 처리 및 다양한 보안 고려사항을 포함합니다.

C 언어에서 Real은 무엇을 의미합니까? C 언어에서 Real은 무엇을 의미합니까? May 09, 2024 pm 12:06 PM

real은 C 언어에서 배정밀도 부동 소수점 숫자를 나타내는 데 사용되는 데이터 유형입니다. 8바이트를 차지하고 소수점 이하 약 15자리의 정밀도를 가지며 범위는 [-1.7976931348623157e+308, 1.7976931348623157e+308]입니다.

C 언어에서 scanf 오류가 발생하면 어떻게 해야 할까요? C 언어에서 scanf 오류가 발생하면 어떻게 해야 할까요? May 09, 2024 am 11:39 AM

C 언어에서 scanf 함수 오류를 처리하는 방법은 다음과 같습니다. 1. 형식 문자열을 확인합니다. 3. 반환 값을 확인합니다. 4. 오류 처리 기능을 사용합니다. 사용자 정의 오류가 처리됩니다. 오류를 방지하려면 올바른 데이터 유형을 사용하고, 입력의 유효성을 주의 깊게 확인하고, 반환 값을 확인하고, 프로그램의 잠재적인 오류를 처리하십시오.

C 언어로 거듭제곱 함수를 구현하는 방법 C 언어로 거듭제곱 함수를 구현하는 방법 May 09, 2024 pm 11:33 PM

C 언어에는 지수 연산을 구현하는 두 가지 방법이 있습니다. pow() 함수를 사용하여 첫 번째 매개변수의 두 번째 매개변수의 거듭제곱을 계산합니다. 재귀적으로 또는 반복적으로 구현할 수 있는 사용자 정의 검정력 함수를 정의합니다. 재귀적 방법은 검정력이 0이 될 때까지 계속해서 두 배로 증가합니다. 반복 방법은 루프를 사용하여 밑수를 하나씩 곱합니다.

_C 언어의 복잡한 사용법 _C 언어의 복잡한 사용법 May 08, 2024 pm 01:27 PM

복소수 유형은 C 언어에서 실수부와 허수부를 포함하는 복소수를 나타내는 데 사용됩니다. 초기화 형태는 complex_number = 3.14 + 2.71i 이며 실수부분은 creal(complex_number)를 통해, 허수부분은 cimag(complex_number)를 통해 접근할 수 있습니다. 이 유형은 덧셈, 뺄셈, 곱셈, 나눗셈 및 모듈로와 같은 일반적인 수학 연산을 지원합니다. 또한 cpow, csqrt, cexp 및 csin과 같은 복소수 작업을 위한 함수 세트가 제공됩니다.

C 언어에서 제한을 사용하는 방법 C 언어에서 제한을 사용하는 방법 May 08, 2024 pm 01:30 PM

제한 키워드는 포인터를 통해서만 변수에 액세스할 수 있음을 컴파일러에 알리고 정의되지 않은 동작을 방지하고 코드를 최적화하며 가독성을 향상시키는 데 사용됩니다. 여러 포인터가 동일한 변수를 가리킬 때 정의되지 않은 동작을 방지합니다. 코드를 최적화하기 위해 컴파일러는 제한 키워드를 사용하여 변수 액세스를 최적화합니다. 포인터를 통해서만 변수에 액세스할 수 있음을 표시하여 코드 가독성을 향상시킵니다.

_C언어에서 bool은 무슨 뜻인가요? _C언어에서 bool은 무슨 뜻인가요? May 08, 2024 pm 01:33 PM

_Bool은 C 언어에서 true 또는 false 두 가지 값만 포함하는 간단한 데이터 유형입니다. 조건이나 논리식의 결과를 나타내는 데 사용되며 일반적으로 1바이트의 메모리를 차지하며 true 또는 false만 저장할 수 있습니다. 거짓. 거짓 값.

See all articles