1.模拟实现strncpy
strncpy 是 C语言的库函数之一,来自 C语言标准库,定义于 string.h,char *strncpy(char *dest, const char *src, int n),把src所指向的字符串中以src地址开始的前n个字节复制到dest所指的数组中,并返回被复制后的dest。
函数原型:char *strncpy(char *dest,char *src,int size_t);
参数:
dest – 指向用于存储复制内容的目标数组
src – 要复制的字符串
n – 要从源中复制的字符数
返回值:该函数返回最终复制的字符串
【参考代码】:
- 不考虑src的长度小于len:
char *_strncpy(char *dest, const char *src, size_t len) {
assert(dest != NULL && src != NULL);
char *ret = dest;
while (len--) {
*dest++ = *src++;
}
return ret;
}
- 当src的长度小于len呢?这份代码没有处理这个问题。
和strcpy一样,strncpy把源字符串的字符复制到目标数组。然而,它总是正好向dest写入len个字符。如果strlen(src)的值小于len,dest数组就用额外的NUL字节填充到len长度,如果strlen(src)的值大于或等于len,那么只有len个字符被复制到dest中。
注:它的结果将不会以NUL字节结尾。(NUL即‘\0’)
由此可见,我们还需要判断strlen(src)是否小于len,如果是,还需要在dest后面添加NULL。
char *_strncpy(char *dest, const char *src, size_t len) {
assert(dest != NULL);
assert(src != NULL);
char *ret = dest;
int offset = 0;
//src长度小于len
if (strlen(src) < len) {
offset = len - strlen(src);
len = strlen(src);
}
while (len--){
*dest++ = *src++;
}
while (offset--){
*dest++ = '\0';
}
return ret;
}
2.模拟实现strncat
函数原型:char * strncat(char *dest, const char *src, size_t n);
参数:dest指向目标字符串,src为指向源字符串。
功能:把src所指字符串的前n个字符添加到dest所指字符串的结尾处,并覆盖dest所指字符串结尾的’\0’,从而实现字符串的连接。
注:src和dest所指内存区域不可以重叠,并且dest必须有足够的空间来容纳src的字符串。
返回值:返回指向dest的指针。
【参考代码】:
char *_strncat(char *dest, const char *src, int len) {
assert(dest != NULL);
assert(src != NULL);
char *ret = dest;
//找到dest中的'\0'
while (*dest) {
dest++;
}
while (len--){
*dest++ = *src++;
}
*dest = '\0';
return ret;
}
3.模拟实现strncmp
函数原型:int strncmp ( const char * str1, const char * str2, size_t n );
参数:str1, str2 为需要比较的两个字符串,n为要比较的字符的数目。
字符串大小的比较是以ASCII 码表上的顺序来决定,此顺序亦为字符的值。strncmp()首先将s1 第一个字符值减去s2 第一个字符值,若差值为0 则再继续比较下个字符,直到字符结束标志’\0’,若差值不为0,则将差值返回。例如字符串"Ac"和"ba"比较则会返回字符"A"(65)和’b’(98)的差值(-33)。注意:要比较的字符包括字符串结束标志’\0’,而且一旦遇到’\0’就结束比较,无论n是多少,不再继续比较后边的字符。
返回值:若str1与str2的前n个字符相同,则返回0;若s1大于s2,则返回大于0的值;若s1 小于s2,则返回小于0的值。
与srncmp函数不同的地方是strncmp函数是指定比较size个字符。
【参考代码】:
int _strncmp(const char *str1, const char *str2, size_t n) {
assert(str1);
assert(str2);
while (n--) {
if (*str1 == *str2) {
str1++;
str2++;
} else {
if (*str1 < *str2)
return -1;
else
return 1;
}
}
return 0;
}