C语言 - 基础

C 语言

1. Hello World

#include <stdio.h>int main(int argc, const char *argv[])
{printf("hello world\n");return 0;
}

注意:

  1. 所有的标点符号必须在英文状态下输入
  2. 单词不要写错
  3. 注意空格

创建 C语言 程序步骤:

1、创建一个文档,以 .c 作为后缀名
2、在该文档中编写以下代码

3、使用gcc编译器编译该程序
4、执行编译生成的可执行文件

编译顺序:

编译时代码从文件头开始检查
运行时程序在运行时会寻找main函数在main函数中从上向下依次执行

2. 注释

作用:解释说明

特点:不会影响代码的运行

语法:

单行注释//注释的内容
块注释/*注释的内容多行*/注意:不能嵌套

3. 输出

作用:给控制台输出内容

语法:

printf("输出的内容", 位置1, 位置2,..);

占位符:

%d, 	十进制有符号整数 
%u, 	十进制无符号整数
%x, 	以十六进制表示的整数 
%o, 	以八进制表示的整数
%f, 	float 型浮点数
%.2f, 	小数点后保留2位
%lf, 	double 型浮点数
%e, 	指数形式的浮点数
%s, 	字符串
%c, 	单个字符
%p, 	指针的值

例:

要求:输出xxx今年xx岁,身高xxm

#include <stdio.h>int main(){printf("%s今年%d岁,身高%fm","张三",18,1.76);return 0;
}

4. 标识符

概念:标记的符号,名称

变量名,函数名,数组名,枚举名,结构体名,...

命名规则(强制要求) :

不能使用数字开头
不能使用特殊符号,_与$除外
不能使用关键字
不能使用中文

命名风格(建议) :

驼峰命名法大驼峰写法:每个单词首字母大写一般用于:枚举名,结构体名小驼峰写法:第一个单词首字母小写,其他单词首字母大写一般用于:变量名,数字名,函数名等全大写写法:全大写一般用于:常量名全小写写法:全小写一般用于:文件夹名Liunx风格命名法多个单词之间使用下划线连接比如: hello_world

5. 关键字

5.1 数据类型相关

short 			短整形
int 			整形
long 			长整形
float 			单精度浮点数
double 			双精度浮点数
char 			字符struct 			结构体
union 			共用体
enum 			枚举
signed 			有符号
unsigned 		无符号
void 			空的返回值类型

5.2 存储相关

register 		寄存器存储
static 			静态的
const 			不可修改的
auto 			自动
extern 			声明

5.3 控制语句相关

if
else
break
continue
for
while
do
switch
case
goto
default

5.4 其他关键字

sizeof 		测量数据或数据类型的大小,单位是字节
typedef 	给已知数类型起别名
volatile 	用 volatile 定义的变量,是易改变的,即告诉 cpu 每次用volatile 变量的时候,重新去内存中取保证用的是最新的值,而不是寄存器中的备份。

6. 数据类型

char 		字符 			1字节 			8位注意:字符需要单引号包裹,一对单引号只能包裹一个字符'a''中''ab' 错特殊的字符转意字符\" 双引号\' 单引号\\ \\n 换行\t 制表\r 回到行首符号\a 发出警报\0 字符串结束符
short 			短正型 			2字节 						16位			-2^15~2^15-1
int 			整形 				 4字节 			 			 32位		-2^31~2^31-1
long 			长整形 			4字节(32位)或8字节(64位) 		 32位或64位
float 			单精度浮点型 		  4字节
double 			双精度浮点型 		  8字节       	(小数默认是double)
signed 			有符号
unsigned 		无符号
null 			空

注意:

  • 当值后加 l 表示为long型的数据,其他情况下整数默认为int
  • 当值后加 f 表为float型的数据,小数默认为double
signed char 			char
sigend int 				int
sigend short 			int short
unsigned inttypedef int myint;
volatile
register 建议寄存器存储

7. 变量

7.1 作用

临时记录一个值,可以被改变的数据

例:

需求:

使用变量分别记录人的姓名,性别,年龄,并在控制台打印,打印格式如
xxx 性别为xx,年龄为xx岁
记录的人有
t m 29
b w 27

#include <stdio.h>int main()
{char name = 't';char sex = 'm';int age = 29;printf("%c 性别为 %c,年龄为%d岁!\n", name, sex, age);name = 'b';sex = 'w';age = 27;printf("%c 性别为 %c,年龄为%d岁!\n", name, sex, age);return 0;
}

7.2 使用

  • 声明(在某些特殊情况下才需进行)

  • 定义(重点)

    语法:数据类型 变量名;数据类型 变量名 = 值;
    名词:变量的第一次赋值称为变量的初始化
    

    注意:

    • 函数中定义的变量为局部变量,局部变量默认使用auto修改,此时默认值为一个随机数
    • 函数外定义的变量为成员变量,默认值为0

    例:

    #include <stdio.h>
    //函数外
    int main()
    {//函数中
    } 
    //函数外
    
  • 使用

    语法:取值变量名改值变量名 = 值;
    
  • 练习:

    #include <stdio.h>int main()
    {int age = 18;char sex = 'm';printf("%s今年%d岁,性别为%c\n","张三",age,sex);age = 19;sex = 'w';printf("%s今年%d岁,性别为%c\n","张三",age,sex);return 0;
    }
    

    注意:

    1、局部变量可以与成员变量重名
    2、当局部变量与成员变量重名时,优先使用局部变量
    3、同一作用域下变量名不能相同

7.3 变量的声明

#include <stdio.h>
/*
此处就是变量的声明
变量声明只是告知编译器有该变量,此时并不会为其开辟内存空间
*/
extern int num;int main(){printf("num=%d\n",num);return 0;} 
/* 
变量的定义,编译器编译时会为其开辟内存空间
*/
int num = 10;

相关关键字:

#include <stdio.h>int main()
{//for(int i = 0; i < 1000; i++){//当变量为局部变量时//变量默认就是有符号的//signed int == int//当变量为局部变量时等价//sigened auto int == int//auto int == intunsigned int num = 10;//建议将n02存储在寄存器中register int n02 = 1;//volatile强制要求从内存中取值volatile int n03 = 2;//typedef 给已经知道的数据类型起别名typedef int myInt;myInt n04 = 10;printf("num=%d\n",n04);//}return 0;
}

7.4 类型转换

7.4.1 自动转换

小类型转换为大类型,无需特殊处理

//'a' 的数据类型为 char 占1字节
//int 占4字节
int num = 'a';
printf("num=%d\n",num);

注意:每一个字符都有对应的数字

ASCII码对照表:

  • a~z:97-122
  • A~Z:64-90
7.4.2 强制转换

大类型转换为小类型,需强转,有风险

语法:

小类型变量名 = (小类型)大类型数值或变量

例:

int num = 'a';
char c = (char)num;
printf("c=%c\n",c);

在这里插入图片描述

8. 进制

8.1 计算机的进制

二进制0b二进制数取值:0 1
八进程0八进制数取值:0~7
十六进制0x十六进制数取值:0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f

**注意:计算机在存储 8进制16进制 数时按无符号数存储 **

8.2 进制转换

8.2.1 十进制转其他
  • 十进制转换为二进制

    口诀:十进制数除2,取余,直到商为0,余数倒读

如:
int num = 12;122-------6 			02 -------3 			02 -------1 			12 -------0 			112对应的2进制为:0000 0000 0000 0000 0000 0000 0000 1100
  • 十进制转换为八进制

    口诀:十进制数除8,取余,直到商为0,余数倒读

  • 十进制转换为十六进制

    口诀:十进制数除16,取余,直到商为0,余数倒读

8.2.2 其他转十进制
  • 二进制转换为十进制
如:int num = 0b1110101110101 * 2^5 + 1 * 2^4 + 1 * 2^3 + 0 * 2^2 + 1*2^1 + 0*2^032 + 16 + 8 + 0 + 2 + 058  
  • 八进制转换为十进制
如:int num = 0123;1 * 8^2 + 2*8^1 + 3*8^064 + 16 + 383
  • 十六进制转换为十进制
如:int num = 0x123;1 * 16^2 + 2*16^1 + 3*16^0256 + 32 + 3291  

9. 原码、反码、补码

9.1 原码

数值对应的二进制数,最高位为符号位,整数为0,负数为1

int num = 1;
0000 0000 0000 0000 0000 0000 0000 0001int n01 = -1;
1000 0000 0000 0000 0000 0000 0000 0001

9.2 反码

正数三码合一,与原码相同

负数的反码等于原码符号位不动其他位取反

int num = 1;
原码: 0000 0000 0000 0000 0000 0000 0000 0001
反码: 0000 0000 0000 0000 0000 0000 0000 0001int n01 = -1;
原码: 1000 0000 0000 0000 0000 0000 0000 0001
反码: 1111 1111 1111 1111 1111 1111 1111 1110

9.3 补码

正数三码合一,与原码相同

负数的补码等于反码+1

int num = 1;
原码: 0000 0000 0000 0000 0000 0000 0000 0001
反码: 0000 0000 0000 0000 0000 0000 0000 0001
补码: 0000 0000 0000 0000 0000 0000 0000 0001int n01 = -1;
原码: 1000 0000 0000 0000 0000 0000 0000 0001
反码: 1111 1111 1111 1111 1111 1111 1111 1110
补码: 1111 1111 1111 1111 1111 1111 1111 1111

注意:**计算机底层以补码形式存储数据 **

补码的意义:

1、统一了正0与负0的编码
0

原码:0000 0000 0000 0000 0000 0000 0000 0000
反码:0000 0000 0000 0000 0000 0000 0000 0000
补码:0000 0000 0000 0000 0000 0000 0000 0000

-0
原码:1000 0000 0000 0000 0000 0000 0000 0000
反码:1111 1111 1111 1111 1111 1111 1111 1111
补码:0000 0000 0000 0000 0000 0000 0000 0000

2、此时减法就是+负数

9.4 扩展:

1111 1111 被当做纯二进制看待时,是255,被当做补码看时是 -1
#include <stdio.h>
int main(int argc, char const *argv[])
{char c = 255; //1111 1111int i = 255; //0000 0000 0000 0000 0000 0000 1111 1111printf("c=%d, i=%d\n", c, i);return 0;
}
//输出:c=-1, i=255

整数越界:

整数的存储是一个圈,越过了最大范围的值,会到最小范围那头。

整数是以纯二进制的方式进行计算的,所以:1111 1111 + 1 ——> (1)0000 0000 ——> 00111 1111 + 1 ——> 1000 0000 ——> -1281000 0000 - 1 ——> 0111 1111 ——> 127

在这里插入图片描述

#include <stdio.h>
int main(int argc, char const *argv[])
{char c = 127; //1111 1111int i = 255; //0000 0000 0000 0000 0000 0000 1111 1111c = c + 1;printf("c=%d, i=%d\n", c, i);return 0;
}
//输出:c=-128, i=255

10. 数据的存取

**计算机存储的是补码,计算机取值是先将补码转换为源码,在将源码转换为10进制数 **

例1:

int num = 0xf1 11 11 11;计算机存储的num是:1111 0001 0001 0001 0001 0001 0001 0001计算机取出的num是:补码:1111 0001 0001 0001 0001 0001 0001 0001反码:1111 0001 0001 0001 0001 0001 0001 0000原码:1000 1110 1110 1110 1110 1110 1110 1111

例2:

char c = 0xf0;补码: 1111 0000
反码: 1110 1111
原码: 1001 0000- 1 * 2^4
- 16

11. 运算符

11.1 算数运算符

+, -, *, /, %++

注意:

++
++在前:
先自增,再参与运算
++在后:
先参与运算,再自增

例:

int a = 10;int b = ++a + 1;   // 12int b = a++ + 1;   // 11

​ --在前:
​ 先递减,再参与运算
​ --在后:
​ 先参与运算,再递减

11.2 赋值运算符

将等号右边的值赋值给左边的变量

=如:int a = 10;int b = a;int c = a + b;

11.3 复合运算符

+=int a = 1;int b = 2;//a = a + b;a += b;-=int a = 1;int b = 2;//a = a - b;a -= b;*=int a = 1;int b = 2;//a = a * b;a *= b;/=
%=

11.4 关系运算符

<1 < 10int a = 1;int b = 10;a < b;
> 
<=
>=
==
!

11.5 逻辑运算符

|| 		短路或有真为真,同假为假int a = 1;int b = 2;int c = 3;a < b || c < b;
&& 		短路与有假为假,同真的真int a = 1;int b = 2;int c = 3;a < b && c > b;! 		非非真为假,非假为真! a < b! a > b

11.6 位运算符

& 			按位与同1为1,有0为0如:int a = 8;int b = 9;int c = a & b;10001001------1000| 			按位或有1为1,同0为0如:int a = 8;int b = 9;int c = a | b;10001001------1001	~ 			取反1为0,0为1^ 			按位异或不同得1,相同得0>> 			右移int num = 4;int a = num >> 2;100001<< 			左移int num = 4;int a = num << 2;10010000

11.7 三目运算符

语法:
条件表达式1 ? 值1 : 值2;

逻辑:
如果条件表达式1为真,取值1,反之取值2

例:

//获取a,b之间的最大值
int a = 10;
int b = 1;
int max = a > b ? a : b;//获取a,b,c之间的最大值
int a = 10;
int b = 1;
int c = 3;
int max = (a > b ? a : b) > c ? (a > b ? a : b) : c;

11.8 其他

运算符优先级:

在这里插入图片描述

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

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

相关文章

成都数字孪生技术推进制造业升级,工业物联网可视化应用加速

成都数字孪生技术推进制造业升级&#xff0c;工业物联网可视化应用加速。灯塔工厂转型的关键在于第四次工业革命新技术的应用。数字孪生灯塔工厂是工业4.0技术的应用典范&#xff0c;工业4.0的核心技术包括&#xff1a;数字孪生、大数据分析&#xff0c;工业物联网&#xff0c;…

html实现360度产品预览(附源码)

文章目录 1.设计来源1.1 拖动汽车产品旋转1.2 汽车产品自动控制 2.效果和源码2.1 动态效果2.2 源代码 源码下载 作者&#xff1a;xcLeigh 文章地址&#xff1a;https://blog.csdn.net/weixin_43151418/article/details/134613931 html实现360度产品预览&#xff08;附源码&…

软件测试:超详细的Jmeter基础教程

JMeter 介绍&#xff1a; 一个非常优秀的开源的性能测试工具。 优点&#xff1a;你用着用着就会发现它的重多优点&#xff0c;当然不足点也会呈现出来。 从性能工具的原理划分 Jmeter工具和其他性能工具在原理上完全一致&#xff0c;工具包含4个部分&#xff1a; &#xff…

通过互联网代理部署Docker+Kubernetes 1.28.1

一、背景 在公司环境中&#xff0c;我们往往都是无法直接连接外网的&#xff0c;之前写过一篇文章&#xff0c;是通过外网自建的中转机器下载需要的离线包&#xff0c;并在内网搭建一个harbor&#xff0c;通过harbor的方式搭建了一个kubernetes&#xff0c;但是这种方式还是有…

Vue与UserEcharts、DataV的协同

文章目录 引言一、Vue.js简介二、ECharts和UserEcharts1.ECharts简介2.UserEcharts&#xff1a;Vue和ECharts的结合 三、DataV简介四、Vue与DataV的结合1.DataV的Vue插件2.Vue和DataV的数据交互 结论我是将军&#xff0c;我一直都在&#xff0c;。&#xff01; 引言 接着上一篇…

破案现场:Docker容器资源限制导致的oom问题

破案现场&#xff1a;Docker容器资源限制导致的oom问题 01 事故现场02 问题定位03 对症下药04 后记 原文来自于微信公众号“运维之美” https://mp.weixin.qq.com/s?__bizMzA5NDY1MTM3MA&mid2247484902&idx1&sn8394aefd884ee09ea546fcd400dd233c&chksm904a136…

Motion Plan之基于采样的路径规划算法笔记

Motion Plan之搜索算法笔记 背景&#xff1a; 基于采样算法是一种在路径规划中广泛应用的有效方法。它通过在图中随机选择点来生成一个简化的搜索图&#xff0c;从而加速搜索过程。这种方法的主要优点包括减少内存使用&#xff0c;避免计算错误&#xff0c;具有动态障碍物对抗…

【小技巧】复制一个模块到你的工程(学习阶段很实用)

问题描述&#xff1a; 当我们学习Springboot时&#xff0c;需要创建大量的模块&#xff0c;而这些模块的许多代码都是重复的&#xff0c;只有模块名等相关的信息不一样&#xff0c;现在就教你如何快速创建一个模块。 应用场景&#xff1a; ①进入项目文件夹&#xff1a; ②复…

C语言中的sqrt函数

目录&#xff1a; 前言&#xff1a; 声明&#xff1a; 搭建环境&#xff1a; 专栏&#xff1a; sqrt函数的参数与返回值&#xff1a; 简单的实践&#xff1a; 问题&#xff1a; 讨论&#xff1a; 改进&#xff1a; 前言&#xff1a; 在日常生活中&#xff0c;我们往往…

LLM之Agent(一):使用GPT-4开启AutoGPT Agent自动化任务完整指南

在ChatGPT引领的大模型时代&#xff0c;要想让大模型按照用户的指令执行&#xff0c;Prompt设计是一门艺术&#xff0c;由此还催生了一个职业”Prompt工程师“。其实&#xff0c;并不是所有人都可以设计出好的Prompt&#xff0c;甚至同样的Prompt应用在不同的大模型上表现的结果…

MySQL表的操作『增删改查』

✨个人主页&#xff1a; 北 海 &#x1f389;所属专栏&#xff1a; MySQL 学习 &#x1f383;操作环境&#xff1a; CentOS 7.6 阿里云远程服务器 &#x1f381;软件版本&#xff1a; MySQL 5.7.44 文章目录 1.创建表1.1.创建时指定属性 2.查看表2.1.查看表结构2.2.查看建表信息…

如何搭建zerotier服务器组网实现内网穿透

小白花了四天的下班时间终于把zerotier网络调通&#xff0c;此刻坐在桌前舒畅地喝口茶&#xff5e;&#xff5e; 下面来详细记录下这几天踩的坑&#xff1a; 起因就在于一直在iPad上用向日葵连接公司电脑的我觉得向日葵的界面用的实在难受&#xff0c;vs code操作十分不灵光&…