字符函数

1.字符分类函数

专门做字符分类的函数,需包含头文件cype.h

int islower ( int c );

如果是小写字母,则返回非0的整数;如果不是小写字母,则返回0。

2. 字符转换函数

int tolower ( int c ); //
将参数传进去的⼤写字⺟转⼩写
     
int toupper ( int c ); //
将参数传进去的⼩写字⺟转⼤写

小写转大写,达到了-32的结果。

字符串函数

1.strlen的使用和模拟实现

size_t strlen ( const char * str );

strlen返回'0’之前字符的个数

注意,函数返回值是size_t(易错)

模拟实现

int my_strlen(char* p)
{
	int count = 0;
	while (*p != '\0')
	{
		p++;
		count++;
	}
	return count;
}
int main()
{
	char str[] = "abcdef";
	int ret = my_strlen(str);
	printf("%d\n", ret);
	return 0;
}

2.strcpy的使用和模拟实现

char* strcpy(char * destination, const char * source );

把一个字符串完整复制到另一个字符数组里,包括结尾的'\0'。

模拟实现

char* my_strcpy(char* dest, const char* src)
{
	char* ret = dest;
	while (*dest++ = *src++)
	{
		;
	}
	return ret;
}
int main()
{
	char str1[] = "hello world";
	char str2[] = "xxxxx";
	my_strcpy(str1, str2);
	printf("%s\n", str1);
	return 0;
}

3.strcat的使用和模拟实现

char *strcat(char *dest, const char*src);

把源字符串拼接到目标字符串的后面

模拟实现

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

}
int main()
{
	char str1[20] = "hello ";
	char str2[] = "world";
	my_strcat(str1, str2);
	printf("%s\n", str1);
}

4.strcmp的使用和模拟实现

int strcmp(const char *str1, const char *str2);

比较两个字符串是否相等。

返回值(重点)

• 返回 0:str1 和 str2 完全相等

• 返回 < 0:str1 小于 str2(按ASCII码比)

• 返回 > 0:str1 大于 str2

模拟实现

int my_strcmp(const char* str1, const char* str2)
{
	while (*str1 == *str2)
	{
		if (*str1 == '\0')
		{
			return 0;
		}
		str1++;
		str2++;
	}
	return *str1 - *str2;
}
int main()
{
	char str1[] = "abcdef";
	char str2[] = "abcddd";
	int ret = strcmp(str1, str2);
	printf("%d\n", ret);
	return 0;
}

5.strncpy的使用

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

拷贝num个字符从源字符串到目标空间
如果src<num,剩下的位置填'\0',直到补够n个

6.strncat的使用

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

7.strncmp的使用

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

比较str1和str2的前num个字符,如果相等就继续往后比较,最多比较num个字母,如果提前发现不一样,就提前结束,大的字符所在的字符串大于另外一个。如果num个字符都相等,就是相等返回0。

8.strstr的使用和模拟实现

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

在一个字符串 str1 中,查找是否包含子串 str2。

• 如果找到:返回 str2 在 str1 中第一次出现的地址

• 如果没找到:返回 NULL

模拟实现

char* my_strstr(const char* str1, const char* str2)
{
	const char* s1 = NULL;
	const char* s2 = NULL;
	//const char* cur = str1;
	if (*str2 == '0')
		return (char*)str1;
	while (*str1)
	{
		s1 = str1;
		s2 = str2;
		while (*s1 == *s2&&*s1!='\0'&&*s2!='\0')
		{
			s1++;
			s2++;
		}
		if (*s2 == '\0')
		{
			return str1;
		}
		str1++;
	}
	return NULL;
}
int main()
{
	char arr1[] = "abcdefabcdef";
	char arr2[] = "cdef";
	char* ret = my_strstr(arr1, arr2);
	if (ret == NULL)
	{
		printf("找不到");
	}
	else
	{
		printf("%s\n", ret);
	}
	return 0;
}

9.strtok函数的使用和strerror的使用

未完待续

内存函数

1.memcpy的使用和模拟实现

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

按字节拷贝内存,不只是字符串,任意数据都能拷。
从 src 复制 n 个字节 到 dest
遇到 \0 不会停,这是和 strcpy 最大区别
source和destination最好不要有内存的重叠

模拟实现

void* my_memcpy(void* dest,const void* src, size_t num)
{
	void* ret = dest;
	int i = 0;
	for (i = 0; i < num; i++)
	{
		*(char*)dest =*(char*)src;
		dest = (char*)dest + 1;
		src = (char*)src + 1;
	}
	return ret;
}
int main()
{
	int arr1[] = {1,2,3,4,5,6,7,8,9,10};
	int arr2[20] = { 0 };
	my_memcpy(arr1, arr2, 20);
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr1[i]);
	}
	return 0;
}

2.memmove的使用和模拟实现

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

和memcpy的功能几乎一样
区别是源内存块和目标内存块是可以重叠的
出现重叠就要用memmove

模拟实现

void* my_memmove(void* dest,const void* src, size_t num)
{
	void* ret = dest;
	if (dest < src)
	{
		while (num--)
		{
			*(char*)dest = *(char*)src;
			dest = (char*)dest + 1;
			src = (char*)src + 1;
		}
	}
	else
	{
		dest = (char*)dest + num-1;
		src = (char*)src + num-1;
		while (num--)
		{
			*(char*)dest = *(char*)src;
			dest = (char*)dest - 1;
			src = (char*)src - 1;
		}
	}
	return ret;
}
int main()
{     //01 00 00 00 02 00 00 00 03 00 00 00.....09 00 00 00 0A 00 00 00
	int arr[] = {1,2,3,4,5,6,7,8,9,10};
	my_memmove(arr+2, arr, 20);
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

3.memset的使用

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

将内存中的值以字节为单位设置成想要的内容
注意,是按字节为单位
int有四个字节,会将每个字节的值都改变
因此,对int等只能用来赋值0
对char随便用

#include <stdio.h>
#include <string.h>
int main ()
{
char str[] = "hello world";
memset (str,'x',6);
printf(str);
return 0;
}

4.memcmp函数的使用

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

比较两段内存的前 n 个字节,逐字节对比。

返回值(和 strcmp 一模一样)

• 返回 0:前 n 个字节完全相同

• 返回 < 0:s1 < s2

• 返回 > 0:s1 > s2


Logo

开源鸿蒙跨平台开发社区汇聚开发者与厂商,共建“一次开发,多端部署”的开源生态,致力于降低跨端开发门槛,推动万物智联创新。

更多推荐