>백엔드 개발 >Golang >gcc(mingw32)를 사용하여 정적 라이브러리로 DLL 컴파일

gcc(mingw32)를 사용하여 정적 라이브러리로 DLL 컴파일

PHPz
PHPz앞으로
2024-02-09 10:00:111023검색

使用 gcc (mingw32) 编译带有静态库的 DLL

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

Solution

와우, 답은 인수 위치입니다,

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제