Skip to main content

Command Palette

Search for a command to run...

c++ hello world

Published
1 min read
c++ hello world

c语言的编译步骤

gcc 编译  hello.c -o 生成的目标(可执行文件)名字为 world

预处理

gcc -E hello.c -o hello.i

带#的语句就是预处理指令,预处理指令在预处理的时候处理了

  • 头文件展开: #include <stdio.h> 包含文件stdio.h预处理时将stdio.h 文件拷贝至预处理文件中

  • 删除注释: 注释有两种方法: // /* */

  • 宏替换: #define 代表是声明一个宏,在预处理时会将宏给替代 (预处理的时候就会替换)

  • 预处理时 不会检查语法错误

  • 条件编译: 条件不成立: #if 0 -> #endif 条件成立 #if 1 -> #endif

    • c语言中 0表示不成立 1表示成立
  • 宏定义展开、头文件展开、条件编译等,同时将代码中的注释删除,这里并不会检查语法

编译

gcc -S hello.i -o hello.s
  • 预处理文件编译生成汇编文件 检查语法错误
  • 检查语法,将预处理后文件编译生成汇编文件

汇编

gcc -c hello.s -o hello.o
  • 汇编文件编译生成二进制文件.o

  • 将汇编文件生成目标文件(二进制文件)

链接

gcc    hello.o -o hello
  • 设置运行环境堆栈等,链接其他库
  • C语言写的程序是需要依赖各种库的,所以编译之后还需要把库链接到最终的可执行程序中去

1

选项含义
-E只进行预处理
-S(大写)只进行预处理和编译
-c(小写)只进行预处理、编译和汇编
-o file指定生成的输出文件名为 file
文件后缀含义
.cC 语言文件
.i预处理后的 C 语言文件
.s编译后的汇编文件
.o编译后的目标文件

一步编译

gcc hello.c -o demo(还是经过:预处理、编译、汇编、链接的过程):
29 views

More from this blog

MySQL | 表的内连接

数据操作语言:表连接查询(一) 从多张表中提取数据 从多张表提取数据,必须指定关联的条件。如果不定义关联条件就会出现无条件连接,两张表的数据会交叉连接,产生 笛卡尔积。 规定了连接条件的表连接语句,就不会出现笛卡尔积。 # 查询每名员工的部门信息 SELECT e.empno,e.ename,d.dname FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno; 表连接的分类 表连接分为两种:内连接 和 外连接 内连接是结果集中只保留符合...

May 16, 20221 min read13
MySQL | 表的内连接

MySQL | 分组查询的应用

数据操作语言:分组查询 为什么要分组? 默认情况下汇总函数是对全表范围内的数据做统计 GROUP BY 子句的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对每个小区域分别进行数据汇总处理 SELECT deptno,AVG(sal) FROM t_emp GROUP BY deptno; SELECT deptno,ROUND(AVG(sal)) FROM t_emp GROUP BY deptno; -- ROUND 取整 逐级分组 数据库支持多列分组条件,执行的时候...

Apr 27, 20221 min read10
MySQL | 分组查询的应用

MySQL | 聚合函数的使用

数据操作语言:聚合函数 什么是聚合函数 聚合函数在数据的查询分析中,应用十分广泛。聚合函数可以对 数据求和、求 最大值 和 最小值 、求 平均值 等等。 求公司员工的评价月收入是多少? SELECT AVG(sal+IFNULL(comm,0)) FROM t_emp; SELECT AVG(sal+IFNULL(comm,0)) AS avg FROM t_emp; SUM 函数 SUM 函数用于求和,只能用户数字类型,字符类型的统计结果为 0 ,日期类型统计结果是毫秒数相加 SE...

Apr 26, 20221 min read8
MySQL | 聚合函数的使用
U

Untitled Publication

173 posts