第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

如下所示,請(qǐng)問主要是那幾個(gè)判斷是什么意思,然后如何識(shí)別,及實(shí)現(xiàn)字對(duì)齊的呢?

如下所示,請(qǐng)問主要是那幾個(gè)判斷是什么意思,然后如何識(shí)別,及實(shí)現(xiàn)字對(duì)齊的呢?

慕工程0101907 2022-04-21 16:11:20
#define lsize sizeof(word)#define lmask (lsize - 1)void *memcpy(void *dest, const void *src, size_t count){char *d = (char *)dest;const char *s = (const char *)src;int len;if(count == 0 || dest == src)return dest;if(((long)d | (long)s) & lmask) {// src and/or dest do not align on word boundaryif((((long)d ^ (long)s) & lmask) || (count < lsize))len = count; // copy the rest of the buffer with the byte moverelselen = lsize - ((long)d & lmask); // move the ptrs up to a word boundarycount -= len;for(; len > 0; len--)*d++ = *s++;}for(len = count / lsize; len > 0; len--) {*(word *)d = *(word *)s;d += lsize;s += lsize;}for(len = count & lmask; len > 0; len--)*d++ = *s++;return dest;}
查看完整描述

1 回答

?
慕容3067478

TA貢獻(xiàn)1773條經(jīng)驗(yàn) 獲得超3個(gè)贊

d,s是兩個(gè)字符型指針,分別指向目標(biāo)傳位置和源傳位置
在判斷 if(((long)d | (long)s) & lmask) 中,舉個(gè)具體的例子
假設(shè)是32位計(jì)算機(jī),字長(zhǎng) word= 32/8 為4,即占4個(gè)byte,則lmask = 000……00011
則d與s若是對(duì)齊的,應(yīng)只有第三位及更高位不同(從低位算起)則(long)d | (long)s的最低兩位一定是00,例如 d = **……**10100 s = **……**00100,則(long)d | (long)s = **……**10100,此時(shí)((long)d | (long)s) & lmask = 0,即對(duì)齊的話不做if中的語(yǔ)句,直接從整字開始copy內(nèi)存內(nèi)容

否則,((long)d | (long)s) & lmask 非0,進(jìn)入if語(yǔ)句:
if((((long)d ^ (long)s) & lmask) || (count < lsize)) 中,記住lmask = 000……00011,所以(long)d ^ (long)s指d,s最低兩位若完全相同,如都為10,10或者01,01,或者11,11,(不可能同時(shí)為00,00),則((long)d ^ (long)s) & lmask)為假,此時(shí)若count>=lsize,即判斷為假,則len = lsize - ((long)d & lmask);
其中((long)d & lmask)指d中后兩位1的個(gè)數(shù),為0個(gè),1個(gè),2個(gè)或者3個(gè),而lsize - ((long)d & lmask)既是從d開始放,到下一個(gè)整字開始前還有幾個(gè)空位,只能相應(yīng)的為3個(gè),2個(gè),1個(gè)或者0個(gè)。隨后的語(yǔ)句是指把先前面的0~3個(gè)零頭字節(jié)復(fù)制掉,
count -= len;
for(; len > 0; len--)
*d++ = *s++;

否則,若d與s開始時(shí)就完全錯(cuò)開,如(10,11)或者(count < lsize),判斷為真,指的是若d與s開始時(shí)就完全錯(cuò)開,則逐字節(jié)復(fù)制即可,此時(shí)不可整字復(fù)制,或者雖然d和s是非整字對(duì)齊,如同為01,01,但是copy內(nèi)容小于lsize(比如是4),不會(huì)存在大小為4byte的整字需要復(fù)制,則從d開始從頭到尾復(fù)制即可,即for(len = count / lsize; len > 0; len--)循環(huán)中的內(nèi)容。

for(len = count & lmask; len > 0; len--)
*d++ = *s++;
因?yàn)閘mask = 000……00011,則len = count & lmask即字符串的最后0~3個(gè)字符,所以最后的for是把整字之外剩余的零頭也copy過去

講的比較混亂,按這個(gè)思路仔細(xì)想象就行了。
Good luck!



查看完整回答
反對(duì) 回復(fù) 2022-04-24
  • 1 回答
  • 0 關(guān)注
  • 157 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)