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

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来