字符串函数介绍

目录

        一.求字符串长度 strlen

        二.长度不受限制的字符串函数 strcpy strcat strcmp

        三.长度受限制的字符串函数介绍 strncpy strncat strncmp

        四.字符串查找 strstr strtok

        五.错误信息报告 strerror


1.strlen函数

函数原型:

        size_t strlen(const char* str);     头文件为<string.h>

参数:

        str:想测量的字符串的首元素的地址

作用:        

        strlen函数的作用是求字符串的长度,参数为char*的指针,接受需要测量的字符串的首地址,strlen的工作原理是计算从给出地址起一直到'\0'的字符串的大小,返回类型为size_t,size_t为无符号整形(unsigned int)。

注意事项:
        1.注意strlen判断字符串的结束标识为 ' \0 ' ,strlen统计的是结束标识前面的字符个数。

        2.返回类型为size_t,不存在负的情况

举例说明:

 模拟实现:
        模拟实现原理和strlen的工作原理是一样的,都是通过判断字符串什么时候碰到字符串结束的标识符即 ' \0 ' ,所以我们的模拟实现如下。

size_t my_strlen(const char* str)
{
	int num = 0;
	if (str == NULL)
	{
		perror("default:");//进行错误判断
	}
	while (*str != '\0')
	{
		str++;
		num++;
	}
	return num;
}

 

2.strcpy

 函数原型

        char* strcpy( char *destination , const char* source)    头文件<string.h>

函数参数

        destination:想把source中字符串拷贝进的目的地址

        source:要被拷贝的字符串的首元素地址

函数作用:

        函数会把source中的字符串拷贝进入destination指向的空间中,但是要注意,destination要有足够的空间去接受source中的字符串,source中只拷贝结束标志(' \0 ')以前的字符串内容。

注意事项:
        1.目的地址空间要足够大以便于接受要拷贝的字符串内容。

        2.源字符串必须以' \0 '结尾。

        3.目标空间必须可以变。

举例:

模拟实现:

#include<assert.h>
char* my_strcpy(char* dest, const char* str)
{
	char* ret = dest;//便于返回dest的地址
	assert(dest != NULL);
	assert(str != NULL);
	while (*str!='\0')
	{
		*dest++=*str++;
	}
	*dest = '\0';
	return ret;
}

 3.strcat

 函数原型

 char * strcat ( char * destination, const char * source)       头文件<string.h>

函数参数:

        destination:目标地址

        souce:源地址

函数作用:

        在目标地址的字符串后面追加soure中字符串的内容,source中的追加字符串仍然是'\0'以前的内容,目的地址也是以第一个'\0'作为字符串的结束标志,在第一个'\0'后追加内容

函数注意事项:

        1.源字符串必须以 '\0' 结束。

        2.目标空间必须有足够的大,能容纳下源字符串的内容。        

        3.目标空间必须可修改。 

        4.注意给自己追加的时候会有一些问题。

举例:

模拟实现:

char* my_strcat(char* dest, const char* str)
{
	char* ret = dest;
	assert(dest != NULL && str!=NULL);
	while (*dest != '\0')
	{
		*dest++;
	}
	while (*str != '\0')
	{
		*dest++ = *str++;
	}
	*dest = '\0';
	return ret;
}

4.strcmp

 函数原型

 char * strcmp ( const char * str1, const char * str2)       头文件<string.h>

函数参数:

        str1:要比较的字符串1

        str2:要比较的字符串2

函数作用:

        比较字符串1和字符串2,比较方法是逐位比较,按照ASCII码的大小来比较两个字符串,如果第一个字符串小于第二个字符串则返回一个小于零的数字,如果两个字符串完全相等,则返回零,如果第一个字符串大于第二个字符串则返回一个大于零的数字。

举例:

模拟实现:

int my_strcmp(const char* str1,const char* str2)
{
	assert(str1 != NULL && str2 != NULL);
	while (*str1 == *str2 && *str1!='\0'&& *str2!='\0')
	{
		str1++;
		str2++;
	}
	if (*str1 - *str2 > 0)
	{
		return 1;
	}
	else if (*str2 - *str2 < 0)
	{
		return -1;
	}
	else
	{
		return 0;
	}
}

5.strncpy

 函数原型

 char * strncpy ( char * destination, const char * source,size_t number)

函数参数:

        destination:目的地址

        source:源地址

        number:要拷贝的字节数量

函数作用:

        同strcpy函数,都是把源地址的字节拷贝到目标地址,但是多了数量限制,strcpy函数没有数量的限制。

函数注意事项:

        如果源字符串的长度小于num,则拷贝完源字符串之后,在目标的后边追加0,直到num个

举例:

6.strncat

 函数原型

 char * strncat ( char * destination, const char * source,size_t num)

函数参数:

        destination:目标地址

        source:源地址

        num:要追加的字符数量

函数作用:

        同strcat但是对于字符的追加数量由num来指定。

举例:        

 

 7.strncmp

  函数原型:

 int strncmp ( const char * str1, const char * str2,size_t num)

函数参数:

        str1:要比较的字符串1

        str2:要比较的字符串2

        num:要比较的字符串前几位的数量

函数作用:

        同strncmp,但是对于输入的大小有一定的限制

举例:

 

8.strstr

 函数原型:

 char * strstr (const char * str1, const char * str2)

函数作用:

        如果str1中有str2,则返回str1中第一个匹配str2的地址,如果没有找到,则返回一个空指针,模拟实现可用暴力算法解决或者参考KMP算法。

举例:

9.strtok

 函数原型

 char * strtok ( char * str, const char * delimiter)

函数作用:

        我们用delimiter指向我们定义的一个符号集合,这个符号集合包含了我们自己定义的这个分隔符号,用于根据分割符号来分割str指向的字符串,strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针。 strtok函数的第一个参数不为 NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串 中的位置。 strtok函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标记,如果字符串中不包含更多的标记,则返回一个空指针。

举例:

 

10.strerror

  函数原型:

 char * strerror ( int errnum)

函数作用:

        打印错误信息。其中参数errnum可以取errno,errno包含在<errno.h>这个头文件中。

举例子:

#include <stdio.h>
#include <string.h>
#include <errno.h>//必须包含的头文件
int main ()
{
  FILE * pFile;
  pFile = fopen ("unexist.ent","r");
  if (pFile == NULL)
    printf ("Error opening file unexist.ent: %s\n",strerror(errno));
    //errno: Last error number
  return 0;
}
Edit & Run

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

荞麦壳枕头

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

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

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

打赏作者

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

抵扣说明:

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

余额充值