php 편집기 Baicao에서는 gcc(mingw32)를 사용하여 정적 라이브러리로 DLL을 컴파일하는 방법을 소개합니다. 개발 프로세스 중에는 다른 프로젝트에서 쉽게 호출할 수 있도록 정적 라이브러리를 DLL로 패키징해야 하는 경우가 많습니다. 정적 라이브러리로 DLL을 컴파일하기 위해 gcc(mingw32)를 사용하는 방법은 비교적 간단하며 특정 단계를 따르기만 하면 됩니다. 먼저 mingw32 및 gcc 컴파일러가 설치되어 있는지 확인하십시오. 그런 다음 명령줄에 gcc -shared -o libname.dll libname.a를 입력하여 DLL 파일을 생성합니다. 이렇게 하면 다른 프로젝트에서 사용할 수 있도록 정적 라이브러리를 DLL로 쉽게 컴파일할 수 있습니다.
외부 도구(예: cgo)로 생성된 정적 라이브러리가 있는데 libsecondary.a라고 부르겠습니다. "libsecondary.a"를 종속성으로 포함하면서 동적 라이브러리를 생성하려고 합니다. libsecondary.h에서 onprocessinit()라는 함수를 내보내고 dll_process_attach 이벤트에서 호출합니다.
공유 라이브러리 생성을 시도했지만 작동하지 않는 것 같습니다. x86_64-w64-mingw32-share-l. -lsecondary -static-libgcc -static-libstdc++ -static .dllmain.c
오류 출력은 다음과 같습니다. dllmain.c:(.text+0x9b): 'onprocessinit'에 대한 정의되지 않은 참조, 무슨 일이 일어나고 있나요?
헤더 파일 libsecondary.h입니다
으아악dllmain.c입니다
65be0f35ebbcbc내보낸 golang 함수입니다(go build -buildmode=c-archive를 사용하여 컴파일한 함수)
/* code generated by cmd/cgo; do not edit. */ /* package command-line-arguments */ #line 1 "cgo-builtin-export-prolog" #include <stddef.h> #ifndef go_cgo_export_prologue_h #define go_cgo_export_prologue_h #ifndef go_cgo_gostring_typedef typedef struct { const char *p; ptrdiff_t n; } _gostring_; #endif #endif /* start of preamble from import "c" comments. */ /* end of preamble from import "c" comments. */ /* start of boilerplate cgo prologue. */ #line 1 "cgo-gcc-export-header-prolog" #ifndef go_cgo_prologue_h #define go_cgo_prologue_h typedef signed char goint8; typedef unsigned char gouint8; typedef short goint16; typedef unsigned short gouint16; typedef int goint32; typedef unsigned int gouint32; typedef long long goint64; typedef unsigned long long gouint64; typedef goint64 goint; typedef gouint64 gouint; typedef size_t gouintptr; typedef float gofloat32; typedef double gofloat64; #ifdef _msc_ver #include <complex.h> typedef _fcomplex gocomplex64; typedef _dcomplex gocomplex128; #else typedef float _complex gocomplex64; typedef double _complex gocomplex128; #endif /* static assertion to make sure the file is being used on architecture at least with matching size of goint. */ typedef char _check_for_64_bit_pointer_matching_goint[sizeof(void*)==64/8 ? 1:-1]; #ifndef go_cgo_gostring_typedef typedef _gostring_ gostring; #endif typedef void *gomap; typedef void *gochan; typedef struct { void *t; void *v; } gointerface; typedef struct { void *data; goint len; goint cap; } goslice; #endif /* end of boilerplate cgo prologue. */ #ifdef __cplusplus extern "c" { #endif extern __declspec(dllexport) void onprocessinit(); #ifdef __cplusplus } #endif
와우, 답은 인수 위치입니다,
x86_64-w64-mingw32 -shared -static-libgcc -static-libstdc++ -static .dllmain.c .libsecondary.a
뒤로 입력하면 libsecondary.a에서 참조를 찾을 수 없습니다. 맙소사...
위 코드는 syscall.NewLazyDLL이 LoadLibraryA를 호출하고 DLL_PROCESS_ATTACH에 잠겨 있기 때문에 로드 시 교착 상태에 빠지므로 해결 방법은 CreateThread를 사용하고 스레드 내에서 golang 내보낸 함수를 실행하는 것입니다. :)
위 내용은 gcc(mingw32)를 사용하여 정적 라이브러리로 DLL 컴파일의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!