本篇文章将详细介绍c语言中处理字符和字符串的库函数的使用和注意事项。
车车已经准备好,开始发车喽
文章目录
1.函数介绍
1.1 strlen
size_t strlen ( const char * str );
解释:字符串以 ‘\0’ 作为结束标志,strlen函数返回的是在字符串中 ‘\0’ 前面出现的字符个数(不包
含 ‘\0’ )。
1.参数指向的字符串必须要以 ‘\0’ 结束。
2.注意函数的返回值为size_t,是无符号的。
1.2 strcpy
char* strcpy(char * destination, const char * source );
解释: strcpy把含有’\0’结束符的字符串复制到另一个地址空间,返回值的类型为char*。
1.源字符串必须以 ‘\0’ 结束。
2.会将源字符串中的 ‘\0’ 拷贝到目标空间。
3.目标空间必须足够大,以确保能存放源字符串。
4.目标空间必须可变。
1.3strcat
char * strcat ( char * destination, const char * source );
解释:将两个char类型连接。
例如:
char d[20]=“Golden”;
char s[20]=“View”;
strcat(d,s);
//打印d
printf(“%s”,d);
输出 d 为 GoldenView (中间无空格)
1.源字符串必须以 ‘\0’ 结束。
2.目标空间必须有足够的大,能容纳下源字符串的内容。
3.目标空间必须可修改。
1.4strcmp
int strcmp ( const char * str1, const char * str2 );
解释:两个字符串自左向右逐个字符相比(按ASCII值大小相比较),直到出现不同的字符或遇’\0’为止。标准规定:
第一个字符串大于第二个字符串,则返回大于0的数字
第一个字符串等于第二个字符串,则返回0
第一个字符串小于第二个字符串,则返回小于0的数字
如:
1.“A”<“B” 2.“A”<“AB” 3.“Apple”<“Banana” 4.“A”<“a” 5.“compare”<“computer”
1.5strncpy
char * strncpy ( char * destination, const char * source, size_t num );
解释:表示把 source所指向的字符串中以 source地址开始的前num个字节复制到destination所指的数组中,并返回被复制后的destination 。
1.拷贝num个字符从源字符串到目标空间。
2.如果源字符串的长度小于num,则拷贝完源字符串之后,在目标的后边追加0,直到num个
1.6 strncat
char * strncat ( char * destination, const char * source, size_t num );
解释:把 source所指字符串的前num个字符添加到 destination所指字符串的结尾处,并覆盖 destination所指字符串结尾的’\0’,从而实现字符串的连接。
1.7 strncmp
int strncmp ( const char * str1, const char * str2, size_t num );
解释:功能是把 str1 和 str2 进行比较,最多比较前 n 个字节,若str1与str2的前num个字符相同,则返回0;若s1大于s2,则返回大于0的值;若s1 小于s2,则返回小于0的值
1.8 strstr
char * strstr ( const char *str1, const char * str2);
解释: 函数用于判断字符串str2是否是str1的子串。如果是,则该函数返回 str1字符串从 str2第一次出现的位置开始到 str1结尾的字符串;否则,返回NULL。
1.9 strtok
char * strtok ( char * str, const char * sep );
解释:分解字符串为一组字符串。str为要分解的字符串, sep为分隔符字符(如果传入字符串,则传入的字符串中每个字符均为分割符)。首次调用时,str指向要分解的字符串,之后再次调用要把str设成NULL。
1.10 strerror
char * strerror ( int errnum );
解释:通过标准错误的标号,获得错误的描述字符串 ,将单纯的错误标号转为字符串描述,方便用户查找错误。
1.11 memcpy
void * memcpy ( void * destination, const void * source, size_t num );
1.11 memcpy
void * memcpy ( void * destination, const void * source, size_t num );
解释:函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置。
1.这个函数在遇到 ‘\0’ 的时候并不会停下来。
2.如果source和destination有任何的重叠,复制的结果都是未定义的.
1.12 memmove
void * memmove ( void * destination, const void * source, size_t num );
解释:memmove用于拷贝字节,如果目标区域和源区域有重叠的话,memmove能够保证源串在被覆盖之前将重叠区域的字节拷贝到目标区域中,但复制后源内容会被更改。但是当目标区域与源区域没有重叠则和memcpy函数功能相同。
1.13 memcmp
int memcmp ( const void * ptr1,const void * ptr2,size_t num );
解释:比较从ptr1和ptr2指针开始的num个字节 小于 则返回负数, 等于 则返回零, 大于 则返回正数。
2.0 模拟实现
2.1strlen
int my_strlen(const char* str)
{
int count = 0;
while (*str)
{
count++;
str++;
}
return count;
}
2.2 strcpy
char *my_strcpy(char *dest, const char*src)
{
char *ret = dest;
assert(dest != NULL);
assert(src != NULL);
while((*dest++ = *src++))
{
;
}
return ret;
}
2.3 strcat
char *my_strcat(char *dest, const char*src)
{
char *ret = dest;
assert(dest != NULL);
assert(src != NULL);
while(*dest)
{
dest++;
}
while((*dest++ = *src++))
{
;
}
return ret;
}
2.4strstr
char * strstr (const char * str1, const char * str2)
{
char *cp = (char *) str1;
char *s1, *s2;
if ( !*str2 )
return((char *)str1);
while (*cp)
{
s1 = cp;
s2 = (char *) str2;
while ( *s1 && *s2 && !(*s1-*s2) )
s1++, s2++;
if (!*s2)
return(cp);
cp++;
}
return(NULL);
}
2.5
int my_strcmp (const char * src, const char * dst)
{
int ret = 0 ;
assert(src != NULL);
assert(dest != NULL);
while( ! (ret = *(unsigned char *)src - *(unsigned char *)dst) && *dst)
++src, ++dst;
if ( ret < 0 )
ret = -1 ;
else if ( ret > 0 )
ret = 1 ;
return( ret );
}
2.6memcpy
void * memcpy ( void * dst, const void * src, size_t count)
{
void * ret = dst;
assert(dst);
assert(src);
while (count--) {
*(char *)dst = *(char *)src;
dst = (char *)dst + 1;
src = (char *)src + 1;
}
return(ret);
}
2.7memmove
void * memmove ( void * dst, const void * src, size_t count)
{
void * ret = dst;
if (dst <= src || (char *)dst >= ((char *)src + count))
{
`` 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);
}`