//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;
}
網站題目:模擬實現部分庫函數(strcpy,strcmp,strcat,strstr,memcpy,memmove,memset)
本文路徑:http://www.yijiale78.com/article42/jjpsec.html
成都網站建設公司_創新互聯,為您提供、電子商務、App設計、網站收錄、響應式網站、小程序開發
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯