C語言中的字符串函數有如下這些
- 獲取字符串長度
- strlen
- 長度不受限制的字符串函數
- strcpy
- strcat
- strcmp
- 長度受限制的字符串函數
- strncpy
- strncat
- strncmp
- 字符串查找
- strstr
- strtok
- 錯誤信息報告
- strerror
接下來看看如何實現它們
長度不受限制的字符串函數
strcpy
我們看看文檔是怎樣說的,如下
char * strcpy ( char * destination, const char * source );
Copy string
字符串拷貝(字符串復制)
Copies the C string pointed by source into the array pointed by destination, including the terminating null character (and stopping at that point).
復制由字符指針source指向的C字符串到另一個字符數組中,該字符數組由字符指針destination指向
To avoid overflows, the size of the array pointed by destination shall be long enough to contain the same C string as source (including the terminating null character), and should not overlap in memory with source.
為避免溢出,由destination指向的字符數組的大小需要足夠長,足夠包含住源字符串(包含'\0')
綜上,可以知道
- 會將源字符串中的 '\0' 拷貝到目標空間,源字符串必須以 '\0' 結束。
- 目標空間必須足夠大,以確保能存放源字符串。
怎么實現拷貝?
int main()
{
char arr1[] = "abcdefghi";
char arr2[] = "bit";
// 把arr2的內容拷貝到arr1中
//strcpy(arr1, arr2);
// 怎么拷貝?
my_strcpy(arr1, arr2);
printf("%s\n", arr1);
return 0;
}
實現
斷言指針不為空是個好習慣~
//char* my_strcpy(char* dest, char* src)
// src加上const,為什么?因為我們只需要拷貝,不需要改動源字符串,防止發生修改,所以加上const修飾
char* my_strcpy(char* dest, const char* src)
{
assert(dest != NULL);
assert(src != NULL);
while (*src != '\0')
{
*dest = *src;
dest++;
src++;
}
*dest = *src; // '\0'
// 返回目的空間的起始地址
return dest;
}
源字符串拷貝到目的空間,尋找'\0',不是'\0'的就執行*dest = *src
,把源字符賦值給目的空間,然后兩個指針都往后偏移,也就是都進行++,當*src為'\0'
時,說明源字符串已經到結尾了,就退出這個循環,直接將'\0'賦值給*dest
,最后返回dest
可以進行優化,如下
char* my_strcpy(char* dest, const char* src)
{
assert(dest != NULL);
assert(src != NULL);
// 優化
while (*src != '\0')
{
*dest++ = *src++;
}
*dest = *src; // '\0'
// 返回目的空間的起始地址
return dest;
}
當然還可以繼續優化,變得更加簡潔,直接將*dest++ = *src++
作為判斷條件,同時還會執行操作,如下
char* my_strcpy(char* dest, const char* src)
{
assert(dest != NULL);
assert(src != NULL);
// 優化
// 拷貝src指向的字符串到dest指向的空間,包含'\0'
char* rest = dest;
while (*dest++ = *src++)
{
;
}
// 返回目的空間的起始地址
return rest;
}
最后,謝謝你看到這里,謝謝你認真對待我的努力,希望這篇博客有幫到你
你輕輕一個贊,就是我世界里的一顆星
還有因本人水平有限,如有錯誤以及不足之處,歡迎靚仔靚女們
指出。