免费注册 查看新帖 |

Chinaunix

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

一道迅雷笔试题,实现memcpy [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-09-20 21:36 |只看该作者 |倒序浏览
填空,实现memcpy


对齐问题的可能性比较小,因为是一个一个字节访问的
为什么要声明寄存器变量呢?


char *memcpy(void *dest,const void *src,unsigned int len)
{
    register char *d;
    register char *s;

    if( _______ ) return dest;

    if( _______ )
    {
        printf("overlap!\n");
    }

    if( _______ )
    {
        d=(char*)dest+len-1;
        s=(char*)src+len-1;

        while( ________ )
        {
            *d--=*s--;
            *d--=*s--;
            *d--=*s--;
            *d--=*s--;
            _________
        }

        while(len--)
            *d--=*s--;
    }else if( _______ )
    {
        d=(char*)dest;
        s=(char*)src;

        while ( _______ )
        {
            *d++=*s++;
            *d++=*s++;
            *d++=*s++;
            *d++=*s++;
            _________
        }

        while(len--)
            *d++=*s++;
    }

     return dest;
}

[ 本帖最后由 scu_guzo 于 2009-9-28 21:31 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2009-09-20 21:59 |只看该作者
一种解法,不知道正不正确,希望有大牛说出标准答案

不知道是不是缓存优化的问题?


  1. 1.dest==src || dest==NULL || src==NULL
  2. 2.(~(dest-src)+1)<len ---------> 此处改为 ((dest-src)?(dest-src):(src-dest))<len
  3. 3.src<dest
  4. 4.len>=4
  5. 5.len-=4;
  6. 6.src>dest
  7. 7.len>=4
  8. 8.len-=4;
复制代码

[ 本帖最后由 scu_guzo 于 2009-9-25 21:04 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2009-09-20 22:20 |只看该作者
楼上3和6的回答原因是什么?不懂。。

论坛徽章:
0
4 [报告]
发表于 2009-09-20 22:32 |只看该作者

回复 #3 hsc_hao 的帖子

产生交叉
也就是 |src-dest|<len

论坛徽章:
0
5 [报告]
发表于 2009-09-20 22:59 |只看该作者
今天迅雷在成都举行笔试。

论坛徽章:
0
6 [报告]
发表于 2009-09-20 23:31 |只看该作者
原帖由 scutan 于 2009-9-20 22:59 发表
今天迅雷在成都举行笔试。


被鄙视了

论坛徽章:
0
7 [报告]
发表于 2009-09-20 23:39 |只看该作者
原帖由 scu_guzo 于 2009-9-20 23:31 发表


被鄙视了

你是川大的吧?今天好像都是C++相关的题?

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
8 [报告]
发表于 2009-09-21 08:26 |只看该作者
明明是memmove么。
既然优化成按4字节拷贝,还要按char而不是int32复制?

论坛徽章:
0
9 [报告]
发表于 2009-09-21 15:32 |只看该作者
原帖由 scu_guzo 于 2009-9-20 21:59 发表
一种解法

1.dest==src || dest==NULL || src==NULL
2.(~(dest-src)+1)dest
7.len>=4
8.len-=4;



他为什么要判断src和dst的大小呢,前面已经判断没有溢出了啊(src - dst + 1 < len),不管谁大谁小都直接拷贝过去不就行了么,为啥还要分两种情况呢?
还有就是2是不是要用绝对值啊?

[ 本帖最后由 sunyu_bit 于 2009-9-21 15:34 编辑 ]

论坛徽章:
0
10 [报告]
发表于 2009-09-21 15:42 |只看该作者
原帖由 sunyu_bit 于 2009-9-21 15:32 发表



他为什么要判断src和dst的大小呢,前面已经判断没有溢出了啊(src - dst + 1 < len),不管谁大谁小都直接拷贝过去不就行了么,为啥还要分两种情况呢?
还有就是2是不是要用绝对值啊?



奥,我明白3和6了,那2应该用绝对值啊,为啥没有用呢
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP