C语言学习笔记(14)字符串和内存函数2

Posted 小倪同学 -_-

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言学习笔记(14)字符串和内存函数2相关的知识,希望对你有一定的参考价值。

strtok

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

  1. sep参数是个字符串,定义了用作分隔符的字符集合
  2. 第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标记。
  3. strtok函数找到str中的下一个标记 ,并将其用\\0结尾,返回一个指向这个标记的指针。( 注: strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容并且可修改。)
  4. strtok函数的第一个参数不为NULL,函数将找到str中第一个标记 ,strtok函数将保存它在字符串中的位置.
  5. strtok函数的第一个参数为NULL,函数将在同一个字符串中被保存的位置开始,查找下一个标记。
  6. 如果字符串中不存在更多的标记,则返回NULL指针。

#include<stdio.h>
#include<string.h>
int main()
{
	char arr[] = "nzb@abc.def hijk";
	char* p = "@. ";
	char tmp[30] = { 0 };
	strcpy(tmp, arr);

	char* ret = NULL;

	for (ret = strtok(tmp, p); ret != NULL; ret=strtok(NULL, p))
	{
		printf("%s\\n", ret);
	}

	return 0;
}

输出结果如下
在这里插入图片描述

strerror

char * strerror ( int errnum);

返回错误码,所对应的错误信息。

  1. 使用库函数的时候 .
  2. 调用库函数失败时,都会设置错误码。

#include<stdio.h>
#include <errno.h>//该函数需要的头文件
#include<string.h>

int main()
{
	FILE* pf = fopen("test.txt", "r");
	if (pf == NULL)
	{
		printf("%s\\n", strerror(errno));
		return 1;
	}
	fclose(pf);
	pf = NULL;

	return 0;
}

在这里插入图片描述
与之类似的还有fopen函数,fopen是直接打印错误信息

#include<stdio.h>
int main()
{
	//打开文件失败的时候,会返回NULL
	FILE* pf = fopen("test.txt", "r");
	if (pf == NULL)
	{
		perror("fopen");
		return 1;
	}
}

在这里插入图片描述

字符分类函数

在这里插入图片描述

字符转换函数

int tolower ( int c )
int toupper ( int c )

#include<stdio.h>
#include <ctype.h>
int main()
{
	char arr[20] = { 0 };
	scanf("%s", arr);
	int i = 0;
	while (arr[i] != '\\0')
	{
		if (isupper(arr[i]))
		{
			arr[i] = tolower(arr[i]);//大写转小写
		}
		printf("%c ", arr[i]);
		i++;
	}

	return 0;
}

在这里插入图片描述

内存操作函数

memcpy

void * memcpy ( void * destination, const void * source, size_t num );

  1. 函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置。
  2. 这个函数在遇到’\\0’的时候并不会停下来。
  3. 如果source和destination有任何的重叠,复制的结果都是未定义的。

int main()
{
	int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 };
	int arr2[10] = { 0 };
	memcpy(arr2, arr1, 20);
	return 0;
}

在这里插入图片描述
模拟实现

#include<stdio.h>
#include<assert.h>
void* my_memcpy(void* dest, const void* src, size_t num)
{
	void* ret = dest;
	assert(dest && src);

	while (num--)
	{
		*(char*)dest = *(char*)src;
		dest = (char*)dest + 1;
		src = (char*)src + 1;
	}
	return ret;
}
int main()
{
	int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 };
	int arr2[10] = { 0 };
	my_memcpy(arr2, arr1, 20);
	return 0;
}

memmove

void * memmove ( void * destination, const void * source, size_t num );

  1. 和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。
  2. 如果源空间和目标空间出现重叠,就得使用memmove函数处理。
int main()
{
	int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 };
	memmove(arr1+2, arr1, 20);
	return 0;
}

在这里插入图片描述
模拟实现:
在这里插入图片描述

#include<stdio.h>
#include<assert.h>
void* my_memmove(void* dest, const void* src, size_t num)
{
	void* ret = dest;
	assert(dest && src);

	if (dest < src)
	{
		//前->后
		while (num--)
		{
			*(char*)dest = *(char*)src;
			dest = (char*)dest + 1;
			src = (char*)src + 1;
		}
	}
	else 
	{
		//后->前
		while (num--)
		{
			*((char*)dest + num) = *((char*)src + num);
		}
	}
	return ret;
}

int main()
{
	int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 };
	my_memmove(arr1+2, arr1, 20);
	return 0;
}

memcmp

int memcmp ( const void * ptr1 , const void * ptr2 , size_t num ) ;

  • 比较从ptr1和ptr2指针开始的num个字节

int main()
{
	float arr1[] = { 1.0, 2.0,3.0,4.0 };
	float arr2[] = { 1.0, 3.0 };
	int ret1 = memcmp(arr1, arr2, 4);
	printf("%d\\n", ret1);
	int ret2 = memcmp(arr1, arr2, 8);
	printf("%d\\n", ret2);

	return 0;
}

在这里插入图片描述

memset

void * memset ( void * ptr, int value, size_t num );

  • 将前num个字节设置成指定的value

int main()
{
	int arr[10] = { 0 };
	memset(arr, 1, 20);//以字节为单位设置内存的

	return 0;
}

结果如下
在这里插入图片描述

以上是关于C语言学习笔记(14)字符串和内存函数2的主要内容,如果未能解决你的问题,请参考以下文章

C语言笔记进阶篇第二章:字符串函数和内存函数

C语言笔记进阶篇第二章:字符串函数和内存函数

C语言进阶学习笔记三字符串函数+内存函数详解

C语言第三天笔记2016年01月14日(周四)P.M

C语言学习笔记(13)字符串和内存函数1

C学习笔记 知识集锦