[发明专利]一种效率提高的内存复制方法无效
申请号: | 201210393876.8 | 申请日: | 2012-10-16 |
公开(公告)号: | CN102929579A | 公开(公告)日: | 2013-02-13 |
发明(设计)人: | 姚艳松;郭立煌;周建波;雍太利;朱学海;陈靖公;王程谦 | 申请(专利权)人: | 国电南京自动化股份有限公司 |
主分类号: | G06F9/30 | 分类号: | G06F9/30 |
代理公司: | 南京纵横知识产权代理有限公司 32224 | 代理人: | 董建林 |
地址: | 210009 江苏*** | 国省代码: | 江苏;32 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 效率 提高 内存 复制 方法 | ||
技术领域
本发明涉及一种计算机系统开发方法,尤其涉及一种效率提高的内存复制方法。
背景技术
内存复制函数(memcpy函数)是计算机系统开发过程中最常用、也是最重要的库函数之一,memcpy函数的实现与平台有关,一般都要尽可能提高该函数的性能,其效率直接影响到计算机系统的性能。
memcpy函数的原型是void*memcpy(void*dest,void*src,int count),该函数实现的功能是将以src指向地址为起始地址的连续count个字节数据复制到以dest指向地址为起始地址的空间内。
以下是memcpy函数实现的一种典型方法:
由上可见,完成一个字节复制需要以下步骤:
(1)检查count是否为0,如果为0则函数返回,否则继续;
(2)把src指针指向的地址中的数据复制到tmp指针指向的地址;
(3)tmp指针加1;
(4)src指针加1;
(5)count减1;
(6)跳转到步骤(1)。
通过分析发现,CPU复制一个字节需要经过多个指令周期,尤其是在有跳转指令的情况下,CPU指令流水线被频繁打断,极大的降低了CPU执行效率。
上述方法是memcpy函数实现的最简单方法之一,实际应用中可以通过判断dest地址和src地址是否为2字节对齐或4字节对齐,CPU可以通过一条指令复制2个字节或4个字节,这种方法只能针对特殊情况,且效率提高并不明显。
发明内容
发明目的:为了克服现有技术中存在的不足,本发明提供一种效率提高的内存复制方法,使CPU进行大块内存复制操作时大幅提高效率。
技术方案:为实现上述目的,本发明采用的技术方案为:
一种效率提高的内存复制方法:包括如下步骤:
(1)判断count是否大于N,N>1;
(2)若步骤(1)的判断为是,则按次序将连续的N个字节数据从s指针指向的地址复制到tmp指针指向的地址,count=count-N、s=s+N、tmp=tmp+N,返回步骤(1);
(3)若步骤(1)的判断为否,则逐字节将数据从s指针指向的地址复制到tmp指针指向的地址。
优选的,N=16。
由上述步骤可见,CPU复制大于等于16个字节数据的时候,首先判断count是否大于16:若判断为是,则按次序将16个字节数据从s指针指向的地址复制到tmp指针指向的地址,最后将count减16、s加16,、tmp加16;若判断为否,则将小于等于16个字节数据按照通常的方法逐字节进行复制。
综上所述,在复制大量数据块时,CPU平均复制每个字节所耗的时间大幅减少,同时不会频繁使用跳转指令;经测试,复制少量字节的性能略有降低(几乎可以忽略,因为只执行了一个判断语句),而复制大块内存数据时效率可提高50%以上,节省了CPU开销,提高了复制大块内存数据的效率。
有益效果:本发明提供的效率提高的内存复制方法,在复制大量数据块时,CPU平均复制每个字节所耗的时间大幅减少,同时不会频繁使用跳转指令,节省了CPU开销,提高了复制大块内存数据的效率。
附图说明
图1为本发明方法的流程图。
具体实施方式
下面结合附图对本发明作更进一步的说明。
如图1所示为一种效率提高的内存复制方法:包括如下步骤:
(1)判断count是否大于16;
(2)若步骤(1)的判断为是,则按次序将连续的16个字节数据从s指针指向的地址复制到tmp指针指向的地址,count=count-16、s=s+16、tmp=tmp+16,返回步骤(1);
(3)若步骤(1)的判断为否,则逐字节将数据从s指针指向的地址复制到tmp指针指向的地址。
以下是根据上述方法给出的一种程序方案:
以上所述仅是本发明的优选实施方式,应当指出:对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也应视为本发明的保护范围。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于国电南京自动化股份有限公司,未经国电南京自动化股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201210393876.8/2.html,转载请声明来源钻瓜专利网。