C | 在ubuntu22下开发的一些配置

2024-06-16 22:28
文章标签 配置 开发 ubuntu22

本文主要是介绍C | 在ubuntu22下开发的一些配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

VScode设置

要下载的插件:

卸载VScode的话就是哪装的哪删。

浅用gcc

预处理指令

使用gcc

语言编译过程

1. 预处理(Preprocessing)

2. 编译(Compilation)

3. 汇编(Assembly)

4. 链接(Linking)


VScode设置

其一开始如果没有进行额外的设置,默认编译C文件的时候只编译当前这个文件,即 ${file} ,这样会造成引用错误。

所以得修改参数:

把${file}注释掉,写成

"*.c"

这表示会编译当前项目目录下的所有.c文件。

保存后再运行文件就不会报错了。例如:

要下载的插件:

卸载VScode的话就是哪装的哪删。

浅用gcc

Linux 的C语言开发,一般选择 GCC 工具链进行编译。

在VScode里直接输入main+回车:

int main(int argc, char const *argv[])
{/* code */return 0;
}

其中,int argc是传入的参数个数, char const *argv[] 是接受传入的参数而形成的数组指针。

这两个参数可以先不用,删去就行。

预处理指令

在C语言中,#ifndef 是一个预处理指令,用于防止头文件被重复包含。它的全称是 "Not Defined If Not",即“如果未定义,则不包含”。这通常用于防止头文件被多次包含,这可能会引起编译错误或运行时错误。

这里是一个使用 #ifndef 的典型例子:

#ifndef HEADER_FILE_NAME_H
#define HEADER_FILE_NAME_H// 头文件的内容#endif // HEADER_FILE_NAME_H

这段代码的工作原理如下:

  1. #ifndef HEADER_FILE_NAME_H 检查是否已经定义了 HEADER_FILE_NAME_H 这个宏。如果没有定义,编译器会继续执行下面的代码。
  2. #define HEADER_FILE_NAME_H 定义了 HEADER_FILE_NAME_H 这个宏,确保如果再次遇到这个头文件,#ifndef 检查会失败,从而防止代码被再次包含。
  3. 头文件的内容放置在 #ifndef#endif 之间。
  4. #endif 表示 #ifndef 指令的结束。

使用这种技术可以确保头文件中的内容只被编译一次,即使在多个源文件中包含了同一个头文件。这是一种常见的做法,用于避免全局变量和函数的重复定义问题。

使用gcc

gcc 所有要编译的文件 -o 编译完输出的程序名

这是gcc最简单的使用过程,省略了中间过程。

语言编译过程

语言编译过程是将源代码转换成机器可以执行的指令的一系列步骤。这个过程通常包括以下几个阶段:

1. 预处理(Preprocessing)


   - 预处理器处理源代码文件中的预处理指令,如宏定义(`#define`)、文件包含(`#include`)等。

2. 编译(Compilation)


   - 编译器将预处理后的源代码转换成中间代码或目标代码。对于C语言,这通常是一个汇编语言形式的中间代码。

3. 汇编(Assembly)


   - 汇编器将汇编语言转换成机器码。这一步对于高级语言来说可能是编译器的一部分,直接生成机器码。

4. 链接(Linking)


   - 链接器将编译后的各个模块(比如由多个源文件编译生成的多个目标文件)合并成一个可执行文件。链接器还会处理外部库和函数调用。

最终生成的程序占内存大小和使用的链接方式有关。

-static :该参数指示编译器进行静态链接,而不是默认的动态链接。使用这个参数,GCC会尝试将所有用到的库函数直接链接到最终生成的可执行文件中,包括C标准库(libc)、数学库(libm)和其他任何通过代码引用的外部库。

5. 优化(Optimization)
   - 在编译和/或链接阶段,编译器可能会对代码进行优化以提高执行效率或减小生成的代码大小。

6. 代码生成(Code Generation)
   - 编译器生成可执行的机器代码。

7. 加载(Loading)
   - 加载器将编译生成的可执行文件加载到内存中,并为程序的执行准备环境。

8. 执行(Execution)
   - 程序开始运行,CPU执行加载到内存中的机器代码。

这个过程可能会根据使用的编程语言和编译器的不同而有所变化。例如,一些语言(如Java和C#)使用中间字节码,需要一个虚拟机来执行这些字节码。另外,一些现代编译器可能会将多个阶段合并或以不同的顺序执行这些步骤。

对于不同的编程语言,编译过程可能还包括其他步骤,比如垃圾收集、类型检查等。

本文需要改进的部分:

  1. 语言编译过程那部分,每部分都要补充对应的gcc命令。

这篇关于C | 在ubuntu22下开发的一些配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1067723

相关文章

IDEA中配置Tomcat全过程

《IDEA中配置Tomcat全过程》文章介绍了在IDEA中配置Tomcat的六步流程,包括添加服务器、配置部署选项、设置应用服务器及启动,并提及Maven依赖可能因约定大于配置导致问题,需检查依赖版本... 目录第一步第二步第三步第四步第五步第六步总结第一步选择这个方框第二步选择+号,找到Tomca

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Debian系和Redhat系防火墙配置方式

《Debian系和Redhat系防火墙配置方式》文章对比了Debian系UFW和Redhat系Firewalld防火墙的安装、启用禁用、端口管理、规则查看及注意事项,强调SSH端口需开放、规则持久化,... 目录Debian系UFW防火墙1. 安装2. 启用与禁用3. 基本命令4. 注意事项5. 示例配置R

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Redis MCP 安装与配置指南

《RedisMCP安装与配置指南》本文将详细介绍如何安装和配置RedisMCP,包括快速启动、源码安装、Docker安装、以及相关的配置参数和环境变量设置,感兴趣的朋友一起看看吧... 目录一、Redis MCP 简介二、安www.chinasem.cn装 Redis MCP 服务2.1 快速启动(推荐)2.

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be