C语言学习笔记----基础篇

1.数据类型-变量-常量

数据类型

数据类型
│
├── 基本数据类型
│   ├── 整数类型
│   │   ├── int
│   │   ├── unsigned int
│   │   ├── short
│   │   ├── unsigned short
│   │   ├── long
│   │   ├── unsigned long
│   │   ├── long long
│   │   └── unsigned long long
│   ├── 浮点数类型
│   │   ├── float
│   │   ├── double
│   │   └── long double
│   └── 字符类型
│       ├── char
│       ├── unsigned char
│       └── signed char
│
├── 派生数据类型
│   ├── 数组
│   ├── 指针
│   ├── 结构体
│   └── 共用体
│
├── 空类型
│   └── void
│
├── 类型限定符
│   ├── short
│   ├── long
│   ├── signed
│   └── unsigned
│
└── 枚举类型└── enum

常量

常量是指在程序运行过程中,其值不发生变化的量。

常量又分为整型 实型(浮点型)字符串型

变量

为了指定存储区域,应该为每个变量赋予唯一的名称(标识符)

变量命名规则

变量名称只能包含字母(大写和小写字母),数字和下划线。

变量的第一个字母应该是字母或下划线。

对于变量名称(标识符)可以使用多长没有指定。但是,如果变量名超过31个字符,则在某些编译器中可能会遇到问题。

常见的格式说明符

1. 整数类型
%d / %i:输出带符号的十进制整数。
例子:int x = -42; printf("%d", x); 输出:-42
%u:输出无符号的十进制整数。
例子:unsigned int x = 42; printf("%u", x); 输出:42
%o:输出无符号的八进制整数。
例子:unsigned int x = 42; printf("%o", x); 输出:52
%x:输出无符号的十六进制整数(小写字母)。
例子:unsigned int x = 42; printf("%x", x); 输出:2a
%X:输出无符号的十六进制整数(大写字母)。
例子:unsigned int x = 42; printf("%X", x); 输出:2A
2. 浮点类型
%f:输出浮点数(默认保留六位小数)。
例子:float x = 3.14159; printf("%f", x); 输出:3.141590
%e:以科学计数法格式输出浮点数(小写)。
例子:float x = 3.14159; printf("%e", x); 输出:3.141590e+00
%E:以科学计数法格式输出浮点数(大写)。
例子:float x = 3.14159; printf("%E", x); 输出:3.141590E+00
%g:根据值的大小自动选择 %f 或 %e 格式来输出浮点数,且不会打印多余的零。
例子:float x = 0.000123; printf("%g", x); 输出:1.23e-04
%G:类似 %g,但是使用大写字母表示科学计数法。
例子:float x = 1234.5678; printf("%G", x); 输出:1234.57
3. 字符与字符串
%c:输出单个字符。
例子:char x = 'A'; printf("%c", x); 输出:A
%s:输出字符串。
例子:char *str = "Hello, World!"; printf("%s", str); 输出:Hello, World!
%p:输出指针的地址。
例子:int *p = &x; printf("%p", p); 输出:0x7fffd71f9e2c(取决于平台和指针值)
4. 宽度与精度
宽度:你可以在格式说明符中指定最小宽度。例如,%5d 会确保输出的数字至少有 5 个字符宽。如果数字较小,会使用空格填充。
例子:int x = 42; printf("%5d", x); 输出:   42
精度:在浮点数输出中,可以指定小数点后的位数,格式是 .数字。例如,%.2f 会输出保留两位小数的浮点数。
例子:float x = 3.14159; printf("%.2f", x); 输出:3.14
组合宽度与精度:你可以同时指定宽度和精度,例如 %10.3f 会打印出宽度为 10 的浮点数,并且保留 3 位小数。
例子:float x = 3.14159; printf("%10.3f", x); 输出:      3.142
5. 无符号整数大小类型
%zu:输出 size_t 类型的无符号整数(适用于 sizeof)。
例子:size_t x = 100; printf("%zu", x); 输出:100
%ld:输出 long 类型的整数。
例子:long x = 1000000; printf("%ld", x); 输出:1000000
%lld:输出 long long 类型的整数。
例子:long long x = 1000000000000; printf("%lld", x); 输出:1000000000000
6. 其他格式说明符
%n:这个格式说明符并不会输出任何内容,而是将当前打印的字符数存储到传入的 int 变量中。
例子:int count; printf("Hello, World!%n", &count); printf("Number of characters printed: %d", count); 输出:Hello, World! Number of characters printed: 13
%%:输出一个百分号 %。
例子:printf("100%% done\n"); 输出:100% done
格式说明符的一般结构:
格式说明符的基本结构是:

%[flags][width][.precision][length]specifier

flags(标志):用来控制输出的格式,比如左对齐、填充零等。

-:左对齐。
0:用零填充空白(适用于数值类型)。
+:总是输出符号(正数时加 +)。
空格:如果是正数,前面输出一个空格。
width(宽度):指定输出的最小宽度,如果输出的内容小于该宽度,则会用空格填充。

.precision(精度):通常用于浮点数和字符串,控制小数位数或者字符串最大长度。

length(长度):指定数据类型的大小(如 l 表示 long,ll 表示 long long,z 表示 size_t 类型)。

#include <stdio.h>int main() {int a = 123;float f = 3.14159;char c = 'A';char *str = "Hello, World!";size_t size = sizeof(a);// 输出整数printf("Integer: %d\n", a);  // 输出:Integer: 123// 输出浮点数printf("Float: %.2f\n", f);  // 输出:Float: 3.14// 输出字符printf("Char: %c\n", c);  // 输出:Char: A// 输出字符串printf("String: %s\n", str);  // 输出:String: Hello, World!// 输出 size_t 类型的值printf("Size of a: %zu\n", size);  // 输出:Size of a: 4return 0;
}

 

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

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

相关文章

YOLOv9改进 ,YOLOv9改进损失函数采用SlideLoss来处理样本不平衡问题

摘要 作者提出了一种基于 YOLOv5 改进的实时人脸检测模型&#xff0c;称为YOLO-FaceV2。设计了一个感受野增强模块&#xff08;RFE&#xff09;来提升小尺度人脸的感受野&#xff0c;并引入了 NWD 损失&#xff0c;以弥补 IoU 在小目标位置偏差上的敏感性。针对人脸遮挡问题&a…

设计模式——策略模式(c++)

策略模式&#xff08;Strategy Pattern&#xff09;在 C 中的实现 1. 策略模式定义 策略模式定义了一系列算法&#xff08;策略类&#xff09;&#xff0c;将每个算法封装起来&#xff0c;使它们可以相互替换&#xff0c;达到灵活使用不同策略的目的。在策略模式中&#xff0…

strcpy放字符串,strcat接着放字符串

#include <stdio.h> #include <stdlib.h> #include <string.h>#define MAX_ARGS 10 #define USAGE_LEN 256int main(int argc, char *argv[]) {char usage[USAGE_LEN];char *args[MAX_ARGS];int i, arg_count 0;// 构建使用说明字符串strcpy(usage, "U…

uni-app中使用 unicloud 云开发平台③

文章目录 六、hbuilderX 中使用 unicloud 云开发平台文档传统业务开发流程什么是 unicloudunicloud 优点开发流程uncloud 构成云数据库云存储及 CDN创建云函数工程七、unicloud api 操作云函数调用云函数实现云数据库基本增删改查1. 获取数据库引用云存储操作六、hbuilderX 中使…

用 Python 从零开始创建神经网络(五):损失函数(Loss Functions)计算网络误差

用损失函数&#xff08;Loss Functions&#xff09;计算网络误差 引言1. 分类交叉熵损失&#xff08;Categorical Cross-Entropy Loss&#xff09;2. 分类交叉熵损失类&#xff08;The Categorical Cross-Entropy Loss Class&#xff09;展示到目前为止的所有代码3. 准确率计算…

rust并发

文章目录 Rust对多线程的支持std::thread::spawn创建线程线程与 move 闭包 使用消息传递在线程间传送数据std::sync::mpsc::channel()for received in rx接收两个producer 共享状态并发std::sync::Mutex在多个线程间共享Mutex&#xff0c;使用std::sync::Arc 参考 Rust对多线程…

PDF24:多功能 PDF 工具使用指南

PDF24&#xff1a;多功能 PDF 工具使用指南 在日常工作和学习中&#xff0c;PDF 是一种常见且重要的文档格式。无论是查看、编辑、合并&#xff0c;还是转换 PDF 文件&#xff0c;能够快速高效地处理 PDF 文档对于提高工作效率至关重要。PDF24 是一款免费、功能全面的 PDF 工具…

CentOS 安装 Python 3.11.9完整流程

在 CentOS 上安装 Python 3.11.9 并替换系统中的默认 Python 版本&#xff0c;可以按照以下步骤来进行。请注意&#xff0c;替换默认 Python 版本可能会影响系统的其他工具和依赖&#xff0c;因此请谨慎操作。 步骤 1&#xff1a;安装依赖 首先&#xff0c;确保系统安装了编译…

java数据结构与算法:栈

栈 1、栈的基本概念2、Java模拟简单的顺序栈实现3、增强功能版栈4、利用栈实现字符串逆序5、利用栈判断分隔符是否匹配6、总结 1、栈的基本概念 **栈&#xff08;英语&#xff1a;stack&#xff09;**又称为堆栈或堆叠&#xff0c;栈作为一种数据结构&#xff0c;是一种只能在…

【Conda】Windows下conda的安装并在终端运行

下载 在官网下载 https://www.anaconda.com/download/success 安装 双击 一直下一步安装 配置环境变量 为了在终端运行&#xff0c;需配置环境变量 进入到安装conda的目录并复制路径 设置高级环境变量 在终端运行 输入&#xff1a; conda list表明可以正常运行 参考…

游戏引擎学习第七天

视频参考:https://www.bilibili.com/video/BV1QFmhYcE69 ERROR_DEVICE_NOT_CONNECTED 是一个错误代码&#xff0c;通常在调用 XInputGetState 或 XInputSetState 函数时返回&#xff0c;表示指定的设备未连接。通常会出现以下几种情况&#xff1a; 未连接控制器&#xff1a;如…

用 Collections.synchronizedSet 创建线程安全的 HashSet

在 Java 中&#xff0c;HashSet 本身并不是线程安全的。如果在多线程环境下使用 HashSet&#xff0c;你需要采取额外的同步措施来保证线程安全。Collections 工具类提供了一种简便的方法来创建线程安全的集合——synchronizedSet 方法。这种方法通过在所有公共方法上添加同步块…

【网络安全渗透测试零基础入门】之SNMP放大攻击原理及实战演示,零基础入门到精通,收藏这一篇就够了!

前言 这是小强给粉丝盆友们整理的网络安全渗透测试入门阶段dos与ddos渗透与防御教程。 喜欢的朋友们&#xff0c;记得给我点赞支持和收藏一下&#xff0c;关注我&#xff0c;学习黑客技术。 SNMP&#xff08;Simple Network Management Protocol &#xff09;&#xff1a;简单…

el-dialog 设置 水平垂直居中 高度不固定

小记一下&#xff1a; 希望实现不管内容高度多少 el-dialog都能水平垂直居中 效果&#xff1a; css: .form-view-dialog{display: flex;align-items: center;justify-content: center;.el-dialog{margin: 0 auto; }.el-dialog__body{max-height: 75vh; // 可选择 设置一个最…

后端接口返回二进制文件,前端 window.opent预览展示

详细步骤 1.修改 PreviewApi 函数&#xff1a; 设置 responseType 为 ‘arraybuffer’&#xff0c;以接收二进制数据。 export const PreviewApi (data) > request({method: post,url: /dev-api/preview,responseType: arraybuffer,data });3.处理响应&#xff1a; 使用…

EMC Plus:外壳中的 PCB 演示

EMC Plus 提供了计算任何导入的近场源文件的字段统计信息的高级功能。在本演示中&#xff0c;我将指导您完成分析辐射电场的分步工作流程&#xff0c;特别是由 EMC Plus 中从 SIwave 导入的近场源产生的辐射电场。让我们开始吧&#xff01; 概述 以下模型是计算机机箱&#x…

【免越狱】iOS砸壳 可下载AppStore任意版本 旧版本IPA下载

软件介绍 下载iOS旧版应用&#xff0c;简化繁琐的抓包流程。 一键生成去更新IPA&#xff08;手机安装后&#xff0c;去除App Store的更新检测&#xff09;。 软件界面 支持系统 Windows 10/Windows 8/Windows 7&#xff08;由于使用了Fiddler库&#xff0c;因此需要.Net环境…

SQLite Where 子句

SQLite Where 子句 SQLite 是一种轻量级的数据库管理系统&#xff0c;广泛应用于移动设备和嵌入式系统。它支持标准的 SQL 语法&#xff0c;包括 SELECT, INSERT, UPDATE, DELETE 等命令。在执行这些命令时&#xff0c;WHERE 子句用于指定过滤条件&#xff0c;从而精确地控制操…

SpringBoot沙箱环境支付宝支付

1、创建应用 登录支付宝开放平台 支付宝开放平台网址 &#xff1a;支付宝 (alipay.com) 支付宝开放平台 下拉最下边 2、获取appId、支付宝公钥、应用私钥 3、开始创建spring boot项目 #支付宝支付配置 alipay:#你的APPIDappId: 902************#你的应用私钥privateKey: MIIE…

Ceph 中Crush 算法的理解

Crush&#xff08;Controlled Replication Under Scalable Hashing&#xff09;算法是一种可扩展的、分布式的副本数据放置算法&#xff0c;广泛用于存储系统中&#xff0c;特别是Ceph分布式存储系统中。以下是对CRUSH算法的详细解释&#xff1a; 一、算法原理 CRUSH算法根据…