C语言 - 基础

news2024/11/18 8:38:09

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 int

typedef 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 == int
        unsigned 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;

    12
    2
    -------
    6 			0
    2 
    -------
    3 			0
    2 
    -------
    1 			1
    2 
    -------
    0 			1
    12对应的2进制为:0000 0000 0000 0000 0000 0000 0000 1100
  • 十进制转换为八进制

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

  • 十进制转换为十六进制

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

8.2.2 其他转十进制
  • 二进制转换为十进制
如:
    int num = 0b111010

    111010
    1 * 2^5 + 1 * 2^4 + 1 * 2^3 + 0 * 2^2 + 1*2^1 + 0*2^0
    32 + 16 + 8 + 0 + 2 + 0
    58  
  • 八进制转换为十进制
如:
    int num = 0123;
    
    1 * 8^2 + 2*8^1 + 3*8^0
    64 + 16 + 3
    83
  • 十六进制转换为十进制
如:
    int num = 0x123;
    
    1 * 16^2 + 2*16^1 + 3*16^0
    256 + 32 + 3
    291  

9. 原码、反码、补码

9.1 原码

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

int num = 1;
0000 0000 0000 0000 0000 0000 0000 0001

int 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 0001

int 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 0001

int 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 1111
    int i = 255; //0000 0000 0000 0000 0000 0000 1111 1111
    printf("c=%d, i=%d\n", c, i);
    
    return 0;
}
//输出:c=-1, i=255

整数越界:

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

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

在这里插入图片描述

#include <stdio.h>
int main(int argc, char const *argv[])
{
    char c = 127; //1111 1111
    int i = 255; //0000 0000 0000 0000 0000 0000 1111 1111
    c = 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;   // 12

	int 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 < 10
    int 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;
        
        1000
        1001
        ------
        1000
        
| 			按位或
	有1为1,同0为0
    如:
        int a = 8;
        int b = 9;
        int c = a | b;
        
        1000
        1001
        ------
        1001	
        
~ 			取反
	1为0,0为1
	
^ 			按位异或
	不同得1,相同得0
	
>> 			右移
    int num = 4;
    int a = num >> 2;
    
    100
    001
    
<< 			左移
    int num = 4;
    int a = num << 2;
    
    100
    10000

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.coloradmin.cn/o/1251192.html

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

相关文章

【MinIO】几个有用的方法

在windows总安装Minio 这是一篇不错的安装指南 进入网址 在Windows安装时&#xff0c;选择相应的exe文件下载&#xff0c;下载到本地后&#xff0c;使用如下的命令即可在前台启动&#xff1a; minio.exe server D:\your_path 或者将该路径写进环境变量的path中&#xff0c;…

新手如何买卖基金,基金投资基础入门

一、教程描述 本套基金教程&#xff0c;大小2.50G&#xff0c;共有13个文件。 二、教程目录 第01课&#xff1a;基金入门&#xff0c;学会投资其实不难.mp4 第02课&#xff1a;基金分类&#xff0c;琳琅满目清清楚楚.mp4 第03课&#xff1a;以稳取胜&#xff0c;稳健基金稳…

CSS水平居中与垂直居中的方法

当我们页面布局的时候&#xff0c;通常需要把某一个元素居中&#xff0c;这一篇文章为大家介绍一下居中的几种方法&#xff0c;本人文笔有限&#xff0c;请见谅&#xff01; 一.水平居中 行内元素水平居中的方法&#xff0c;我们使用text-align:center; <!DOCTYPE html&g…

市场被套牢,没有了解积累和分配,昂首资本一一介绍

很多投资者对市场中的积累和分配的概念不是很清楚&#xff0c;下面昂首资本将一一介绍。 积累意味着尽可能多地买入筹码&#xff0c;而不大幅抬高价格&#xff0c;直到在你买入时的价格水平上没有或几乎没有筹码。这种买入通常发生在市场熊市之后&#xff0c;此时有最佳买入价…

枚举与应用

作者简介&#xff1a;大家好&#xff0c;我是smart哥&#xff0c;前中兴通讯、美团架构师&#xff0c;现某互联网公司CTO 联系qq&#xff1a;184480602&#xff0c;加我进群&#xff0c;大家一起学习&#xff0c;一起进步&#xff0c;一起对抗互联网寒冬 枚举简介 枚举是一种特…

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

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

是否有无限提取的代理IP?作为技术你需要知道这些

最近有互联网行业的技术小伙伴问到&#xff0c;有没有可以无限提取的代理IP&#xff1f;就是比如我一秒钟提取几万、几十万次&#xff0c;或者很多台机器同时调用API提取链接&#xff0c;这样可以吗&#xff1f;看到这个问题&#xff0c;不禁沉思起来&#xff0c;其实理论上是存…

数据结构与算法编程题23

设计二叉树的双序遍历算法&#xff08;双序遍历是指对于二叉树的每一个结点来说&#xff0c;先访问这个结点&#xff0c;再按双序遍历它的左子树&#xff0c;然后再一次访问这个结点&#xff0c;接下来按双序遍历它的右子树&#xff09; #define _CRT_SECURE_NO_WARNINGS#inclu…

【点云surface】Poisson表面重建

1 介绍 Poisson表面重建算法是一种用于从点云数据生成平滑曲面模型的算法。它基于Michael Kazhdan等人在2006年发表的论文《Poisson surface reconstruction》。该算法通过将点云数据转换为体素表示&#xff0c;并利用Poisson方程来重建曲面。 该算法的基本原理是将点云数据转…

python基础教程:动态参数

前言 大家早好、午好、晚好吖 ❤ ~欢迎光临本文章 如果有什么疑惑/资料需要的可以点击文章末尾名片领取源码 Python的动态参数有两种&#xff0c;分别是*args和**kwargs&#xff0c; 这里面的关键是一个和两个星号的区别&#xff0c;而不是args和kwargs在名字上的区别&#…

微信小程序-跳转到另一个小程序

微信小程序-跳转到另一个小程序 微信小程序跳转到另一个小程序有一个条件:这两个小程序被同一个微信公众号关联&#xff0c;否则不能跳转&#xff0c;会报错。 官方文档 wx.navigateToMiniProgram({appId: wxa38r249405b957c6,path: pages/splash/index,//extraData: 需要传递…

Android : PopupWindow 悬浮框_简单应用

示例图&#xff1a; MainActivity.java package com.example.popupwindow;import androidx.appcompat.app.AppCompatActivity;import android.content.Context; import android.graphics.drawable.ColorDrawable; import android.os.Bundle; import android.view.LayoutInflat…

浅谈STL中的分配器

分配器是STL中的六大部件之一&#xff0c;是各大容器能正常运作的关键&#xff0c;但是对于用户而言确是透明的&#xff0c;它似乎更像是一个幕后英雄&#xff0c;永远也不会走到舞台上来&#xff0c;观众几乎看不到它的身影&#xff0c;但是它又如此的重要。作为用户&#xff…

Vue组件的几种通信方式

这里写目录标题 Vue组件的几种通信&#xff08;数据传递&#xff09;方式非父子组件间通信&#xff08;Bus事件总线&#xff09;介绍实例 非父子通信-provide&inject1.作用2.场景3.语法4.注意 父子组件间的通信固定props属性名&#xff08;v-model&#xff09;介绍实例 不固…

【部署运维】docker:入门到进阶

0 前言 部署运维博客系列一共有三篇&#xff1a; 拥抱开源&#xff0c;将工作中的经验分享出来&#xff0c;尽量避免新手踩坑。 【部署运维】docker&#xff1a;入门到进阶 【部署运维】kubernetes&#xff1a;容器集群管理掌握这些就够了 【部署运维】pythonredisceleryd…

C++多态-虚函数

多态分为编译时多态和运行时多态。编译时多态就是在编译阶段就能绑定要执行的那个函 数。运行时多态要等到运行到调用的那条语句时&#xff0c;根据指针/引用所绑定的对象&#xff0c;来决定执行哪 个函数&#xff0c;我们要讲的虚函数就是运行时多态&#xff0c;是 C中非常重…

嵌入式的学习需要合理规划时间

低级的欲望放纵即可获得&#xff0c;高级的欲望只有克制才能达成。——卡耐基1、粉丝的误会 很多粉丝&#xff0c;问我&#xff0c; "胡老师我想报您的培训班。" ... 得知我知识业余时间写文章&#xff0c;紧接着又会问&#xff0c; "jg单位这么清闲啊&#…

带你理解H桥电路

H桥电路 文章目录 H桥电路前言一、H桥基本结构二、H桥原理二、控制模式三、MOS管H桥 前言 在做单片机控制小车的时候一定会用一个电机驱动板&#xff0c;这个电机驱动板是怎么做的呢&#xff0c;答案就是H桥&#xff0c;没学过电路的同学可能会问什么是H桥&#xff0c;这篇文章…

【c++哈夫曼树代码实现】

哈夫曼树是不定长编码方式&#xff0c;由于是将权值大的元素放在离根结点近的地方 &#xff0c;权值小的放在离根远的地方&#xff0c;哈夫曼树效率很高&#xff0c;并且一个编码不会以另一个编码作为前缀&#xff0c;避免了编码的歧义性&#xff0c;本文将带大家探索如何创建和…