system函数与LD_PRELOAD变量

一次简单的调试经历


产品里使用了jemalloc替换原先的malloc函数


但是发现在图形界面上进行某项操作时,log里会出现 ERROR: ld.so: object LD_PRELOAD cannot be preloaded: ignored,

后来经查实,发现是由于代码里调用了system(const char * )函数,该函数会启动一个新的进程,并继承父进程所有的环境变量.


但是我们的产品是32位的,jemalloc也是编译成32位的,但是产品所运行的环境是SUSE LINUX 64位的,所以LINUX下所有的程序,如chmod,chgrp也是64位的,而这些程序启动时LD_PRELOAD环境变量已经被设置去载入libjemalloc.so,结果发现不兼容,于是报错cannot be preloaded: ignored,但其实根本没什么影响,因为chmod等本来的malloc就没什么问题

你可能感兴趣的:(system函数与LD_PRELOAD变量)