Linux学习

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 + 函数声明。定义放在类外面,当然也可以在类里面直接定义,但它依然是友元,不是成员函数。

?

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。