C语言:字符函数和字符串函数(一篇拿捏字符串函数!)

2023-10-27

目录

求字符串长度:

1. strlen(字符串长度)

长度不受限制函数:

2. strcpy(字符串拷贝)

3. strcat(字符串追加)

4. strcmp(字符串比较)

长度受限制函数:

5. strncpy(字符串拷贝)

6. strncat(字符串追加)

7. strncmp(字符串比较)

字符串查找:

8. strstr(查找字符串子串)

9. strtok(字符串分割)

错误信息报告:

10. strerror(返回错误信息)

字符操作函数:

字符转换:

1. tolower(小写->大写)

2. toupper(大写->小写)

内存操作函数:

1. memcpy(内存拷贝)

2. memmove(内存拷贝)

3. memcmp(内存比较)

4. memset(内存设置)


求字符串长度:

1. strlen(字符串长度)

size_t   strlen ( const char * str );
        str:C 字符串。
返回值:unsigned  int.
1.1 字符串已经 '\0' 作为结束标志 strlen 函数返回的是在字符串中 '\0' 前面出现的字符个数 (不包
含 '\0' )。
1.2 参数指向的字符串必须要以 '\0'结束
1.3 注意函数的返回值为size_t ,是无符号的( 易错 )。
#include <stdio.h>
#include <string.h>

int main()
{
	if ((int)strlen("abc") - (int)strlen("abcdef") > 0)
	{
		printf("大于\n");
	}
	else
	{
		printf("小于等于\n");
	}

	return 0;
}

长度不受限制函数:

2.strcpy(字符串拷贝)

char*  strcpy(char * destination, const char * source );
        destinatiob:指向要在其中复制内容的目标 数组的指针
        source:要复制的 C 字符串。
2.1 源字符串必须以 '\0' 结束。
2.2 会将源字符串中的 '\0' 拷贝到目标空间。
2.3 目标空间必须足够大,以确保能存放源字符串。
2.4 目标空间必须可变。
#include <stdio.h>
#include <string.h>

int main()
{
	//char arr1[3] = "";
	//char arr2[] = "hello bit";
	char* arr1 = "xxxxxxxxxx";
	char arr2[6] = { 'a', 'b', 'c', 'd', 'e' , '\0'};
	strcpy(arr1, arr2);
	printf("%s\n", arr1);

	return 0;
}

3.strcat(字符串追加)

char * strcat ( char * destination, const char * source );
        
         destination:指向目标数组的指针,该数组应包含 C 字符串,并且足够大以包含串联的结果字符串。
        source: 要追加的 C 字符串。这不应与 目标 重叠。
3.1 源字符串必须以 '\0' 结束。
3.2 目标空间必须有足够的大,能容纳下源字符串的内容。
3.3 目标空间必须可修改。
#include <stdio.h>
#include <string.h>

int main()
{
	char arr1[20] = "hello ";
	char arr2[] = "world";
	strcat(arr1, arr2);

	printf("%s\n", arr1);
	return 0;
}

4. strcmp(字符串比较)

int strcmp ( const char * str1, const char * str2 );
        
         str1:要比较的 C1 字符串。
         str2:要比较的 C2 字符串。
4.1 标准规定:
        4.1.1 第一个字符串大于第二个字符串,则返回大于 0 的数字
        4.1.2 第一个字符串等于第二个字符串,则返回0
        4.1.3 第一个字符串小于第二个字符串,则返回小于 0 的数字
#include <stdio.h>
#include <string.h>

int main()
{
	int ret = strcmp("bbq", "bcq");
	if (ret>0)
		printf(">\n");

	printf("%d\n", ret);
	return 0;
}

长度受限制函数:

5. strncpy(字符串拷贝)

char * strncpy ( char * destination, const char * source, size_t num );
        
         destination:指向要在其中复制内容的目标数组的指针。
         source:要复制的 C 字符串。
         num :要从 复制的最大字符数;

                  size_t 是无符号整数类型。

5.1 拷贝 num 个字符从源字符串到目标空间
5.2 如果源字符串的长度小于 num,则拷贝完源字符串之后,在目标的后边追加0,直到num
#include <stdio.h>
#include <string.h>

int main()
{
	char arr1[20] = "abcdef";
	char arr2[] = "xxx";
	strncpy(arr1, arr2, 5);

	return 0;
}

6. strncat(字符串追加)

char * strncat ( char * destination, const char * source, size_t num );
        
         destination:指向目标数组的指针,该数组应包含一个 C 字符串,并且足够大以包含串联的结果字符串,包括其他 null 字符。
        source:要追加的 C 字符串。
         num: 要追加的最大字符数。

                 size_t是无符号整数类型。

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

int main()
{
	char arr1[20] = "abcdef\0yyyyyyyy";
	char arr2[] = "xxxxxxxxx";
	strncat(arr1, arr2, 3);

	return 0;
}

7. strncmp(字符串比较)

int strncmp ( const char * str1, const char * str2, size_t num );
        
         str1:要比较的 C1 字符串。
        str2:要比较的 C2 字符串。
        num:要比较的最大字符数。
                 size_t是无符号整数类型。
7.1 比较到出现另个字符不一样或者一个字符串结束或者num个字符全部比较完

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

int main()
{
	char arr1[] = "abcqwertyuiop";
	char arr2[] = "abcdef";
	printf("%d\n", strncmp(arr1, arr2, 4));

	return 0;
}

字符串查找:

8. strstr(查找字符串子串)

char * strstr ( const char *str1, const char * str2);
        
         str1:要扫描的 C 字符串。
         str2:包含要匹配的字符序列的 C 字符串。
#include <stdio.h>
#include <string.h>

int main()
{
	char arr1[] = "abbbcdef";
	char arr2[] = "bbc";

	char* ret = strstr(arr1, arr2);
	if (ret != NULL)
		printf("%s\n", ret);
	else
		printf("找不到\n");

	return 0;
}

9. strtok(字符串分割)

char * strtok ( char * str, const char * sep );
        
         str:要截断的 C 字符串。请注意,此字符串是通过分解为较小的字符串(标记)来修改的。或者,可以指定空指针,在这种情况下,函数将继续扫描以前成功调用函数的位置。
        sep :包含分隔符字符的 C 字符串。这些可能因调用而异。
9.1 sep 参数是个字符串,定义了用作分隔符的字符集合。
9.2 第一个参数指定一个字符串,它包含了 0 个或者多个由 sep 字符串中一个或者多个分隔符分割的标记。
9.3 strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针。 (注:
strtok 函数会改变被操作的字符串,所以在使用 strtok 函数切分的字符串一般都是临时拷贝的内容
并且可修改。)
9.4 strtok 函数的第一个参数不为 NULL ,函数将找到 str 中第一个标记, strtok 函数将保存它在字符串中的位置。
9.5 strtok 函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标记。
9.6 如果字符串中不存在更多的标记,则返回 NULL 指针
#include <stdio.h>
#include <string.h>

int main()
{
	char arr[] = "zpengwei@yeah.net@666#777";
	char copy[30];
	strcpy(copy, arr);

	char sep[] = "@.#";
	char* ret = NULL;

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

	return 0;
}

错误信息报告:

10. strerror(返回错误信息)

char * strerror ( int errnum );
        
         errnum :错误号。
        库函数在执行的时候,发生了错位会将一个错误码存放errno这个变量中errno是C语言提供的一个全局的变量。
10.1 返回错误码,所对应的错误信息。 
#include <stdio.h>
#include <string.h>

int main()
{
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d: %s\n", i, strerror(i));//
	}
	return 0;
}

字符操作函数:

字符串函数
函数
如果他的参数符合下列条件就返回真
iscntrl
任何控制字符
isspace
空白字符:空格 ‘ ’ ,换页 ‘\f’ ,换行 '\n' ,回车 ‘\r’ ,制表符 '\t' 或者垂直制表符 '\v'
isdigit
十进制数字 0~9
isxdigit
十六进制数字,包括所有十进制数字,小写字母 a~f ,大写字母 A~F
islower
小写字母 a~z
isupper
大写字母 A~Z
isalpha
字母 a~z A~Z
isalnum
字母或者数字, a~z,A~Z,0~9
ispunct
标点符号,任何不属于数字或者字母的图形字符(可打印)
isgraph
任何图形字符
isprint
任何可打印字符,包括图形字符和空白字

字符转换:

1.towlower(小写->大写)

int  tolower ( int c );

        

        c:要转换、转换为 int 或 EOF 的字符。

#include <stdio.h>
#include <ctype.h>

int main()
{
    printf("%c\n", tolower('A'));
    printf("%c\n", tolower('s'));
    
    return 0;
}

2. toupper(大写->小写)

int  toupper ( int c );

        

        c:要转换、转换为 int 或 EOF 的字符。

#include <stdio.h>
#include <ctype.h>

int main()
{
	char arr[20] = { 0 };
	gets(arr);//遇到空格继续读

	char* p = arr;
	while (*p)
	{
		if (isupper(*p))// *p>='A' && *p<='Z'
		{
			*p = tolower(*p);//*p = *p+32;
		}
		p++;
	}
	printf("%s\n", arr);
	return 0;
}

内存操作函数:

1. memcpy(内存拷贝)

void * memcpy ( void * destination, const void * source, size_t num );
        
         destination:指向要在其中复制内容的目标数组的指针,类型转换为 void* 类型的指针。
        source:指向要复制的数据源的指针,类型转换为 const void* 类型的指针。
        num :要复制的字节数。
                    size_t 是无符号整数类型。
1.1 函数 memcpy source的位置开始向后复制num字节的数据到destination 的内存位置
1.2 这个函数在遇到 '\0' 的时候并 不会 停下来
1.3 如果 source destination 有任何的 重叠 复制的结果都是未定义的。

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

int main()
{
	int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
	int arr2[20] = { 0 };
	//将arr1中的内容,拷贝到arr2中
	memcpy(arr2, arr1, 40);
         int*  int*
	int i = 0;
	for (i = 0; i < 20; i++)
	{
		printf("%d ", arr2[i]);
	}

	return 0;
}

2. mommove(内存拷贝)

void * memmove ( void * destination, const void * source, size_t num );
        
         destination:指向要在其中复制内容的目标数组的指针,类型转换为 void* 类型的指针。
        source:指向要复制的数据源的指针,类型转换为 const void* 类型的指针。
        num : 要复制的字节数。

                  size_t 是无符号整数类型。

2.1 memcpy差别就是memmove 函数处理的源内存块和目标内存块是可以重叠的。
2.2 如果源空间和目标空间出现重叠,就得使用 memmove 函数处理。
#include <stdio.h>
#include <string.h>

int main()
{
	int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
	//             1 2 1 2 3 4 5 8 9 10
	memmove(arr1, arr1+2, 20);
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr1[i]);
	}
	return 0;
}

3. memcmp(内存比较)

int  memcmp ( const void * ptr1, const void * ptr2, size_t num );
        
         ptr1:指向内存块的指针。
        ptr2:指向内存块的指针。
         num :要比较的字节数。
3.1 比较从 ptr1 ptr2 指针开始的 num个字节;
3.2 返回值如下:

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

int main()
{
	int arr1[] = { 1,2,1,4,5,6 };
	int arr2[] = { 1,2,257 };
	int ret = memcmp(arr1, arr2, 10);
	printf("%d\n", ret);
	return 0;
}

4. memset(内存设置)

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

        

        ptr1:指向要填充的内存块的指针。

        value:要设置的值。该值作为 int 传递,但该函数使用此无符号 char 转换填充内存块。

        num :要设置为该值的字节数。
                    size_t 是无符号整数类型。

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

int main()
{
	char arr[] = "hello bit";
	memset(arr+1,'x',4);//以字节为单位设置的
	printf("%s\n", arr);
	return 0;
}

以上就是个人学习见解和学习的解析,欢迎各位大佬在评论区探讨!

感谢大佬们的一键三连! 感谢大佬们的一键三连! 感谢大佬们的一键三连!

                                              

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

C语言:字符函数和字符串函数(一篇拿捏字符串函数!) 的相关文章

随机推荐

  • java随笔:类与对象1

    1 好久不见 隔了几个月没有更新csdn了 主要是觉得自己的水平实在不怎么样 最后找到了原因 基础不扎实 由于近一段时间学的是android开发 android开发是一门基于java之上的技术 kotlin选手求轻喷 所以最近一段时间也一直
  • 网盘搜索引擎汇总——快速搜索你想要的资料

    1 网盘搜索引擎 http so baiduyun me 备注 提供百度谷歌双索 几乎包含所有的网盘 默认搜索百度网盘 如果百度网盘搜不到 各位可以选择其他网盘再进行搜索 2 找文件 http www zhaofile com 备注 搜索的
  • ElasticSearch部署架构和容量规划

    一 前言 前面介绍了ElasticSearch原理和使用相关的内容 在生产环境如何比较科学的进行容量规划 部署 调优 排查问题呢 业界和官方也对相关的问题进行总结 我这边也结合自己的经验对这些使用ElasticSearch经常遇到的问题进行
  • 音视频开发学习笔记(一)

    开发概述 分辨率和像素的关系 DPI Dot Per Inch 表示打印分辨率 指每英寸长度上的点数 DPI 又可细分为水平分辨率和垂直分辨率 例如一张 1英寸1英寸 1英寸 2 54cm 的图片 如果它的水平分辨率是100 dpi 垂直分
  • drm 学习笔记-2:DRM介绍

    声明 文章从DRM WIKI翻译过来的 可以帮忙英语不好同学更好的了解 刚过4级的英语水平 能力有限 原文地址 https en wikipedia org wiki Direct Rendering Manager 正文 Direct R
  • mysql order by 顺序_mysql group by order by 执行顺序

    写的顺序 select from where group by having order by 执行顺序 from where group by having select order by 本文就和大家一起深入研究下mysql中group
  • 设计模式之桥接模式(Bridge)摘录

    23种GOF设计模式一般分为三大类 创建型模式 结构型模式 行为模式 创建型模式包括 1 FactoryMethod 工厂方法模式 2 Abstract Factory 抽象工厂模式 3 Singleton 单例模式 4 Builder 建
  • linux下编译安装skynet

    最近开始skynet的学习和开发工作 本文只是作为自己使用过程中的一个简单的记录 大神勿喷 初学者在linux编译还是会遇到很多问题 记录一下 后续会陆续记录一些源码分析文档 和使用 的心得 本文操作基于centos 安装编译工具 yum
  • 编年史

    79年 6月 出生 85年 6岁 上小学 91年 12岁 小学毕业 上初中 94年 15岁 初中毕业 上高中 97年 某月 买第一台机器 7月 高中毕业 正常的人生道路结束 9月 至时代大学读书 98年 10月 从时代大学退学 11月 和Z
  • 内网穿透——搭建私人影音媒体平台

    文章目录 1 前言 2 Jellyfin服务网站搭建 2 1 Jellyfin下载和安装 2 2 Jellyfin网页测试 3 本地网页发布 3 1 cpolar的安装和注册 3 2 Cpolar云端设置 3 3 Cpolar本地设置 4
  • springboot 修改了端口不生效_SpringBoot 速记

    Demo 脚手架项目地址 https github com Vip Augus springboot note Table of Contents generated with DocToc SpringBoot 速记构建项目SpringB
  • uniapp选择只选择月份demo效果(整理)

  • 多元相关性分析_SPSS分析问卷数据的流程------一篇带你学会SPSS

    毕业大半年了 现在还清晰的记得当时毕业论文不会用SPSS的痛苦 每天挣扎把度娘 知乎 知网 优酷 某宝等各大网站都逛了个遍 依然没有找到用SPSS完整的分析一份问卷的流程 几乎都是零零散散的一些知识 又或是几十个视频的解说却总是听不到自己想
  • cadence 17.2 入门学习3 allegro

    目录 布局设计 查看进度状态 AD原理图转cadence AD封装转cadence 导入导出层面颜色设置的方法 重命名元器件序号 模块复用 模块旋转 布局设计 布局设置 执行菜单命令Setup Application Mode Placem
  • python实现字符串去重

    python实现字符串去重 一 方法一 通过列表set方法 1 set也是一组数 无序 内容又不能重复 通过调用set 方法创建 2 例子 s 233333 print s a set list s print a a join a pri
  • FPGA时序约束简介和应用技巧

    FPGA时序约束简介和应用技巧 FPGA Field Programmable Gate Array 是一种可编程逻辑设备 广泛应用于数字电路设计和实现 FPGA的性能和正确功能的实现与时序约束密切相关 时序约束是一种描述设计中各个时钟域之
  • 实证操作:R语言实现分位数回归的介绍

    分位数回归是估计一组回归变量X与被解释变量Y的分位数之间线性关系的建模方法 从最小二乘法可以看出 传统回归中最小化残差的平方极易受极端值的影响 而且属于均值回归 这种方法不能得到不同分布下的数据关系 导入程序包与数据 分位数回归不考虑同方差
  • Java修饰符protected

    Java protected 详解 可见性有以下两点 被protected修饰的成员对本包内的成员及其子类可见 若基类和子类不在同一包中 那么在子类中 子类实例可以访问从基类继承来的protected 方法 子类中的基类实例不能访问prot
  • WIN10更改代理设置后无法保存的解决办法

    每次更改代理之后保存 推出界面再进来发现还是和原来一样 这应该是代理报错失败 解决办法如下 win R regedit 打开注册表编辑器 找到计算机 HKEY LOCAL MACHINE SOFTWARE Policies Microsof
  • C语言:字符函数和字符串函数(一篇拿捏字符串函数!)

    目录 求字符串长度 1 strlen 字符串长度 长度不受限制函数 2 strcpy 字符串拷贝 3 strcat 字符串追加 4 strcmp 字符串比较 长度受限制函数 5 strncpy 字符串拷贝 6 strncat 字符串追加 7