linux工具命令:
nm: 显示目标文件中的符号清单。
idconfig :把动态库放入缓存,目的是为了程序执行快一点。
ldd:查看程序依赖哪些库。
strip: 去掉目标文件中的冗余信息。A.out,一般是调试相关的信息。
objdump: 显示目标文件中的附加信息。
1、加载执行动态库:(自己加载动态库)
dlopen(dynamic link)
Void *dlopen(const char* filename, int flag); 打开一个动态库文件,返回一个指针作为句柄handle,失败返回null。
潜规则:返回指针的函数一般用正常地址表示成功,NULL表示失败。个别返回(void*) 0xffffffff 表示(-1)失败。
Char* dlerror(void); 取得一个字符串描述动态库操作发生了什么错误
Void* dlsym(void * handle, const char* sybol); 查找指定的符号名在动态库中的地址,失败返回null(一般的做法:在执行dlsym前执行dlerror,dlsym之后再执行dlerror ,判断后一次的返回值是否非空来判断是否失败)
Int dlclose(void * handle); 关闭动态库,从内存卸载。
头文件: #include <dlfcn.h>
2、访问环境变量
env/set
int main(int argc, char* argv[] , char* env[]);
env 是一个字符串数组,每个元素是一个环境变量字符串。env没有元素个数,他是通过一个值为null的元素来表示结束。
潜规则:向一个函数传递指针数组时,一般不传递个数,而是将null作为指针数组的结束元素。
以下例子说明environ 是外部变量,linux已经定义的变量。
3、进程内存分段:
代码段(函数和一些常量) 数据段(带初始化的全局变量与静态局部变量)
BSS(未初始化的全局变量和静态局部变量) 堆(动态分配的内存)
栈(普通局部变量)
所谓的段错误,是因为两个变量不在同一个段当中,所以我们有时候赋值的时候回出现段错误。
mmap/unmmap(内存映射,解除映射)
sbrk/brk(重新指定数据段的结束位置)
如果对某一个函数网开一面,可以访问某个类的私有成员。叫做友元函数。
在某一个类中加入: friend + 函数声明。定义放在类外面,当然也可以在类里面直接定义,但它依然是友元,不是成员函数。