详细的字符函数和字符串函数(相关实现)

本篇文章将详细介绍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);
}`

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大大白的小小白

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值