日常记录自己的错
功能描述:一个主控进程定期读取配置文件里信息,有动态库名以及需要调用的函数名等等信息(函数名固定格式,可以用统一的函数指针),接着主控线程开启多个线程,线程使用dlopen系列函数动态加载配置文件的动态库,并调用对应的函数。
错误描述:该配置文件里配置了俩个函数,来自同一动态库,同时俩个函数都是调用该动态库里同一个函数去读取同一个文件,该函数有一个打开文件和一个关闭文件的操作,运行一段时间就会出现core,gdb定位到是fclose出现的段错误,在往下是free(),abort(),raise()等,程序错误输出有double free的问题。
错误原因:该动态库的读文件函数的文件指针定义为全局变量,动态库的全局变量应该是线程共享的,因此其中一个线程关闭该文件描述符后另外一个线程再次关闭就会出现关闭俩次的现象,从而引起段错误。
错误修改:将全局的文件描述符放到需要使用该文件描述符的函数内成为局部变量
补充:对dlopen动态加载不太了解,以为俩个线程分别去加载该动态库的话,动态库的数据会互相隔离,动态库所有数据都是线程独享的,从而导致了这个错误的产生
待补充:编译链接动态库和运行链接动态库的区别?