调用so失败,dlopen 报 cannot restore segment prot after reloc: Permission denied
解决:chcon -t texrel_shlib_t *.so
执行可执行文件, 报cannot open shared object file: No such file or directory
export LD_LIBRARY_PATH=../dll
../dll 为so所在路径
so delete 指针失败,产生core dump
so 中导出函数产生一个类指针,该指针是new返回的,且调用delete是该指针也非空,但是仍产生core。
注意:看是否在类的析构中先dlclose 了,必须先delete 导出的指针,才能dlclose。
make出错
undefined reference to `dlopen'
undefined reference to `dlerror'
undefined reference to `dlsym'
undefined reference to `dlerror'
undefined reference to `dlclose'
makfile中 注意 加 -ldl
make时报 undefined reference to `__gxx_personality_v0'
makefile的的编译 CC=gcc 改为 CC=g++ 可解决
makefile
dll
target=../dll/Calculate.so
OBJ = calculate.o
INCLUDE=-I../include
CFLAGS = -g
LDFLAGES=-fPIC -shared
all:$(target)
$(target):$(OBJ)
$(CC) $(LDFLAGES) $(INCLUDE) $(CFLAGS) -o $@ $^
$(OBJ): calculate.cpp
$(CC) $(CFLAGS) $(INCLUDE) -c $<
clean:
rm -rf $(target) $(OBJ)
测试执行文件
core 是之前析构指针问题产生
CC=g++
CFLAGS=-g
INCLUDE=-I../include
TARGET=../bin/test
OBJ=teststddll.o
LIB_DIR=../dll
LDFLAGS=-L$(LIB_DIR) -lCalculate.so
LDFLAGS=
all:$(TARGET)
$(TARGET):$(OBJ)
$(CC) $(CFLAGS) $(INCLUDE) -ldl $(LDFLAGS) -o $@ $^
$(OBJ):teststddll.cpp
$(CC) $(CFLAGS) $(INCLUDE) -c $<
clean:
rm -rf $(TARGET) $(OBJ)
注意:调用 动态连接库
-l后面接的是链接库会默认加前缀lib 和后缀.so,例如你需要链接一个liba.so的动态库,你使用的方法应该是-la,如果你不使用-l指明,则需要使用liba.so的绝对路经。(绝对路径可以用于自己名的库,如自己的库名并无lib前缀)。
编译报/usr/bin/ld: cannot find 错时,可注意该项。
静态库
makefile
CC=gcc
CFLAGS=-g
TARGET=../lib/libcalculate.a
OBJ=calculate.o
AR=ar
all: $(TARGET)
$(TARGET): $(OBJ)
$(AR) rcsv $@ $^
$(OBJ): calculate.cpp
$(CC) $(CFLAGS) -c $<
clean:
rm -rf $(OBJ) $(TARGET)
测试使用静态库
CC=g++
CFLAGES=-g
INCLUDE=-I../include
TARGET=test
OBJ=test.o
LDFLAGS=
all:$(TARGET)
$(TARGET):$(OBJ)
$(CC) $(CFLAGES) $(INCLUDE) $(LDFLAGS) -o $@ $^ ../lib/libcalculate.a
$(OBJ): test.cpp
$(CC) $(CFLAGES) $(INCLUDE) -c $<
clean:
rm -rf $(TARGET) $(OBJ)