>백엔드 개발 >C++ >`goto`는 C에서 소멸자 실행을 우회합니까?

`goto`는 C에서 소멸자 실행을 우회합니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-01 04:52:14970검색

Does `goto` Bypass Destructor Execution in C  ?

Goto가 소멸자를 호출하지 않고 함수를 탐색할 수 있습니까?

goto가 코드 섹션을 건너뛰어 소멸자 및 이와 유사한 실행을 방지한다는 일반적인 오해가 지속됩니다. 운영. 이러한 오해는 특히 C를 둘러싼 토론에서 두드러집니다.

범위 제한

일반적인 믿음과는 달리 goto는 함수 경계를 넘을 수 없습니다. 다른 함수에 정의된 레이블로 이동하려고 하면 아래 그림과 같이 컴파일러 오류가 발생합니다.

void f() {
   int x = 0;
   goto lol;
}

int main() {
   f();
lol:
   return 0;
}

오류: 'lol' 레이블이 사용되었지만 정의되지 않았습니다

객체 초기화 고려 사항

객체 초기화를 건너뛰는 것도 마찬가지로 허용되지 않습니다. 개체 초기화를 건너뛰려고 하면 컴파일러에서 오류 플래그를 지정합니다.

int main() {
   goto lol;
   int x = 0;
lol:
   return 0;
}

오류: 'lol' 라벨로 점프
오류: 여기에서
오류: 교차 초기화 'int x'

범위별 파기

자동 저장 기간이 있는 개체는 종료 방법에 관계없이 해당 범위를 나갈 때 파기됩니다. 따라서 Goto는 객체 파괴를 우회할 수 없습니다.

struct T {
   T() { cout << "*T"; }
  ~T() { cout << "~T"; }
};

int main() {
   {
      T t;
      goto lol;
   }

lol:
   return 0;
}

출력: *T~T

객체 유형 제한

범위에 뛰어드는 동안 스칼라가 아닌 객체는 일반적으로 금지됩니다. 사소한 기본 생성자와 소멸자가 있는 객체에는 예외가 있습니다. 이니셜라이저가 없는 배열 선언도 예외입니다.

결론

Goto는 C의 범위 지정 메커니즘을 우회하는 허점이 아니지만 부주의하게 사용할 경우 예상치 못한 동작을 일으킬 수 있습니다. 그럼에도 불구하고 위에 설명된 제한 사항은 의도하지 않거나 유해한 goto 사용을 방지하는 보호 장치를 제공합니다. 따라서 일반적으로 인식되는 것처럼 본질적으로 악한 것은 아니지만 신중하게 적용해야 합니다.

위 내용은 `goto`는 C에서 소멸자 실행을 우회합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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