gpt4 book ai didi

c - 共享全局变量: interaction between main, lib.a和dll

转载 作者:行者123 更新时间:2023-11-30 17:11:47 24 4
gpt4 key购买 nike

我保留了必需品。

caller.exe加载dll,然后调用dll内部声明的函数dll_init。

最后一个函数调用公共(public)库中声明的函数“get_ptr”,该函数应返回指向全局变量的指针。

问题是:

  • 每当 caller.exe 调用“get_ptr”时,它都会返回一个有效的指针,该指针与之前在 caller.exe 正常启动时分配的指针相同。
  • 每当 dll 通过它的函数“dll_init”(在被调用之后)caller.exe)调用“get_ptr”(知道该 dll 链接到static lib) 它返回 NULL 指针。

我缺少什么?

libcommon.c

#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
/***************header****************/
int *get_ptr(void);
int set_ptr(void);
/**********************************/

int *global=NULL;
//extern __declspec(dllimport) int *global; doesnt work

int set_ptr() {
global = (int *) malloc(sizeof(int));
printf("global allocated to %p\n",global);
*global=485; //random value
return 0;
}

int *get_ptr() {
return global;
}

这里是编译命令(makefile 简化):

gcc.exe -c libcommon.c -o libcommon.o -m32
ar r libcommon.a libcommon.o
ranlib libcommon.a

模块.c

#include <windows.h>
#include <stdio.h>

#if BUILDING_DLL
#define DLLIMPORT __declspec(dllexport)
#else
#define DLLIMPORT __declspec(dllimport)
#endif

DLLIMPORT int dll_init(void) {
int *ptr=(int *) get_ptr();

puts("dll run");
printf("from dll global: %p\n",ptr);
puts("dll end");

return 0;
}

编译:

gcc.exe -c module.c -o module.o -m32 -DBUILDING_DLL=1
gcc.exe -shared module.o -o module.dll -static-libgcc -lws2_32 -m32 -s -L"." -lcommon -Wl,--output-def,libmodule.def,--out-implib,libmodule.a,--add-stdcall-alias

来电者.c

#include <stdio.h>
#include <stdlib.h>
#include <windows.h>

typedef void(voidfunc)(void);
voidfunc *fct_ptr;

int test(int a) {
printf("%d",a++);
}

int main() {
set_ptr();
printf("::%p\n",get_ptr());

/* Load the dll then call dll_init */
HMODULE dllptr = LoadLibrary("module.dll");
if (dllptr != NULL) {
fct_ptr = (voidfunc *) GetProcAddress(dllptr, "dll_init");
puts("loaded");
if (fct_ptr != NULL)
fct_ptr();
FreeLibrary(dllptr);
}
}

编译:

gcc.exe caller.c -o caller.exe -m32 -static-libgcc -lws2_32 -L. -lcommon -m32

最佳答案

I believe you have 2 different places in memory named global. One is in caller since you compiled it statically with lcommon. Data is set there via set_ptr. Second is in module space (for the same reasons), but you never called set_ptr() there. Check memory address of global inside dll_init and in main. If they are not the same, you then need to call set_ptr in your `dll_init``

他是对的,我认为与 exe 和 dll 链接的公共(public)静态库是一个错误的想法。解决方案在这里:.dll Plugin that uses functions defined in the main executable

欢迎提出其他建议

关于c - 共享全局变量: interaction between main, lib.a和dll,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32016488/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com