這篇文章主要為大家展示了“如何模擬實現(xiàn)str系列庫函數(shù)”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學習一下“如何模擬實現(xiàn)str系列庫函數(shù)”這篇文章吧。
成都創(chuàng)新互聯(lián)公司專注于通州企業(yè)網(wǎng)站建設(shè),成都響應式網(wǎng)站建設(shè)公司,商城網(wǎng)站開發(fā)。通州網(wǎng)站建設(shè)公司,為通州等地區(qū)提供建站服務(wù)。全流程定制開發(fā),專業(yè)設(shè)計,全程項目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)strlen #include <string.h> size_t strlen( char *str ); |
功能:函數(shù)返回字符串str 的長度( 即空值結(jié)束符之前字符數(shù)目)。
非遞歸實現(xiàn)
size_t my_strlen(const char* src) { assert(src); size_t len = 0; while (*src++ != '\0') ++len; return len; }
遞歸實現(xiàn)
int my_strlen2(const char* strDest) //遞歸求字符串長度 { assert(strDest); if ('\0' == *strDest) return 0; else return (1 + my_strlen(++strDest)); }
strcpy #include <string.h> char *strcpy( char *to, const char *from ); |
功能:復制字符串from 中的字符到字符串to,包括空值結(jié)束符。返回值為指針to。
不考慮內(nèi)存重疊
char* my_strcpy(char* dst, const char* src) { assert(dst && src); char* pdst = dst; while ((*pdst++ = *src++) != '\0'); return dst; }
考慮內(nèi)存重疊
char *my_strcpy(char *dst,const char *src) { assert(dst && src); char *ret = dst; my_memcpy(dst,src,strlen(src)+1); return ret; }
其中my_memcpy實現(xiàn)如下:
void * my_memcpy(void *dst, const void *src, size_t count) { assert(dst && src); char* pdst = (char*)dst; char* psrc = (char*)src; int n = count; if (pdst > psrc && pdst < (psrc + count)) //重疊 { for (size_t i = n - 1; i != -1; --i) pdst[i] = psrc[i]; } else { for (size_t i = 0; i < n; ++i) pdst[i] = psrc[i]; } return dst; }
strncpy #include <string.h> char *strncpy( char *to, const char *from, size_t count ); |
功能:將字符串from 中至多count個字符復制到字符串to中。如果字符串from 的長度小于count,其余部分用'\0'填補。返回處理完成的字符串。
char* my_strncpy(char* dst, const char* src, size_t n) { assert(dst && str); char* pdst = dst; const char* psrc = src; while (n && (*pdst++ = *psrc ++) != '\0') { --n; } if (n) //如果n==0 則下面會死循環(huán) { while (n--) { *pdst++ = '\0'; } } return dst; }
strstr #include <string.h> char *strstr( const char *str1, const char *str2 ); |
功能:函數(shù)返回一個指針,它指向字符串str2 首次出現(xiàn)于字符串str1中的位置,如果沒有找到,返回NULL。
char* my_strstr(const char* src, const char* sub) { assert(src && sub); int sublen = strlen(sub); char* srctmp = NULL; char* subtmp = NULL; while (strlen(src) >= sublen) //strlen(src)在不斷更新,可以提前結(jié)束循環(huán) { srctmp = (char*)src; subtmp = (char*)sub; while (*srctmp == *subtmp) { if (*subtmp == '\0') return (char*)src; ++srctmp; ++subtmp; } if (*subtmp == '\0') return (char*)src; ++src; } return NULL; }
strcat #include <string.h> char *strcat( char *str1, const char *str2 ); |
功能:函數(shù)將字符串str2 連接到str1的末端,并返回指針str1.
char* my_strcat(char* dst, const char* str) { assert(dst && str); char* pdst = dst; while (*pdst != '\0') //注意這里不能為 *pdst++ != '\0' 這樣會多加一次! ++pdst; while (*str != '\0') *pdst++ = *str++; *pdst = '\0'; return dst; }
strncat #include <string.h> char *strncat( char *str1, const char *str2, size_t count ); |
功能:將字符串from 中至多count個字符連接到字符串to中,追加空值結(jié)束符。返回處理完成的字符串。
char* my_strncat(char *dst, const char *str, size_t n) { assert(dst && str); char* pdst = dst; while (*pdst != '\0') ++pdst; while (n && (*pdst = *str) != '\0') { --n; ++pdst; //最好這樣做,不要放在while里面 ++str; } *pdst = '\0'; return dst; }
strcmp #include <string.h> int strcmp( const char *str1, const char *str2 ); |
功能:比較字符串str1 and str2, 返回值如下:
返回值 | 解釋 |
less than 0 | str1 is less than str2 |
equal to 0 | str1 is equal to str2 |
greater than 0 | str1 is greater than str2 |
int my_strcmp(const char *str1, const char *str2) { assert(str1 && str2); const char* pstr1 = str1; const char* pstr2 = str2; while (*pstr1 && *pstr2 && (*pstr1 == *pstr2)) { ++pstr1; ++pstr2; } return *pstr1 - *pstr2; }
strncmp #include <string.h> int strncmp( const char *str1, const char *str2, size_t count ); |
功能:比較字符串str1 和 str2中至多count個字符。返回值如下:
返回值 | 解釋 |
less than 0 | str1 is less than str2 |
equal to 0 | str1 is equal to str2 |
greater than 0 | str1 is greater than str2 |
如果參數(shù)中任一字符串長度小于count, 那么當比較到第一個空值結(jié)束符時,就結(jié)束處理。
int my_strncmp(const char *str1, const char *str2, size_t n) { assert(str1 && str2 && n > 0); const char* pstr1 = str1; const char* pstr2 = str2; while (--n && *pstr1 && *pstr2 && (*pstr1 == *pstr2)) { ++pstr1; ++pstr2; } return *pstr1 - *pstr2; }
以上是“如何模擬實現(xiàn)str系列庫函數(shù)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
當前文章:如何模擬實現(xiàn)str系列庫函數(shù)-創(chuàng)新互聯(lián)
文章轉(zhuǎn)載:http://muchs.cn/article22/dhihjc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護、外貿(mào)網(wǎng)站建設(shè)、標簽優(yōu)化、網(wǎng)站內(nèi)鏈、App設(shè)計、營銷型網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容