免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 11689 | 回复: 25
打印 上一主题 下一主题

如何对memcpy()进行优化 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-10-23 20:00 |只看该作者 |倒序浏览
代码如下,请问该如何优化?
另外,为什么内存拷贝要从低地址到高地址?


void* memcpy(void* dst, const void* src, size_t count)

{

    void* ret = dst;



    //copy from lower to higher


    while (count--) {

        *(char *) dst = *(char *) src;

        dst = (char *)dst + 1;

        src = (char *)src + 1;

    }

  

    return ret;

}

论坛徽章:
0
2 [报告]
发表于 2008-10-23 20:18 |只看该作者
1、

    while ( *(char *) dst++ = *(char *) src++ )
            ;


2、也可以从高向低拷贝,只要你不怕麻烦。

论坛徽章:
0
3 [报告]
发表于 2008-10-23 20:25 |只看该作者
2楼好像没考虑参数size_t count了,^-^

论坛徽章:
0
4 [报告]
发表于 2008-10-23 20:33 |只看该作者
原帖由 LinuxKen 于 2008-10-23 20:18 发表
1、

    while ( *(char *) dst++ = *(char *) src++ )
            ;


2、也可以从高向低拷贝,只要你不怕麻烦。

好像不是这么简单,这是一道面试题,
听说是vc的库函数里的,首先是少了一些必要的检查,然后是需要优化,还有就是为什么一定要从低地址到高地址拷贝
我的回答是得检查指针是否为NULL,是否相等,COUNT是否在范围内,优化部分跟你差不多,就是改成++,其他的就不知道了。

论坛徽章:
0
5 [报告]
发表于 2008-10-23 20:40 |只看该作者
counter小于0的话会出现死循环

论坛徽章:
0
6 [报告]
发表于 2008-10-23 20:52 |只看该作者
原帖由 capable 于 2008-10-23 20:25 发表
2楼好像没考虑参数size_t count了,^-^


恩,因为觉得可以不用那个参数,当然拷贝之前要对指针的有效性进行测试。

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
7 [报告]
发表于 2008-10-23 20:58 |只看该作者
memcpy应该用的时汇编了

论坛徽章:
0
8 [报告]
发表于 2008-10-23 21:02 |只看该作者
原帖由 Godbach 于 2008-10-23 20:58 发表
memcpy应该用的时汇编了

请问从低地址往高地址拷贝,而不是从高往低,有什么优点呢?
面试官一直问我这个问题,实在是想不出来。

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
9 [报告]
发表于 2008-10-23 21:04 |只看该作者
这个还真不清楚。默认的就是这样吧

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
10 [报告]
发表于 2008-10-23 21:06 |只看该作者
因为一个内存区可以根据他的起始地址和长度就可以确定了。

要从高地址拷贝,呵呵。。。。 感觉有些别扭
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP