> 백엔드 개발 > C++ > Void 포인터 할당이 C에서는 작동하지만 C에서는 실패하는 이유는 무엇입니까?

Void 포인터 할당이 C에서는 작동하지만 C에서는 실패하는 이유는 무엇입니까?

Patricia Arquette
풀어 주다: 2024-10-28 20:55:02
원래의
551명이 탐색했습니다.

Why Does a Void Pointer Assignment Work in C But Fail in C  ?

C와 C의 보이드 포인터 차이점 이해

프로그래밍 영역에서는 C와 C의 차이점을 이해하는 것이 중요합니다. 특히 무효 포인터의 경우. 특정 C 코드가 성공적으로 컴파일되지만 C에서는 실패하는 이유에 대해 일반적인 질문이 제기됩니다.

C 대 C에서 Void 포인터 할당

강조된 초기 문제는 불가능하다는 것입니다. malloc()에 의해 반환된 void 포인터를 정수 포인터(int*)에 할당하려면 C를 사용합니다. 그러나 C에서는 암시적 변환으로 인해 이러한 할당이 허용됩니다.

공허 포인터를 사용한 C의 명시적 변환

C와 달리 C는 명시적 변환을 시행합니다. void 포인터를 다른 포인터에 할당할 때. 즉, void 포인터(void)를 정수 포인터(int)로 변환하려면 캐스트가 필요합니다.

변환 규칙 및 K&R2 원칙

C의 K&R2 원칙에 따르면 객체에 대한 모든 포인터는 데이터 손실 없이 void* 유형으로 변환될 수 있습니다. 마찬가지로, 이 void 포인터를 원래 포인터 유형으로 다시 변환하면 원래 값이 보존됩니다.

Void 포인터 변환에 대한 C 표준

C 원칙을 기반으로 하는 C 표준에서는 T에서 void로의 변환이 암시적으로 유지되도록 규정합니다. 그러나 void*에서 다른 포인터 유형으로의 변환은 명시적으로 캐스트되어야 합니다.

요약하자면 C에서는 void 포인터와의 암시적 변환이 허용되는 반면, void*에서 다른 포인터 유형으로의 변환에는 C에서 명시적인 캐스트가 필요합니다. 이러한 구별은 유형 안전성을 보장하고 C 코드의 잠재적인 오류를 방지합니다.

위 내용은 Void 포인터 할당이 C에서는 작동하지만 C에서는 실패하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿