青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Dict.CN 在線詞典, 英語(yǔ)學(xué)習(xí), 在線翻譯

學(xué)海苦作舟,書山勤為徑

留下點(diǎn)回憶

常用鏈接

統(tǒng)計(jì)

積分與排名

Denoise

English study

Web技術(shù)

數(shù)據(jù)壓縮

一些連接

最新評(píng)論

一段關(guān)于memcpy的代碼

看到一段代碼,學(xué)習(xí)一下:

?1?void*?mymemcpy(?void*?dest,?const?void*?src,?size_t?count?)
?2?{
?3?????char*?d?=?(char*)dest;
?4?????const?char*?s?=?(const?char*)src;
?5?????int?n?=?count>>3;
?6?????switch(?count?&?7?)
?7?????{
?8??????????? case?0:??
?9?????????do?{??
10?????????????*d++?=?*s++;
11?????????????case?7:????? *d++?=?*s++;
12?????????????case?6:????????*d++?=?*s++;
13?????????????case?5:????????*d++?=?*s++;
14?????????????case?4:????????*d++?=?*s++;
15?????????????case?3:????????*d++?=?*s++;
16?????????????case?2:????????*d++?=?*s++;
17?????????????case?1:????????*d++?=?*s++;
18?????????}?while?(--n?>?0);
19?????}
20?????return?dest;
21?}

實(shí)際上也可以這么寫
?1?void*?mymemcpy(?void*?dest,?const?void*?src,?size_t?count?)?
?2?{?
?3?????char*?d?=?(char*)dest;?
?4?????const?char*?s?=?(const?char*)src;?
?5???//??int?n?=?(count?+?7)?/?8;?//?count?>?0?assumed?
?6?????int?n?=?count?>>?3;?
?7?????switch(?count?&?7?)?
?8?????{?
?9???????????????do?{??*d++?=?*s++;?
10?????case?7:????????*d++?=?*s++;?
11?????case?6:????????*d++?=?*s++;?
12?????case?5:????????*d++?=?*s++;?
13?????case?4:????????*d++?=?*s++;?
14?????case?3:????????*d++?=?*s++;?
15?????case?2:????????*d++?=?*s++;?
16?????case?1:????????*d++?=?*s++;?
17?????case?0??????????}?//while?(--n?>?0);?
18??????????????????while?(n--?>?0)?
19?????}?
20?
21?????return?dest;?
22?}?
23?
24?
這么寫更容易理解
實(shí)際上這里也可以是4個(gè)字節(jié)來復(fù)制,而不是8。其實(shí)這個(gè)看喜好。

posted on 2006-03-28 22:58 笨笨 閱讀(3017) 評(píng)論(23)  編輯 收藏 引用

評(píng)論

# re: 一段關(guān)于memcpy的代碼 2006-03-29 09:32 蟲子

你這個(gè)算法只處理了最后一部分?jǐn)?shù)據(jù)了吧,前面整8倍數(shù)的數(shù)據(jù)處理了嘛?  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-03-29 10:39 笨笨

呵呵,看來你還沒有理解這個(gè)代碼。
我解釋一下:
n是我們需要循環(huán)的次數(shù),我們的switch中有8個(gè)項(xiàng),所以我們除8。
在count&7這個(gè)時(shí)候?qū)嶋H上這樣的count&0x111,我們僅僅取最低三位,也就是除8的余數(shù),這可以保證,即使count不能被8整除也能處理多余的數(shù)據(jù)。
好了,現(xiàn)在回到循環(huán),第一輪處理多余的部分(如果有),然后用N來控制循環(huán)次數(shù)

這里的case語(yǔ)句會(huì)從上到下一直執(zhí)行,因?yàn)闆]有break語(yǔ)句

最終可以保證我們需要的次數(shù)  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-03-29 10:41 笨笨

實(shí)際上這和:
1 void* mymemcpy( void* dest, const void* src, size_t count )
2 {
3 char* d = (char*)dest;
4 const char* s = (const char*)src;
5 do {
*d++ = *s++;
10
18 } while (count -- > 0) ;
20
21 return dest;
22 }
沒有本質(zhì)區(qū)別,僅僅循環(huán)的次數(shù)減少了。
有人說這個(gè)提高的效率,不知道提高在什么地方。
另外,我們也可以用4,16等任意數(shù)字來代替這里的8,當(dāng)然以方便處理為依據(jù)。  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-03-29 16:48 蟲子

do{}while();不是應(yīng)該放在switch外面嗎?
  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-03-29 21:29 笨笨

不是,是就不對(duì)了  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-03-31 13:36 芋頭

的確是看過這么寫的,不過不知道怎么優(yōu)化的,我覺得應(yīng)該是效率不高吧。效率高的做法一般是超過一定長(zhǎng)度,就選按每4字節(jié)整體拷貝,生成的匯編指令一般是rep movl...,剩下幾字節(jié)單獨(dú)拷貝。編譯器都會(huì)特殊處理這個(gè)函數(shù)。

上面這個(gè)代碼在我的GCC上用最高的優(yōu)化方式也不能生成高效代碼。  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-04-01 09:46 沐楓

個(gè)人覺得很難優(yōu)化。因?yàn)槊總€(gè)字節(jié)拷貝,都要留一個(gè)跳轉(zhuǎn)入口。編譯器又怎么敢私自用8字節(jié)操作指令直接優(yōu)化掉它呢。
由此估計(jì),寫此代碼純粹是為了挑戰(zhàn)C/C++的語(yǔ)法。  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-04-03 15:41 a1240

我個(gè)人感覺,如果沒有特殊的要求,還是不要這樣寫代碼為好。畢竟,簡(jiǎn)單直觀的代碼才好維護(hù)嘛。  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-04-16 17:35 請(qǐng)問:

能否解釋一下switch語(yǔ)句:
switch( count & 7 ) 8 {
9 do { *d++ = *s++;
10 case 7: *d++ = *s++;
11 case 6: *d++ = *s++;
12 case 5: *d++ = *s++;
13 case 4: *d++ = *s++;
14 case 3: *d++ = *s++;
15 case 2: *d++ = *s++;
16 case 1: *d++ = *s++;
17 case 0 } //while (--n > 0);
18 while (n-- > 0)
19 }
  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-04-16 22:03 笨笨

看上面的回復(fù)  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-04-19 11:12 LiLing

這樣寫是為了提高內(nèi)存訪問效率,各位可以看看計(jì)算機(jī)組成原理中的內(nèi)存結(jié)構(gòu)就清楚了。  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-11-15 12:49 qzq

根本不可能高效,原因有2個(gè):
1. 不算循環(huán),拷貝每個(gè)字節(jié),也要2次++,1次拷貝。
2. 用匯編更高效

但沒有必要重新發(fā)明輪子。
C的庫(kù)函數(shù)或者操作系統(tǒng)的標(biāo)準(zhǔn)函數(shù),如:
CopyMemory ()
memcpy()
這種內(nèi)存代碼你千萬(wàn)不要嘗試自己去實(shí)現(xiàn),那將是一種災(zāi)難,在每個(gè)操作系統(tǒng)/編譯器中,內(nèi)存拷貝可以說是非常頻繁的,所以系統(tǒng)/編譯器的內(nèi)存拷貝函數(shù)基本上都是非常完美的,VC++用的就是匯編代碼,
不信的話你可以自己寫一段內(nèi)存拷貝函數(shù),然后和系統(tǒng)的內(nèi)存拷貝函數(shù)比較一下就知道了。

  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-11-17 09:30 笨笨

我從來沒有說過這個(gè)代碼比系統(tǒng)函數(shù)高效,我提出來的目的在于和大家一道探討程序的寫法。  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-11-24 22:01 LeVaN

http://filmiki-najlepsze.lolas.pl ^^^ <a href="http://filmiki-najlepsze.lolas.pl">filmiki najlepsze</a> ^^^ [url]http://filmiki-najlepsze.lolas.pl[/url]  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2006-12-15 10:48 lwang

樓主第一個(gè)程序?qū)戝e(cuò)了
應(yīng)該是n--,不是--n
不信試試下面的代碼,結(jié)果不對(duì),改成n--就對(duì)了。
#include <stdio.h>

void* mymemcpy( void* dest, const void* src, size_t count )
{
char* d = (char*)dest;
const char* s = (const char*)src;
int n = count>>3;
switch( count & 7 )
{
case 0:
do {
*d++ = *s++;
case 7: *d++ = *s++;
case 6: *d++ = *s++;
case 5: *d++ = *s++;
case 4: *d++ = *s++;
case 3: *d++ = *s++;
case 2: *d++ = *s++;
case 1: *d++ = *s++;
} while (--n > 0);
}
return dest;
}
int main()
{
char * src = "hello, world.\n";
char dst[100] = {0};

mymemcpy(dst, src, strlen(src));
printf("src:%sdst:%s", src, dst);
return 0;
}  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2008-04-21 17:52 vfdff

switch( count & 7 )
7 {
8 case 0:
9 do {
10 *d++ = *s++;
11 case 7: *d++ = *s++;
12 case 6: *d++ = *s++;
13 case 5: *d++ = *s++;
14 case 4: *d++ = *s++;
15 case 3: *d++ = *s++;
16 case 2: *d++ = *s++;
17 case 1: *d++ = *s++;
18 } while (--n > 0);
19 }
怎么switch語(yǔ)句內(nèi)部可以有 除了case 之外的語(yǔ)句 *d++ = *s++; 呢 ?  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2009-01-03 02:15 fuck

放些狗屁,這種代碼能辨已過去嗎  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2012-06-09 21:28 personal loans

All people deserve good life and mortgage loans (goodfinance-blog.com) or short term loan can make it much better. Because people's freedom is based on money state.   回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2012-06-15 18:32 sociology essays types

Visit essaysservice firm (essaysservice.com) in order to receive a splendid opportunity to order best academic essays and make a change in your academic life owing to our cheap essay custom writing.  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2012-06-15 18:34 research essays

Visit Internet site (essaysservice.com) if you are anxious to buy papers and enjoy our help with research paper.  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2012-08-04 22:39 zhongyunde

為什么這么寫效率高?  回復(fù)  更多評(píng)論   

# re: 一段關(guān)于memcpy的代碼 2012-09-04 19:15 thesis

I guess that it is viable to go to this web page, just because simply here students will find the smashing information about this topic. Hence, the thesis service should use this for thesis report creating.   回復(fù)  更多評(píng)論   


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美激情精品久久久久久免费印度| 亚洲欧美日韩一区二区在线 | 麻豆av福利av久久av| 亚洲国产精品传媒在线观看| 91久久午夜| 国产精品美女久久久免费| 国产精品第一区| 国产日韩在线播放| 国产偷国产偷亚洲高清97cao| 国产日韩欧美电影在线观看| 国产在线观看91精品一区| 国产一区二区三区奇米久涩| 在线观看欧美激情| 日韩午夜激情av| 久久久999精品视频| 欧美二区在线播放| 亚洲视频每日更新| 久久综合色影院| 欧美日韩三级视频| 国内精品久久久| 一区二区欧美视频| 久久久久成人精品| 亚洲一区免费视频| 久久国产精品久久久| 狂野欧美激情性xxxx欧美| 亚洲国产高清视频| 亚洲毛片av| 欧美一区二区在线观看| 欧美顶级大胆免费视频| 国产欧美在线看| 亚洲日本精品国产第一区| 香蕉久久一区二区不卡无毒影院| 免费视频亚洲| 性久久久久久| 欧美日韩免费观看一区三区 | 亚洲女同精品视频| 欧美电影免费观看网站| 亚洲欧美在线一区二区| 欧美精品18+| 激情久久久久久久| 欧美一级久久| 亚洲视频一区二区| 欧美日韩国产成人精品| 亚洲国产视频直播| 另类春色校园亚洲| 性色av香蕉一区二区| 国产精品v欧美精品v日韩精品| 亚洲国产视频a| 欧美福利视频网站| 久久亚洲精选| 亚洲二区在线| 久色成人在线| 久久精品一区二区三区中文字幕 | 亚洲黄页一区| 女人天堂亚洲aⅴ在线观看| 午夜激情综合网| 国产精品久久久久999| 亚洲神马久久| 中文日韩电影网站| 欧美日韩一区免费| 亚洲午夜在线| 亚洲一区欧美二区| 国产欧美一区二区白浆黑人| 久久成人免费网| 久久成人一区| 亚洲福利一区| 亚洲激情成人在线| 欧美日韩在线三区| 亚洲男人的天堂在线aⅴ视频| 在线一区二区三区四区| 国产伦精品一区二区三区视频孕妇| 亚洲伊人网站| 欧美一区激情| 亚洲高清不卡一区| 亚洲国产欧美日韩精品| 欧美色视频日本高清在线观看| 亚洲成人在线网站| 久久综合九色综合久99| 久久中文字幕导航| 亚洲精品日本| 亚洲一品av免费观看| 国产婷婷色一区二区三区在线| 乱中年女人伦av一区二区| 蜜桃av一区二区| 亚洲一本视频| 欧美一区二区三区视频在线| 亚洲国产成人不卡| 99精品视频网| 国产在线乱码一区二区三区| 亚洲激情图片小说视频| 国产精品盗摄一区二区三区| 久久精品视频免费播放| 牛人盗摄一区二区三区视频| 亚洲免费视频一区二区| 久久精品在线视频| 亚洲视屏在线播放| 久久免费视频观看| 午夜精彩视频在线观看不卡| 久久中文字幕一区二区三区| 亚洲女性裸体视频| 免费成人性网站| 欧美中文在线字幕| 欧美精品一区二区三区一线天视频| 欧美在线视频一区二区| 欧美另类变人与禽xxxxx| 久久国内精品自在自线400部| 欧美精品粉嫩高潮一区二区 | 亚洲欧洲中文日韩久久av乱码| 国产精品久久久一区二区三区| 欧美高清视频在线观看| 国产亚洲精品福利| 在线亚洲成人| 一本一本久久a久久精品综合麻豆| 欧美影院久久久| 香蕉久久夜色精品| 欧美视频在线一区| 亚洲精品国久久99热| 亚洲国产精品久久精品怡红院| 欧美一区二区三区日韩视频| 亚洲欧美日韩国产一区| 欧美区亚洲区| 亚洲国内欧美| 亚洲精品字幕| 欧美www在线| 欧美第一黄网免费网站| 红桃视频一区| 久久国产欧美日韩精品| 欧美在线观看天堂一区二区三区| 欧美日韩在线观看一区二区| 亚洲国产精品热久久| 亚洲日本aⅴ片在线观看香蕉| 久久综合伊人| 亚洲高清在线视频| 日韩视频在线观看一区二区| 欧美成人午夜剧场免费观看| 欧美成人在线免费观看| 亚洲国产mv| 欧美激情麻豆| 亚洲精选在线观看| 欧美www视频| 欧美11—12娇小xxxx| 老司机一区二区| 在线观看精品一区| 麻豆九一精品爱看视频在线观看免费| 久久久久久亚洲精品中文字幕| 国产在线视频欧美| 久久亚洲综合色一区二区三区| 免费成人高清| 99国产精品99久久久久久| 欧美另类视频在线| 亚洲夜晚福利在线观看| 欧美一级视频精品观看| 国产中文一区| 免费成人毛片| 一区二区三区高清| 久久久久在线观看| 亚洲精品久久久久久一区二区 | 国产欧美精品在线| 久久精品理论片| 亚洲激情一区| 欧美一级视频| 亚洲欧洲精品成人久久奇米网| 欧美久久精品午夜青青大伊人| 亚洲香蕉网站| 欧美成人免费一级人片100| 在线一区二区三区做爰视频网站 | 在线亚洲欧美视频| 国产日韩精品一区二区三区在线| 久久久欧美精品| 日韩视频在线观看国产| 久久精品中文| 一区二区三区视频在线| 韩国精品在线观看| 欧美日韩一卡| 久久久人人人| 亚洲影院免费观看| 亚洲国产精品成人综合| 欧美在线视频不卡| 中文一区字幕| 亚洲第一在线综合在线| 国产精品久久久对白| 免费成人黄色| 久久精品72免费观看| 一区二区三区 在线观看视频| 蜜臀久久99精品久久久久久9 | 99国产精品99久久久久久粉嫩 | 蜜臀久久99精品久久久久久9| 一区二区三区精品视频| 激情久久久久久久| 国产精品乱人伦中文| 美女黄网久久| 久久av一区二区三区| 宅男在线国产精品| 国产精品乱码久久久久久| 日韩视频三区| 伊人久久av导航| 亚洲视频一起| 亚洲精品视频啊美女在线直播| 国产精品视频福利| 麻豆freexxxx性91精品|