C语言字符函数与字符串函数:编织文字的舞会之梦(下)

欢迎来到白刘的领域   Miracle_86.-CSDN博客

系列专栏  C语言知识

先赞后看,已成习惯

   创作不易,多多支持!

目录

七、strncpy的使用以及模拟实现

 八、strncat的使用以及模拟实现

九、strncmp的使用以及模拟实现

十、strstr的使用以及模拟实现

十一、strtok的使用

十二、strerror的使用


七、strncpy的使用以及模拟实现

char* strncpy(char* destination, const char* source, size_t num);

在上篇中,我们学到了strcpy,知道了它是用来拷贝字符串的:

C语言字符函数与字符串函数:编织文字的舞会之梦(上)-CSDN博客

这个strncpy,它相比较strcpy多了个字母n,我们再来看上面的函数原型,多了个size_t类型的num,这个n是代表num个字符。也就是说这个函数可以指定拷贝几个字符。

1.原理:将源的前 num 个字符复制到目标。如果源 C 字符串的末尾(由 null 字符表示)在复制 num 字符之前找到,destination 用零填充,直到写入总共 num 个字符。

2.拷贝num个字符从源字符串到目标空间

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

来看它的使用:

#include <stdio.h>
#include <string.h>
int main()
{
	char src[40];
	char dest[40];
	strncpy(src, "Hello World",12);
	strncpy(dest, src,15);
	printf("最终的目标字符串:%s\n", dest);
	return 0;
}

这里编译器给出警告,也就是我们说的追加0:

strncpy的模拟实现,根据原理其实很好操作:

char* mystrncpy(char* dst, const char* src, size_t n)
{
    int i;
    for (i = 0; src[i] && i < n; i++)
    {
        dst[i] = src[i];
    }

    if (i < n)
    {
        dst[i] = 0;
    }
    return dst;
}

 八、strncat的使用以及模拟实现

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

同理,仿照strncpy,这个应该是追加num个字符到目标空间。

1.将source指向字符串的前num个字符追加到destination指向的字符串末尾,再追加⼀个 \0 字符。

2.如果source 指向的字符串的⻓度⼩于num的时候,只会将字符串中到 \0 的内容追加到destination指向的字符串末尾。

直接上代码:

/* strncat example */
#include <stdio.h>
#include <string.h>
int main()
{
	char str1[20];
	char str2[20];
	strcpy(str1, "To be ");
	strcpy(str2, "or not to be");
	strncat(str1, str2, 6);
	printf("%s\n", str1);
	return 0;
}

再来看模拟实现:

char * mystrncat(char * dst, const char * src, size_t n)
{
	char * tmp = dst;
   
  while (*dst)
  {
    dst++;
  }
   
  int i;
  for (i = 0; src[i] && i < n; i++)
  {
    dst[i] = src[i];
  }
   
  dst[i] = 0;
  return tmp;
}

九、strncmp的使用以及模拟实现

int strncmp(const char* str1, const char* str2, size_t num);
⽐较str1和str2的前num个字符,如果相等就继续往后⽐较,最多⽐较num个字⺟,如果提前发现不⼀样,就提前结束,⼤的字符所在的字符串⼤于另外⼀个。如果num个字符都相等,就是相等返回0。

我们来看模拟实现:

int Mystrncmp(const char* str1, const char* str2, int n)
{
	assert(str1 != NULL && str2 != NULL);
	while (n-- && *str1 == *str2)
	{
		str1++;
		str2++;
	}
	return *str1 - *str2;
}

将n放进循环中再自减,达到比较n个字符这一效果。

十、strstr的使用以及模拟实现

这个其实不太好想是什么意思,单从字面上来讲,放了两个str是什么意思呢?我们来看函数原型:

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

 其实这个函数是用来返回字符串str2在字符串str1中第一次出现的位置。

细节注意:字符串的比较的不包含字符'\0',以'\0'作为结束标准。

#include <stdio.h>
#include <string.h>
int main()
{
	char str[] = "This is a simple string";
	char* pch;
	pch = strstr(str, "simple");
	strncpy(pch, "sample", 6);
	printf("%s\n", str);
	return 0;
}

 运行结果:

模拟实现:

思路:首先str2可以是'\0',如果是的话,直接返回str1的地址。接下来我们创建一个指针cp来指向str1,然后将其放进循环,我们还需要两个指针分别指向两个字符串,然后遍历一一对照是否相等。

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);
}

十一、strtok的使用

char* strtok(char* str, const char* sep);

这个函数是用来分割字符串的。

1.sep参数指向⼀个字符串,定义了⽤作分隔符的字符集合。

2.第⼀个参数指定⼀个字符串,它包含了0个或者多个由sep字符串中⼀个或者多个分隔符分割的标记。

3.strtok函数找到str中的下⼀个标记,并将其⽤ \0 结尾,返回⼀个指向这个标记的指针。(注:strtok函数会改变被操作的字符串,所以在使⽤strtok函数切分的字符串⼀般都是临时拷⻉的内容并且可修改。)

4.strtok函数的第⼀个参数不为 比特就业课主页:https://m.cctalk.com/inst/s9yewhfr

NULL ,函数将找到str中第⼀个标记,strtok函数将保存它在字符串中的位置。

5.strtok函数的第⼀个参数为 NULL ,函数将在同⼀个字符串中被保存的位置开始,查找下⼀个标记。

6.如果字符串中不存在更多的标记,则返回 NULL 指针。

#include <stdio.h>
#include <string.h>

int main()
{
	char arr[] = "192.168.6.111";
	char* sep = ".";
	char* str = NULL;
	for (str = strtok(arr, sep); str != NULL; str = strtok(NULL, sep))
	{
		printf("%s\n", str);
	}
	return 0;
}

其实就记住,str是要分割的字符串,sep是字符的集合,str里面有sep里的元素,然后这个函数会找到str中要分割的那个点(也就是sep的元素),并且将其替换成'\0',返回值为首元素地址,同时也会记录'\0'之后的首元素地址。

十二、strerror的使用

char* strerror(int errnum);

error这个单词大家都知道,是错误的意思,那这个函数就是用来返回错误的。

strerror函数可以把参数部分错误码对应的错误信息的字符串地址返回来。
在不同的系统和C语⾔标准库的实现中都规定了⼀些错误码,⼀般是放在< errno.h>  这个头⽂件中说明的,C语⾔程序启动的时候就会使⽤⼀个全⾯的变量errno来记录程序的当前错误码,只不过程序启动的时候errno是0,表⽰没有错误,当我们在使⽤标准库中的函数的时候发⽣了某种错误,就会讲对应的错误码,存放在errno中,⽽⼀个错误码的数字是整数很难理解是什么意思,所以每⼀个错误码都是有对应的错误信息的。strerror函数就可以将错误对应的错误信息字符串的地址返回。
#include <errno.h>
#include <string.h>
#include <stdio.h>

//我们打印⼀下0~10这些错误码对应的信息
int main()
{
	int i = 0;
	for (i = 0; i <= 10; i++) {
		printf("%s\n", strerror(i));
	}
	return 0;
}

在Window11+VS2022环境下输出结果如下:

再来举个栗子:

#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));
	return 0;
}

输出结果:

Error opening file unexist.ent: No such file or directory

也可以了解一下 perror函数

perror 函数相当于⼀次将上述代码中的第9⾏完成了,直接将错误信息打印出来。perror函数打印完参数部分的字符串后,再打印⼀个冒号和⼀个空格,再打印错误信息。
#include <stdio.h>
#include <string.h>
#include <errno.h>
int main()
{
	FILE* pFile;
	pFile = fopen("unexist.ent", "r");
	if (pFile == NULL)
		perror("Error opening file unexist.ent");
	return 0;
}

输出结果是一样的:

Error opening file unexist.ent: No such file or directory

  • 108
    点赞
  • 77
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 126
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 126
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Miracle_86.

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

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

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

打赏作者

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

抵扣说明:

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

余额充值