您好,登錄后才能下訂單哦!
//1.strcpy(拷貝) char* my_strcpy(char*dst, const char*src) { assert(dst); assert(src); char* cp = dst; while (*cp++ = *src++) { ; } return dst; } //2.strcat(連接) char* my_strcat(char*dst, const char*src) { assert(dst); assert(src); char* cp = dst; while (*cp != '\0') { cp++; } while (*cp++ = *src++) { ; } return dst; } //3.strcmp(比較) int my_strcmp(const char*dst, const char*src) { assert(dst); assert(src); int ret = 0; while (!(ret=*(unsigned char*)dst - *(unsigned char*)src) && *dst) { dst++; src++; } if (ret > 0) { ret = 1; } else if (ret < 0) { ret = -1; } return ret; } //4.strstr (尋找子串) char* my_strstr(const char*dst, const char*src) { char* cp = (char*)src; char*s1; char*s2; if (!*dst) { return ((char*)src); } while (*cp) { s1 = cp; s2 = (char*)dst; while (!(*s1-*s2)&&*s1&&s2) { s1++; s2++; } if (!*s2) { return (cp); } cp++; } return (NULL); } //5.memcpy(內存拷貝,不重疊) void* my_memcpy(void *dst, const void*src, size_t count) { assert(dst); assert(src); char*ret = (char*)dst; while (count--) { *(char*)dst = *(char*)src; dst = (char*)dst + 1; src = (char*)src + 1; } return ret; } //6.memmove(內存移動,實現重疊拷貝) //內存移動有兩種情況:如有一字符串:abcdefgh ,若dst<src,即dst在src前面,則沒有重疊。 //若dst>src,即dst在src后面,此時若srt+count<dst,則沒有重疊。 //若dst>src,即dst在src后面,此時若srt+count>dst,則有重疊,此時需從后向前,由src+count開始拷貝到dst+count。 void *my_memmove(void*dst, const void*src, size_t count) { assert(dst); assert(src); void *ret = dst; if ((dst < src) || ((char*)src + count) < (char*)dst) //內存不重疊,順著按順序拷貝 { while (count--) { *(char*)dst = *(char*)src; dst = (char*)dst + 1; src = (char*)src + 1; } } else //內存有重疊,則倒著拷貝 { 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; } //7.memset(內存設置) void* my_memset(void*dst, int val, size_t count) { void*start = dst; while (count--) { *(char*)dst = (char)val; dst = (char*)dst + 1; } return start; }
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。