C语言程序设计——字符、字符串、内存函数

news2024/11/26 19:25:01

一、长度不受限的字符串函数

1. strlen

size_t strlen(const char* str);

功能:求字符串长度

(1)字符串以'\0'作为结束标志,strlen函数返回的是在字符串中'\0'之前出现的字符个数(不包含'\0')。

(2)参数指向的字符串,必须要以'\0'结尾。

(3)strlen函数返回值类型是size_t,是无符号整型。

模拟实现:

size_t my_strlen(const char* str) {
	assert(str);
	size_t res = 0;
	while (*str != '\0') {
		++res;
		++str;
	}
	return res;
}

2. strcpy

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

功能:将source指向的字符串拷贝到destination指向的空间中

(1)源字符串必须以'\0'结尾;

(2)strcpy会将源字符串中的'\0'拷贝到目标空间中,且拷贝完第一个'\0'后停止拷贝;

(3)目标空间必须足够大,以保证能够存放源字符串;

(4)目标空间必须是可修改的。

模拟实现:

char* my_strcpy(char* destination, const char* source) {
	assert(source && destination);
	char* ret = destination;
	while (*ret++ = *source++);
	return destination;
}

3. strcat

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

功能:将source指向字符串,追加到destination指向空间中字符串的末尾

(1)源字符串必须以'\0'结尾;

(2)目标空间必须足够大,以保证能够追加源字符串;

(4)目标空间必须是可修改的;

(5)不能自己给自己追加!

模拟实现:

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

4. strcmp

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

功能:比较两个字符串大小

(1)第一个字符串大于第二个字符串,则返回大于0的数字;

(2)第一个字符串等于第二个字符串,则返回0;

(3)第一个字符串小于第二个字符串,则返回小于0的数字。

模拟实现:

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

二、长度受限的字符串函数

1. strncpy

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

功能:拷贝num个字符从源字符串到目标空间

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

2. strncat

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

功能:追加num个字符从source指向字符串中到destination指向字符串末尾

(1)若source指向的字符串字符个数少于num个,则只将该字符串全部追加到目标末尾。

3. strncmp

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

功能:比较两个字符串大小

(1)只比较到出现两个字符不一样,或一个字符串结束,或num个字符全部比较完。

三、其他字符串函数

1. strstr子串查找

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

功能:查找字符串str2是否是str1的子串

(1)是,则返回子串在str1中的起始地址;

(2)不受,则返回NULL。

2. strtok切割字符串

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

功能:字符串切割

(1)sep参数是一个字符串,定义了用作分隔符的字符集合;

(2)第一个参数指定一个字符串,它包含了0个或多个分隔符分割的标记;

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

(4)strtok函数的第一个参数不为NULL,函数将找到str中的第一个标记,strtok函数将保存它在字符串中的位置;

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

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

3. strerror错误报告函数

char* strerror(int errnum);

功能:返回错误码所对应的错误信息

(1)C语言的库函数在执行失败时,会设置对应的错误码;

(2)strerror函数就是根据错误码,返回对应的文字(字符)信息。

(3)errno是C语言设置的全局错误码存放变量,库函数执行失败时,会自动将错误码存放到该变量中。

四、字符函数

1. 字符分类函数

函数参数符合下列条件则返回真
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任何可打印字符,包括图形字符和空白字符

2. 字符转换函数

函数介绍
int tolower(int c)给入大写字母,返回小写字母;非大写字母则不改变
int toupper(int c)给入小写字母,返回大写字母;非小写字母则不改变

五、内存函数

1. memcpy

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

功能:内存拷贝

(1)从source的位置开始向后拷贝num个字节的数据到destination的内存位置;

(2)该函数遇到'\0'时,并不会停下来;

(3)如果source和destination有任何的重叠,拷贝的结果都是未定义的。

模拟实现:

void* my_memcpy(void* destination, const void* source, size_t num) {
	assert(destination && source);
	char* buff = (char*)destination;
	char* src = (char*)source;
	while (num--) {
		*buff++ = *src++;
	}
	return destination;
}

2. memmove

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

功能:内存拷贝

(1)它与memcpy的区别就是memmove函数处理的源内存块和目标内存块是可重叠的;

(2)所以如果源内存块和目标内存块出现重叠,就使用memmove函数进行处理。

模拟实现:

void* my_memmove(void* destination, const void* source, size_t num) {
	assert(destination && source);
	char* buff = (char*)destination;
	char* src = (char*)source;
	if (buff < src) {
		while (num--) {
			*buff++ = *src++;
		}
	}
	else {
		while (num--) {
			*(buff + num) = *(src + num);
		}
	}
	return destination;
}

3. memcmp

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

功能:比较从ptr1和ptr2指针开始的num个字节

(1)若出现不相等的情况,则提取返回比较结果;

(2)只有完全相等,才会比较完num个字节。

4. memset

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

功能:内存设置

(1)从ptr位置开始设置num个字节,设置内容为value。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/764531.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【每日运维】大文件的分割与合并

产生背景 特殊单位需要将文件刻盘带入&#xff0c;并且刻盘有大小限制&#xff0c;所以有了这个需求 推荐方法 个人电脑上使用 split 命令指定大小分割Linux 服务上使用 cat 命令进行合并使用 md5sum 命令校验包的完整性 方法演示 需要将一个按照100M分割后刻盘导入 在个…

数据结构 ~ 树

什么是树 - tree 一种分层数据的抽象模型&#xff1b; 如&#xff1a;DOM、级联选择、树形控件&#xff0c;js 中没有树 可以用 Object 构建树&#xff1a; const tree {val: a,children: [{val: a-1,children: [{val: a-1-1,children: []}]},{val: a-2,children: [{val: a…

mapbox绘制多边形

1、实现效果 请忽略马赛克 2、实现思路 绘制一个填充的多边形&#xff0c;再描个边框。 3、实现代码 绘制多边形函数 drawPolygon() {map.addSource(maine, {type: geojson,data: https://asc-test1.oss-cn-beijing.aliyuncs.com/2023/07/05/45f6bd80f2f34d79b3e457b31ec5d…

云原生网关如何实现安全防护能力

作者&#xff1a;刘晓瑞(钰诚) 云原生网关&#xff1a;将安全、流量和微服务三合一 作为面向南北向的公网网关&#xff0c;使用 Waf 防护异常流量是很常规的需求&#xff0c;而且随着互联网环境变得越来越复杂&#xff0c;用户对防护的诉求是持续增强的&#xff0c;常规做法是…

需要我怎么帮你?关于维护Nutsdb开源社区的思考

背景 近来有人问我打算怎么继续维护Nutsdb社区&#xff0c;他们当中不乏有开源项目的狂热爱好者&#xff0c;发起了好几个几千star的开源项目&#xff0c;也有对Nutsdb感兴趣的&#xff0c;想来问问后续的计划。这不禁让我回想到从刚开始参与这个项目到最近这段时间一个人维护…

三维重建的工作

文章目录 一、北京&#xff1a;二、广州&#xff1a;三、深圳&#xff1a; 一、北京&#xff1a; 链接 三维重建技术是自动驾驶领域4D真值数据生成的核心基础能力。融合LiDAR、Camera、IMU、轮速计等传感器数据像BlockNeRF一样重建城市级别逼真精细的三维场景&#xff0c;将…

ArcGIS Pro 矢量数据的空间校正

GIS 数据通常来自多个源。当数据源之间出现不一致时,有时需要执行额外的工作以将新数据集与其余数据进行整合。相对于基础数据而言,一些数据会在几何上发生变形或旋转。 在编辑环境中,空间校正提供用于对齐和整合数据的交互式方法。 空间校正可执行的一些任务包括:将数据…

SQLite数据库安装

安装方式一&#xff1a; sudi apt-get install sqlite 安装方式二&#xff1a; https://www.sqlite.org/download.html 1. 把下载的文件 sqlite-autoconf-3420000.tar.gz 上传到开发板 2. tar xvf sqlite-autoconf-3420000.tar.gz 解压 3. cd sqlite-autoconf-3420000 进入…

[Mysql] 索引失效的情况详解~

一条查询语句走了索引和没走索引的查询效率是非常大的&#xff0c;但有很多情况导致我们的索引失去效果。这里总结一下常见的索引失效的情况~ 数据准备 我们准备一张简单的学生来做演示。 CREATE TABLE student (id int NOT NULL COMMENT id,name varchar(255) COLLATE utf8…

基于weka手工实现支持向量机smo算法

关于svm机器学习模型&#xff0c;我主要学习的是周志华老师的西瓜书&#xff08;《机器学习》&#xff09;&#xff1b; 但是西瓜书中对于参数优化&#xff08;即&#xff1a;Sequential Minimal Optimization&#xff0c;smo算法&#xff09;部分讲解的十分简略&#xff0c;看…

Linux运维面试题(三)之shell编程类

Linux运维面试题&#xff08;三&#xff09;之shell编程类 文本截取有一个b.txt文本&#xff0c;要求将所有域名截取出来&#xff0c;并统计重复域名出现的次数统计当前服务器正在连接的IP地址&#xff0c;并按连接次数排序&#xff08;cut不能以空格做分隔符&#xff09; 随机…

Vis相关的期刊会议

中国计算机学会推荐国际学术会议和期刊目录 文档&#xff0c; 下载 link&#xff1a;CCF推荐国际学术刊物目录-中国计算机学会 一.可视化方向文章 1.IEEE VIS&#xff0c;是由 IEEE Visualization and Graphics Technical Committee(VGTC) 主办的数据可视化领域的顶级会议&a…

VMware桥接模式无法识别英特尔AX200无线网卡解决办法

1.先到英特尔网站下载最新驱动&#xff0c;更新网卡驱动适用于 Intel 无线网络卡的 Windows 10 和 Windows 11* Wi-Fi 驱动程序 2.到控制面板查看无线网卡属性是否有下图组件 没有的话&#xff0c;依次操作 安装---服务---添加---从磁盘安装----浏览--进入VMware安装目录&…

Linux系统的目录结构

目录 一、Linux系统使用注意 1、Linux严格区分大小写 2、Linux文件"扩展名" 3、Linux中所有内容以文件形式保存 4、Linux中存储设备都必须在挂载之后才能使用 二、目录结构 1、Linux分区与Windows分区 2、Linux系统文件架构 3、Linux系统的文件目录用途 一、…

Docker【安装与基本使用】

【1】Docker的安装 注意&#xff1a;如果之前安装过docker其他版本&#xff0c;请删除干净。 docker-01 10.0.0.51 2G docker-02 10.0.0.52 2G docker-01 [rootdocker-01 ~]# cp -rp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime cp: overwrite ‘/etc/localtime’? …

(中等)LeetCode146 LRU 缓存 Java

本题有两种实现操作&#xff0c;需要使用到一个哈希表和一个双向链表。在Java语言中&#xff0c;有一种结合了哈希表和双向链表的数据结构&#xff0c;LinkedHashMap import java.util.LinkedHashMap; import java.util.Map;class LRUCache extends LinkedHashMap<Integer,…

网络运维能转型到系统运维吗?

很多网工处于刚起步的初级阶段&#xff0c;各大公司有此专职&#xff0c;但重视或重要程度不高&#xff0c;可替代性强&#xff1b;小公司更多是由其它岗位来兼顾做这一块工作&#xff0c;没有专职&#xff0c;也不可能做得深入。 现在开始学习入门会有一些困难&#xff0c;不…

【深度学习】日常笔记13

前向传播&#xff08;forward propagation或forward pass&#xff09;指的是&#xff1a;按顺序&#xff08;从输⼊层到输出层&#xff09;计算和存储神经⽹络中每层的结果。 绘制计算图有助于我们可视化计算中操作符和变量的依赖关系。下图是与上述简单⽹络相对应的计算图&…

【C语言】深入了解分支和循环语句

&#x1f341; 博客主页:江池俊的博客 &#x1f341;收录专栏&#xff1a;C语言——探索高效编程的基石 &#x1f341; 如果觉得博主的文章还不错的话&#xff0c;请点赞&#x1f44d;收藏&#x1f31f; 三连支持一下博主&#x1f49e; &#x1f4ab;“每一天都是一个全新的机会…

【优选算法题练习】day7

文章目录 一、35. 搜索插入位置1.题目简介2.解题思路3.代码4.运行结果 二、69. x 的平方根1.题目简介2.解题思路3.代码4.运行结果 三、852. 山脉数组的峰顶索引1.题目简介2.解题思路3.代码4.运行结果 总结 一、35. 搜索插入位置 1.题目简介 35. 搜索插入位置 给定一个排序数组…