linux内核中memcpy和memmove函数的区别和实现

linux内核中memcpy和memmove函数的区别和实现,第1张

memcpy的效率会比memmove高一些,如果还不明白的话可以看一些两者的实现,平时很少有重叠的例子,所以只有特殊情况才考虑memmove

void *memmove(void *dest, const void *source, size_t count)

{

assert((NULL != dest) &&(NULL != source))

char *tmp_source, *tmp_dest

tmp_source = (char *)source

tmp_dest = (char *)dest

if((dest + count<source) || (source + count) <dest))

{// 如果没有重叠区域

while(count--)

*tmp_dest++ = *tmp_source++

}

else

{ //如果有重叠

tmp_source += count - 1

tmp_dest += count - 1

while(count--)

*--tmp_dest = *--tmp

}

return dest

}

void *memcpy(void *dest, const void *source, size_t count)

{

assert((NULL != dest) &&(NULL != source))

char *tmp_dest = (char *)dest

char *tmp_source = (char *)source

while(count --)//不对是否存在重叠区域进行判断

*tmp_dest ++ = *tmp_source ++

return dest

}

用户空间中动态申请内存函数为malloc (),这个函数在各种 *** 作系统上的使用都是一致的,malloc ()申请的内存的释放函数为free()。对于Linux而言,C库的malloc ()函数一般通过brk ()和mmap ()两个系统调用从内核申请内存。由于用户空间C库的malloc算法实际上具备一个二次管理能力,所以并不是每次申请和释放内存都一定伴随着对内核的系统调用。比如,代码清单11.2的应用程序可以从内核拿到内存后,立即调用free(),由于free()之前调用了mallopt(M_TRIM_THRESHOLD,一1)和mallopt (M_MMAP_MAX,0),这个free ()并不会把内存还给内核,而只是还给了C库的分配算法(内存仍然属于这个进程),因此之后所有的动态内存申请和释放都在用户态下进行。另外,Linux内核总是采用按需调页(Demand Paging),因此当malloc ()返回的时候,虽然是成功返回,但是内核并没有真正给这个进程内存,这个时候如果去读申请的内存,内容全部是0,这个页面的映射是只读的。只有当写到某个页面的时候,内核才在页错误后,真正把这个页面给这个进程。

在Linux内核空间中申请内存涉及的函数主要包括kmalloc( ) 、get free pages ( )和vmalloc ()

等。kmalloc ()和_get_free pages ()(及其类似函数)申请的内存位于DMA和常规区域的映射区,而且在物理上也是连续的,它们与真实的物理地址只有一个固定的偏移,因此存在较简单的转换关系。而vmalloc()在虚拟内存空间给出一块连续的内存区,实质上,这片连续的虚拟内存在物理内存中并不一定连续,而vmalloc ()申请的虚拟内存和物理内存之间也没有简单的换算关系。

kmalloc vmalloc

kmalloc:分配连续的物理地址,如果没有这么大的,就是败了

vmalloc: 分配虚拟地址,在物理上不一定连续

IRQ 是普通中断,FIQ是快速中断

不同处是他们的中断处理函数不同,

FIQ 优先


欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/yw/7475265.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-06
下一篇2023-04-06

发表评论

登录后才能评论

评论列表(0条)

    保存