C語言常用庫函數實現

來源:互聯網
上載者:User

標籤:細節   位元組   ==   地址   覆蓋   ems   set   font   src   

1.strcpy

char * strcpy(char *dst,const char *src)   {    if((dst==NULL)||(src==NULL))                    return NULL;      char *ret = dst; //[1]     while ((*dst++=*src++)!=‘\0‘); //[2]     return ret;//[3]}

細節是:

(1)判斷地址是否為空白;

(2)參數只有兩個地址,沒有拷貝的長度。拷貝到‘\0‘時就會終止,要保證最終dst末尾是‘\0‘;

(3)要保證目標字串的長度足夠,能夠容納原串的長度;

(4)因為拷貝是dst會移動,而最終要返回的是拷貝後字串的起始地址,因此要先儲存dst的地址,便於最終返回。

 

 

2.strcmp

int strcmp(const char *str1, const char *str2){   int ret=0;   while( !(ret = *(unsigned char*)str1 - *(unsigned char*)str2 ) && *str1 )    //紅色為了當str1==str2的時候,已經判斷到了字串末尾,跳出迴圈   {      str1++;      str2++;   }   if(ret < 0)       return -1;   else if(ret > 0)        return 1;   return 0;    

 

 

3.strlen

size_t __cdecl strlen (            //源自標準庫        const char * str        ){        const char *eos = str;        while( *eos++ ) ;        return( eos - str - 1 );  //為什麼要-1? 因為當eos為‘\0‘後仍又++}

 

 

4.memcpy

void * __cdecl memcpy ( void * dst,const void * src,size_t count){         void * ret = dst;         while (count--)         { // 注意, memcpy函數沒有處理dst和src地區是否重疊的問題            *(char *)dst = *(char *)src;            dst = (char *)dst + 1;            src = (char *)src + 1;         }         return(ret);}

細節:

1)src和dst所指記憶體地區不能重疊,函數返回指向dst的指標。如果src和dst以任何形式出現了重疊,它的結果是未定義的。

2)與strcpy相比,memcpy遇到’\0’不結束,而且一定會複製完n個位元組。只要保證src開始有n位元組的有效資料,dest開始有n位元組記憶體空間就行。

3)如果目標數組本身已有資料,執行memcpy之後,將覆蓋原有資料(最多覆蓋n個)。

     如果要追加資料,則每次執行memcpy()後,要將目標地址增加到要追加資料的地址。

4)source和destin都不一定是數組,任意的可讀寫的空間均可。

 

 

5.memmov

void * __cdecl memmove ( void * dst,const void * src,size_t count){         void * ret = dst;         if (dst <= src || (char *)dst >= ((char *)src + count))         {                   // 若dst和src地區沒有重疊,則從起始處開始逐一拷貝                   while (count--)                   {                            *(char *)dst = *(char *)src;                            dst = (char *)dst + 1;                            src = (char *)src + 1;                   }         }         else         { // 若dst和src 地區交叉,則從尾部開始向起始位置拷貝,這樣可以避免資料衝突                   dst = (char *)dst + count - 1;                   src = (char *)src + count - 1;                   while (count--)                   {                            *(char *)dst = *(char *)src;                            dst = (char *)dst - 1;                            src = (char *)src - 1;                   }         }         return(ret);}

Q:memcpy與memmove的區別?

A:當src和dst地區沒有重疊時,兩個函數是完全一樣的。木有重疊的條件是: dst <= src || (char *)dst >= ((char *)src + count 。否則,memcpy是不能正常工作的,memmove是可以正常工作的。

 

 

6.memset

void* memset(void* dst,int val, size_t count){    void* ret = dst;    while(count--)    {        *(char*)dst = (char)val;        dst = (char*)dst + 1; //移動一個位元組    }    return ret;}

 

 

7.atoi && itoa

8.atof

 

C語言常用庫函數實現

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.