c语言学习笔记

逗号表达式

#include <stdio.h>
 
int main(){
    int a = 10;
    int b =5;
    int c = 6;
    int d = (a = 2+3,b = a-4,c= b+2);
    printf("%d",d);
}

打印结果为:
在这里插入图片描述
逗号表达式,从左往右依次进行,将最后一个表达式的值赋值给变量.

c语言字符串相关库函数

求字符串长度strlen
长度不受限制的字符串函数strcpy , strcat , strcmp
长度受限制的字符串函数strncpy , strncat , strncmp
字符串查找strstr , strtok
错误信息报告strerror
内存操作函数memcpy , memmove , memset , memcmp

下面分别进行详细介绍

strlen <----求字符串长度

所需头文件

#include <string.h>

参数类型

size_t strlen(const char* string);

参数类型为char*,因此我们传进来的参数需要是字符串的地址,并且这里的指针变量用const修饰,可以保证传进来的字符串不被修改. 因为我们求字符串的长度是不需要对字符串进行修改的,加上const保证程序的安全. size_t是函数的返回值类型,他是一个无符号整型. 关于这个无符号整形,会导致一些问题,可以用一个例子说明.

#include <stdio.h>
#include <string.h>
int main()
{
	char* str1 = "abc";
	char* str2 = "abcedf";
	if (strlen(str1) - strlen(str2) > 0)
	{
		printf("str1 is bigger\n");
	}
	else
	{
		printf("str2 is bigger\n");
	}
	return 0;
}

我们可以看出,str1比str2短,因此结果应该为负数,小于0,打印str2 is bigger. 但是运行程序,发现结果如下:
在这里插入图片描述
这和我们所认为的不同,就是因为strlen函数返回的是一个无符号整型,因此当两个无符号整型进行减法的时候,得到的结果仍然是无符号整型,因此虽然得到的结果为负数,但是在无符号整型看来,这是一个很大的正数,前面的符号位被认为是一个有效的数字位,导致结果大于0.打印的是str1 is bigger. 如果想要进行比较长度大小,可以直接strlen(str1) > strlen(str2)这样子比较就没有问题了.

注意事项

  1. strlen函数返回的是在字符串中 \0 前面出现的字符个数(不包含 ‘\0’ ),因此当字符串中存在\0的时候,得到的不是字符串的长度
  2. 参数指向的字符串必须要以 ‘\0’ 结束,否则strlen会运行到读取到\0才结束
  3. 注意函数的返回值为size_t,是无符号的,在计算的时候要注意

strcpy<----字符串拷贝

所需头文件

#include <string.h>

参数类型

char *strcpy(char *strDestination,const char* strSource);

参数类型是两个字符串指针地址,第一个是需要被拷贝的字符串地址,第二个参数是要拷贝的内容. 其中要拷贝的内容由于不需要改变,用const修饰,保证程序的安全. 函数的返回值类型为char*类型,是拷贝完成后的字符串地址.

注意事项

  1. strSource必须以\0结束,否则strcpy函数不知道什么时候拷贝结束
  2. 拷贝会将\0也拷贝到strDestination中
  3. strDestination必须足够大,确保放的下strSource,防止越界访问
  4. strDestination不能被const修饰,必须是可变的.

strcat<—字符串追加

所需头文件

#include <string.h>

参数类型

char *strcat(char *strDestination,const char* strSource);

参数类型和strcpy是一致的,就不再赘述了. 返回值类型也是char*类型.用来返回被追加后的字符串地址.

具体功能是将两个字符串拼接起来.

#include <stdio.h>
#include <string.h>
int main()
{
	char str1[20] = "abcd";
	char str2[] = "efgh";
	char* ret = strcat(str1, str2);
	printf("%s", ret);
	return 0;
}

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

strcat的注意事项和strcpy类似,唯一的区别在于strDestination的空间要足够大,能够放得下strSource+原strDestination才行.而strcpy只需要能够放得下strSource就行.

strcmp<—字符串比较

所需头文件

#include <string.h>

参数类型

int strcmp(const char *string1,const char* string2);

参数为两个字符串指针,都被const修饰,不需要对字符串进行修改,只是进行比较,保证程序的安全性. 返回值类型为int类型.
strcmp函数对返回值的规定如下:

  • 标准规定
    • 第一个字符串大于第二个字符串,返回大于0的数字
    • 第一个字符串等于第二个字符串,返回0
    • 第一个字符串小于第二个字符串,返回小于0的数字

strcmp函数的功能就是比较两个字符串的大小,比较的是字符串的内容而不是字符串的长度.
比方说abcde就小于accd因为从第二个字符开始,b的ASCII码小于c的ASCII码. 但字符串的长度确实abcde大于accd

strncpy<—受限制的字符串拷贝

所需头文件

#include <string.h>

参数类型

char *strncpy( char *strDestination,const char *strSource,size_t count);

前两个参数类型和strcpy是一致的,只是多了个size_t类型的参数count用来控制拷贝字符的个数. 这里的count为多少,就从strSource中拷贝多少个字符到strDestination中. 返回值类型也和strcpy一样,返回的是被拷贝的字符串的地址

strncpy的功能如下:

#include <stdio.h>
#include <string.h>
int main()
{
	char str1[20] = "abcd";
	char str2[] = "kpl";
	char* ret = strncpy(str1, str2, 2);
	printf("%s", ret);
	return 0;
}

运行结果如下:
在这里插入图片描述
作用就是经str2的前面两个字符串拷贝到str1的前面两位.因此结果为kpcd
注意事项和strcpy是一致的.

strncat<—长度受限制的字符串追加

所需头文件

#include <string.h>

参数类型

char *strncat(char *strDestination,const char* strSource, size_t count);

和strncpy类似,也是多了个size_t类型的count用来控制追加字符串的长度.返回的也是被追加字符串的地址.

#include <stdio.h>
#include <string.h>
int main()
{
	char str1[20] = "abcd";
	char str2[] = "efgh";
	char* ret = strncat(str1, str2, 2);
	printf("%s", ret);
	return 0;
}

运行结果为:
在这里插入图片描述
将str2中的前面两个字符追加到str1中,因此结果为abcdef
注意事项和strncat一致.

strncmp<----长度受限制的字符串拷贝

所需头文件

#include <string.h>

参数类型

int strncmp(const char *string1,const char* string2, size_t count);

类似的,多了个size-t类型的count,用来控制比较字符串的长度. 返回的值和strcmp一样.

#include <stdio.h>
#include <string.h>
int main()
{
	char str1[] = "abcd";
	char str2[] = "abkl";
	int ret = strncmp(str1, str2, 2);
	printf("%d", ret);
	return 0;
}

运行结果为:
在这里插入图片描述
由于str1和str2前面两个字符都为ab,因此比较的结果是两者相等,因此结果为0
如果使用strcmp比较,结果为小于0的数字.

strstr<----字符串查找函数

所需头文件

#include <string.h>

参数类型

char *strstr(const char *string,const char* strCharSet);

参数是两个指针,分别接收的是被查找的字符串地址和查找内容的字符串地址,两个指针都被const修饰. 返回值类型为char*,所以接收的是字符string被strcharset查找到后,对应查找到的字符串的首地址.

#include <stdio.h>
#include <string.h>
int main()
{
	char str1[] = "abcdefdgh";
	char str2[] = "d";
	char* ret = strstr(str1, str2);
	printf("%s", ret);
	return 0;
}

运行结果为:
在这里插入图片描述

小结

c语言还在学习中,会实时保持更新

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

web wifi配网和模式切换-esp8266和esp32

web wifi配网和模式切换-esp8266和esp32 支持模式:1:tcp client() 2:tcp server 3:http server(POST/GET) 4:http client 5:udp,6:factory,7:mqtt 配网进入方式&#xff1a; 开机&#xff0c;指示灯亮起后(需要灯闪烁3下后)&#xff0c;需在3s内&#xff08;超过3s则会正常启动…

WebGL技术开发框架

WebGL技术框架是一些提供了便捷API和工具的库&#xff0c;用于简化和加速在Web浏览器中使用WebGL进行3D图形开发。以下是一些常用的WebGL技术框架&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#xff0c;欢迎交流合作。 1.Th…

vue+ElementPlus实现中国省市区三级级联动封装

安装插件获取中国省份的所有数据 npm install element-china-area-data -S 借助ElementPlus 级联选择器 Cascader实现 <template><div><el-cascadersize"large":options"options"v-model"selectedOptions"change"handleCh…

32OLED中断系统&对射式红外计数&旋转编码计数

一.程序调试方式 二.OLED简介 stm32引脚上电后&#xff0c;如果不初始化&#xff0c;默认是浮空输入的模式&#xff0c;在这个模式下引脚不会输出电平 三. 中断系统 EXTI外部中断&#xff0c;TIM定时器&#xff0c;ADC模数转换器&#xff0c;USART串口&#xff0c;SPI通信&…

【SpringBoot3】集成Knife4j、springdoc-openapi作为接口文档

一、什么是springdoc-openapi Springdoc-openapi 是一个用于生成 OpenAPI&#xff08;之前称为 Swagger&#xff09;文档的库&#xff0c;专为 Spring Boot 应用程序设计。它可以根据你的 Spring MVC 控制器、REST 控制器和其他 Spring Bean 自动生成 OpenAPI 文档&#xff0c…

Google Chrome 中出现 ERR_SSL_KEY_USAGE_INCOMPATIBLE 错误

证书的方式发生了变化&#xff0c;出现了这个新错误&#xff0c;导致我无法浏览该网站。 可以右键属性获取位置 关闭导航器chrome并转到文件夹&#xff0c;找到Local State文件并删除 执行指令结束进程&#xff0c;重新打开浏览器即可 taskkill /im "chrome.exe"…

Unity3d实现简单的战斗

使用u3d实现一个简单的战斗demo&#xff0c;记下学到的知识点&#xff0c;以备后查。 1.判断是否点中指定物体 if (Input.GetMouseButton(0)) {Ray ray Camera.main.ScreenPointToRay(Input.mousePosition);if (Physics.Raycast(ray, out RaycastHit hit)){//坐标转换Vector…

PeakCAN连接到WSL2 Debian

操作步骤 按照以下步骤进行操作&#xff1a; 在Windows下安装PeakCAN驱动并安装&#xff0c;地址是https://www.peak-system.com/PCAN-USB.199.0.html?&L1 在Windows下安装usbipd&#xff0c;地址是https://github.com/dorssel/usbipd-win/releases&#xff0c;最新版是…

我们是如何测试人工智能的(六)推荐系统拆解

推荐系统简介 推荐系统的问题 根据之前学习到的内容&#xff0c;我们已经基本了解到了要如何构建一个二分类模型。我们都知道模型大体可以分成&#xff0c;回归&#xff0c;二分类和多分类。但推荐系统是属于哪一种场景呢&#xff0c;比如我们常见的广告推荐或者内容推荐&…

线性代数---------学习总结

线性代数之行列式 行列式的几条重要的性质 1.某两行某两列交换位置之后&#xff0c;值变号 2.行列式转置&#xff0c;值不变 3.范德蒙德行列式&#xff0c;用不同行的公比做一系列的累乘运算 4.把某一行的行列式加到另一行上&#xff0c;利用他们之间的倍数关系&#xff0…

最小二乘圆柱拟合(高斯牛顿法)

欢迎关注更多精彩 关注我&#xff0c;学习常用算法与数据结构&#xff0c;一题多解&#xff0c;降维打击。 本期话题&#xff1a;最小二乘圆柱拟合 相关背景资料 点击前往 圆柱拟合输入和输出要求 输入 8到50个点&#xff0c;全部采样自圆柱上。每个点3个坐标&#xff0c;坐…

云计算底层技术奥秘、磁盘技术揭秘、虚拟化管理、公有云概述

云计算基础 实验图例 虚拟化平台安装 创建虚拟机 1、创建虚拟机 2cpu&#xff0c;4G内存&#xff08;默认用户名: root 密码: a&#xff09; 2、验证 ecs 是否支持虚拟化 [rootecs ~]# grep -Po "vmx|svm" /proc/cpuinfovmx... ...[rootecs ~]# lsmod |grep kvm…

Android 13以上版本读写SD卡权限适配

如题&#xff0c;最近工作上处理的问题&#xff0c;把解决方案简单逻列出来&#xff0c;供有需要的朋友参考之 解决方案&#xff1a; 1、配置权限 <uses-permission android:name"android.permission.READ_MEDIA_IMAGES" /><uses-permission android:name&q…

Security ❀ HTTP/HTTPS逐包解析交互过程细节

文章目录 1. TCP三次握手机制2. HTTP Request 请求报文3. HTTP Response 响应报文4. SSL/TLS协议4.1. ClientHello 客户端Hello报文4.2 ServerHello 服务器Hello报文4.3. *ServerKeyExchange 服务公钥交换4.4. ClientKeyExchange 客户端公钥交换4.5. *CertificateVerify 证书验…

Mysql 更新数据

MySQL中使用UPDATE语句更新表中的记录&#xff0c;可以更新特定的行或者同时更新所有的行。基本语法结构如下&#xff1a; UPDATE table_name SET column_name1 value1,column_name2 value2,……, column_namen valuen WHERE(condition); column_name1,column_name2,……,…

Oracle数据库如何对中文的一二三四五六七八九十数进行正序排列排序

引言 在处理包含中文数字的数据库查询时&#xff0c;我们可能会遇到一个看似简单实则充满挑战的问题——如何让Oracle数据库按照阿拉伯数字顺序&#xff08;1, 2, 3, 4, 5, 6…&#xff09;对诸如“一、二、三、四、五、六…”这样的中文数字进行排序。这不仅是一个技术性问题&…

长度最小的子数组[中等]

一、题目 给定一个含有n个正整数的数组和一个正整数target。找出该数组中满足其总和大于等于target的长度最小的连续子数组[numsl, numsl1, ..., numsr-1, numsr]&#xff0c;并返回其长度。如果不存在符合条件的子数组&#xff0c;返回0。 示例 1&#xff1a; 输入&#xff…

数据结构奇妙旅程之七大排序

꒰˃͈꒵˂͈꒱ write in front ꒰˃͈꒵˂͈꒱ ʕ̯•͡˔•̯᷅ʔ大家好&#xff0c;我是xiaoxie.希望你看完之后,有不足之处请多多谅解&#xff0c;让我们一起共同进步૮₍❀ᴗ͈ . ᴗ͈ აxiaoxieʕ̯•͡˔•̯᷅ʔ—CSDN博客 本文由xiaoxieʕ̯•͡˔•̯᷅ʔ 原创 CSDN …

如何做好阅读笔记搭建个人知识体系?

一、阅读笔记的重要性 阅读笔记在个人知识管理中扮演着重要的角色。通过记录、整理和利用阅读笔记&#xff0c;可以帮助我们更好地梳理个人知识体系&#xff0c;提高阅读效率&#xff0c;并且能够为个人成长提供有力支持。阅读笔记的重要性不言而喻&#xff0c;它是我们通过阅…

芯片替代查询指南:如何在电子设计中选择最佳替代方案

在电子制造与维修的世界里&#xff0c;芯片的选择和替代是一个常见且复杂的过程。选择正确的芯片替代对于确保电路的正常工作以及产品的性能不可或缺。本篇文章将为您提供关于芯片替代查询网站的全面指南。 什么是芯片替代查询&#xff1f; 芯片替代查询是提供芯片替代选项查…