1.函数介绍
2.库函数的模拟实现
前言
C语言中对字符和字符串的处理很是频繁,但是C语言本身是没有字符串类型的,字符串通常放在 常量字符串中或者字符数组中。 字符串常量 适用于那些对它不做修改的字符串函数.
提示:以下是本篇文章正文内容,下面案例可供参考
一、字符串函数有哪些?
1.1 strlen函数
那么我们应该如何使用呢?
2.库函数的模拟实现
前言
C语言中对字符和字符串的处理很是频繁,但是C语言本身是没有字符串类型的,字符串通常放在 常量字符串中或者字符数组中。 字符串常量 适用于那些对它不做修改的字符串函数.
提示:以下是本篇文章正文内容,下面案例可供参考
一、字符串函数有哪些?
1.1 strlen函数
那么我们应该如何使用呢?
size_t strlen ( const char * str );
注意:
1.字符串已经 ‘\0’ 作为结束标志
2.strlen函数返回的是在字符串中 ‘\0’ 前面出现的字符个数(不包含 ‘\0’ )
3.参数指向的字符串必须要以 ‘\0’ 结束。
4.注意函数的返回值为size_t,是无符号的( 易错 )
例:strlen函数的使用
int main()
{
char arr[] = "abcdef";
int len = strlen(arr);
printf("%d\n",len);
return 0;
}
答案是6,如何实现的呢?已知arr是数组名,也是数组的首元素地址。
于是我们从a开始数,直到找到'\0'为止。
字符串常量“abcdef” 其实是abcdef'\0'.在f后就紧跟着'\0'。
并且字符串长度是不算'\0'在内的,这也是与sizeof的区别。
因此不难得出,字符串长度为 6.
再来看一个例子:
int main()
{
char arr[] = { 'a','b','c','d' };
int len = strlen(arr);
printf("%d\n", len);
return 0;
}
答案是随机值。原因是什么呢?因为arr数组中,
'\0'的位置是随机的,并不是跟在'd'后面的。
而strlen函数必须找到'\0'作为结束标识符。
1.2 strcpy
那么我们应该如何使用呢?
char* strcpy(char * destination, const char * source );
int main()
{
char arr1[] = "abcdef";
char arr2[10] = { 0 };
strcpy(arr2, arr1);
//其中arr2是需要拷贝的空间,arr1是拷贝过去的。
printf("%s\n", arr2);
return 0;
}
输出是 abcdef
注意:
1. 源字符串必须以 ‘\0’ 结束。
2. 会将源字符串中的 ‘\0’ 拷贝到目标空间。
3. 目标空间的大小一定要比拷贝过来的空间大,不然会出bug。
1.3 strcmp
char * strncat ( char * destination, const char * source,
size_t num )
标准规定:
第一个字符串大于第二个字符串,则返回大于0的数字
第一个字符串等于第二个字符串,则返回0
第一个字符串小于第二个字符串,则返回小于0的数字
那么如何判断字符串大小呢?
例1:
int main()
{
char arr1[] = "abcdef";
char arr2[] = "abcdeg";
int ret =strcmp(arr1, arr2);
}
1.当字符串长度相同的时候
从第一个字符开始比较,如果字符相同,则选择比较下一个字符。直到至少其中一个字符串遇到’\0’。
int main()
{
char arr1[] = "abcdef";
char arr2[] = "abcde";
int ret =strcmp(arr1, arr2);
}
2.当字符串长度不相同的时候
从第一个字符开始比较,如果字符相同,则选择比较下一个字符。如果当一个字符串执行到’\0’的时候,还没能比较出来,则字符串长度长的长。
二、字符串函数模拟实现
int my_strlen(const char* p)
{
assert(p);
int count = 0;
while (*p != '\0')
{
p++;
count++;
}
return count;
}
char* my_strcpy(char* dest, const char* str)
{
assert(dest && str);
char* begin = dest;
while (*dest++ = *str++)
{
;
}
return begin;
}
int my_strcmp(const char* str1, const char* str2)
{
assert(str1 && str2);
int ret = 0;
while (!(ret = *(unsigned char*)str1 - *(unsigned char*)str2) && *str2)
{
++str1;
++str2;
}
if (ret < 0)
ret = -1;
else if (ret > 0)
ret = 1;
return ret;
}