별도의 Visual Studio 2010 프로젝트에 있는 C 코드에서 C 함수를 호출할 때 링커 오류가 발생합니다.
C 코드를 C 프로젝트에 통합하려고 할 때 Visual Studio 2010에서는 개발자에게 링커 오류가 발생할 수 있습니다. 이 문제는 정적 또는 동적 라이브러리를 연결할 때 발생합니다. 파일 이름 지정 및 매크로의 불일치한 코드 구성과 불일치로 인해 이러한 오류가 발생할 수 있습니다.
적절한 파일 구성 및 선언
C 및 C에서 각 개체 또는 모듈은 다음과 같아야 합니다. 자체 헤더 파일과 소스 코드 파일로 명확하게 구분됩니다. 여러 C 함수의 경우 헤더 파일(예: function.h)과 소스 코드 파일(예: function.c)을 권장합니다.
함수 내보내기
다른 프로젝트에서 기능에 액세스할 수 있도록 하려면 적절한 내보내기 메커니즘을 구현해야 합니다. C에서는 헤더 파일의 함수 선언 앞에 extern 키워드를 추가하면 됩니다. 그러나 C에서는 extern "C" 매크로를 사용해야 합니다. 또한 코드가 함수를 내보내는지 아니면 가져오는지 지정하기 위해 매크로를 정의해야 할 수도 있습니다.
컴파일러 및 링커 설정
Visual Studio 2010에서는 특정 프로젝트 설정이 적절한 컴파일과 링크를 보장하도록 구성해야 합니다. 이러한 설정에는 매크로 확장 및 함수 내보내기/가져오기 동작을 제어하는 데 사용할 수 있는 전처리기 정의가 포함됩니다.
재구성된 코드 구조
<code class="c">#include <stdio.h> #if defined(_WIN32) # if defined(FUNCTIONS_STATIC) # define FUNCTIONS_EXPORT_API # else # if defined(FUNCTIONS_EXPORTS) # define FUNCTIONS_EXPORT_API __declspec(dllexport) # else # define FUNCTIONS_EXPORT_API __declspec(dllimport) # endif # endif #else # define FUNCTIONS_EXPORT_API #endif #if defined(__cplusplus) extern "C" { #endif FUNCTIONS_EXPORT_API char *dtoa(double, int, int, int*, int*, char**); FUNCTIONS_EXPORT_API char *g_fmt(char*, double); FUNCTIONS_EXPORT_API void freedtoa(char*); #if defined(__cplusplus) } #endif</code>
<code class="c">#define FUNCTIONS_EXPORTS #include "functions.h" char *dtoa(double, int, int, int*, int*, char**) { // Function Implementation } char *g_fmt(char*, double) { // Function Implementation } void freedtoa(char*) { // Function Implementation }</code>
이러한 지침을 채택하고 적절한 파일 구성, 함수 선언 및 내보내기 메커니즘을 보장함으로써 Visual Studio 2010의 C 프로젝트에 C 코드를 통합하고 여러 프로젝트에 걸쳐 C 코드에서 C 함수를 호출할 때 링커 오류를 해결할 수 있습니다.
위 내용은 Visual Studio 2010에서 C 코드를 C 프로젝트에 통합하고 링커 오류를 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!