C를 사용하는 동안 개발자는 변수를 괄호로 묶은 선언을 허용하는 다소 혼란스러운 구문을 발견했을 수 있습니다. int (x) = 0;과 같은 선언 또는 심지어 int (((x))) = 0; 그 목적과 실용성이 궁금할 수 있습니다.
이 수수께끼에 대한 답은 그룹화의 개념에 있습니다. f(int) 유형의 함수에 대한 포인터를 선언하는 예를 고려하십시오. 표준 접근 방식인 int *f(int);는 int*를 반환하는 함수로 해석됩니다. 그러나 해당 함수에 대한 포인터를 올바르게 지정하려면 int (*f)(int); 형식으로 괄호를 사용해야 합니다.
이 동일한 원칙이 배열 선언에도 적용됩니다. 선언 int *x[5]; 5개의 int* 배열을 나타내는 반면 int (*x)[5]; 5개의 int 배열을 가리킵니다.
제공된 코드 조각에서:
struct B { }; struct C { C (B *) {} void f () {}; }; int main() { B *y; C (y); // Oops, compiler error! }
소멸자에서 유용한 작업을 수행하는 C 유형의 개체를 구성하는 것이 목적입니다. 그러나 컴파일러는 C(y)를 잘못 해석합니다. C 유형의 변수 y를 선언하면 재정의 오류가 발생합니다. 여기서 괄호 그룹화가 시작됩니다. 생성자 호출을 C(y) 대신 C(y)로 묶으면 컴파일러의 해석이 수정되어 코드가 의도한 대로 컴파일될 수 있습니다.
위 내용은 C 변수 선언에 괄호를 사용하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!