知识大全 Linux 动态函式库解析(四)

Posted

篇首语:直如朱丝绳,清如玉壶冰。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 Linux 动态函式库解析(四)相关的知识,希望对你有一定的参考价值。

Linux 动态函式库解析(四)  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

  摘要 我想各位读者应该对于 Linux 上的动态函式库的架构有了进一步的了解 笔者根据自己电脑 Linux 的记忆体配置画了下面的架构图 相信会让有心了解整个运作的人 有了更清楚的一个印象     结束语       最后 我想各位读者应该对于 Linux 上的动态函式库的架构有了进一步的了解 笔者根据自己电脑 Linux 的记忆体配置画了下面的架构图 相信会让有心了解整个运作的人 有了更清楚的一个印象       在这张图中 我们所执行的程序是由记忆体 x 开始载入的 而所用到的动态函式库则是在记忆体位置 x 开始载入 以笔者的电脑为例 动态函式库载入的记忆体映射情况大略为      /usr/share/locale/en_US/LC_MESSAGES/SYS_LC_MESSAGES    /usr/share/locale/en_US/LC_MONETARY    /usr/share/locale/en_US/LC_TIME    b /lib/libnss_files so    b c /lib/libnss_files so    c f /lib/libc so    f fb /lib/libc so    fb ff    ff /lib/ld so    /lib/ld so    b /lib/libnss_nisplus so ┅(more)       若我们程序透过 malloc 配置动态的记忆体 则会配置在标示为 Free Space 的记忆体空间中 程序所用到的堆叠(Stack) 是由 xbfffffff 开始 往下延伸       而在记忆体位置 xc 以上 则是属于 Kernel Mode 的部分 这部份包含了Linux Kernel 的 Image 以及我们之后所动态载入的模组       文章到此正式结束了 读者若有任何的问题或是这篇文章有任何疏漏的部份 欢迎各位可以来信指教 谢谢各位 ^_^My E Mail:       注一:(~mcculley/mapself/)笔者在写这篇文章时 在一个网页上看到一个很有意思的记忆体区块拷贝效率比较 我们知道在Linux下面如果要把记忆体区块由 A 拷贝到 B 我们除了可以使用memcpy来完成以外 还可以透过mmap来开启档案/proc/self/mem 来完成拷贝记忆体区块的目的 举个例子来说 如果我们要把记忆体区块由A拷贝到B共 chunksize 个bytes 可以透过如下的写法     memcpy(B A chunksize);       透过 mmap 来做的话 可以借由以下的写法     int self;   self = open( /proc/self/mem O_RDONLY);   B = mmap(B chunksize PROT_READ | PROT_WRITE   MAP_PRIVATE | MAP_FIXED self (off_t)A);      也就是透过 Linux 提供给每个 Process 的记忆体装置档案 mem 来完成记忆体的拷贝动作       不过 虽然我们可以有这两种方法可以选择 可是遇到要拷贝记忆体时 却不免会遇到要选择何种方式来实做的问题 因此该网页的作者写了一个小程序来测试这两种方式的优缺点 首先在 Linux 上每个记忆体的 Page 大小为 bytes 因此测试时就是利用 bytes为单位来逐渐增加测试的记忆体区块大小 每个阶段都有一个固定的记忆体区块大小 与两个内容不同的记忆体区块作为拷贝时的来源端 每一个循环都会先拷贝一个来源端到目的的记忆体区块中 再比较内容 若相同 则拷贝另一个来源端的资料到目的的记忆体区块中 再比较内容 如此重复 次(表示共拷贝了 次到目的记忆体区块中) 借此来比较 memcpy 与 mmap 在执行记忆体区块拷贝时的效率       如下表(笔者电脑配备: PII MB RAM)     memcpy mmap                               我们不难发现当记忆体区块为 时 memcpy 都胜过mmap 不过当拷贝的记忆体区块越来越大时 mmap 明显表现的相当有效率 像最后测试的记忆体区块大小为 bytes mmap 相较于 memcpy所花的时间少了约 秒钟       由此我们可以了解到 如果在 Linux 上我们所撰写的系统需要使用较大的记忆体区块拷贝时 透过 mmap 来作或许是一个不错的选择    cha138/Article/program/Oracle/201311/16613

相关参考

知识大全 Linux 动态函式库解析(二)

Linux动态函式库解析(二)  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  动态连结VS静态联

知识大全 LINUX系统中动态链接库的创建与使用

LINUX系统中动态链接库的创建与使用  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  大家都知道

知识大全 linux生成(加载)动态库静态库和加载示例方法

  动态库的生成  /*mysumc*/    复制代码代码如下:  #include<stdioh>#includesrch  intsum(intaintb)return(a+b);&

知识大全 根据下列条件分别求二次函式的解析式(1)抛物线经过(0,3)(1,0)(3,0)

根据下列条件分别求二次函式的解析式(1)抛物线经过(0,3)(1,0)(3,0)(1)抛物线经过(0,3)(1,0)(3,0)第二个第三个点就是影象与X轴的交点了可设抛物线为y=a(x-1)(x-3)

知识大全 关于VB.NET动态连接库使用四点总结

关于VB.NET动态连接库使用四点总结  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  VBNET

知识大全 什么是点函式

什么是点函式?点函式的定义:从点集到实数集的对映,称为“点函式”,有了点函式的概念,就可以把一元函式、二元函式、三元函式、……、n元函式的概念都统一到点函式的概念,更利于我们对函式实质的理解。把实数x

知识大全 已知定义域为R的函式f(x)在区间(8,+∞)上为减函式,且函式y=f(x+8)为偶函式则

已知定义域为R的函式f(x)在区间(8,+∞)上为减函式,且函式y=f(x+8)为偶函式则  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后

知识大全 已知y=f(x)是偶函式,且在[0,+∞)上是减函式,则f(1-x 2)是增函式的区间是() 求过

已知y=f(x)是偶函式,且在[0,+∞)上是减函式,则f(1-x2)是增函式的区间是()求过由题意,y=f(x)是偶函式,且在[0,+∞)上是减函式,所以y=f(x)在(-∞,0]上是增函式.解1-

知识大全 Linux下的编程 PHP高级技巧全放送(二)

Linux下的编程PHP高级技巧全放送(二)  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  四P

知识大全 函式在闭区间可导,那么其导函式在该闭区间是否连续

函式在闭区间可导,那么其导函式在该闭区间是否连续?是的,可导可以推出连续,但是连续不能推出可导。如果一个函式在x0处可导,那么它一定在x0处是连续函式。函式可导定义:(1)设f(x)在x0及其附近有定