记事本写C++并用g++编译,同样,启动记事本gedit
写代码:
#include<iostream>
using namespace std;
int main()
{
cout<<"Hi,learning c++ in g++"<<endl;
return 0;
}
保存在主文件夹目录下,名字就叫hello.cpp
启动终端,执行命令:
$g++ -Wall hello.cpp -o hello
$ ./hello
Hi,learning c++ in g++
该命令将文件‘hello.cpp’中的代码编译为机器码并存储
在可
执行文件’hello’中。机器码的文件名是通过 -o 选项指定的。该选项通常作为命令行中的最后一个参数。如果被省略,输出文件默认为
‘a.out’。注意到如果当前目录中与可执行文件重名的文件已经存在,它将被复盖。选项 -Wall
开启编译器几乎所有常用的警告──强烈建议你始终使用该选项。编译器有很多其他的警告选项,但 -Wall 是最常用的。默认情况下GCC
不会产生任何警告信息。当编写 C 或 C++
程序时编译器警告非常有助于检测程序存在的问题。本例中,编译器使用了 -Wall
选项而没产生任何警告,因为示例程序是完全合法的。这将可执行文件载入内存,并使 CPU 开始执行其包含的指令。 路径 ./ 指代当前目录,因此
./hello 载入并执行当前目录下的可执行文件 ‘hello’。
捕捉错误的例子
如上所述,当用 C 或 C++
编程时,编译器警告是非常重要的助手。为了说明这一点,下面的例子包含一个微妙的错误:为一个整数值错误地指定了一浮点数控制符‘%f’。
#include <stdio.h>
int main (void)
{
printf ("Two plus two is %f\n", 4);
return 0;
}
一眼看去该错误并不明显,但是它可被编译器捕捉到,只要启用了警告选项 -Wall。编译上面的程序‘bad.c’,将得到如下的消息:
$ gcc -Wall bad.c -o bad
bad.c: In function 'main':
bad.c:6: warning: double format, different type arg (arg 2)
这表明文件 ‘bad.c’第 6 行中的格式字符串用法不正确。GCC 的消息总是具有下面的格式
文件名:行号:消息。编译器对错误与警告区别对待,前者将阻止编译,后者表明可能存在的问题但并不阻止程序编译。本例中,对整数值来说,正确的格式控制符
应该是 %d。如果不启用 -Wall,程序表面看起来编译正常,但是会产生不正确的结果:
显而易见,开发程序时不检查警告是非常危险的。如果有函数使用不当,将可能导致程序崩溃或产生错误的结果。开启编译器警告选项 -Wall 可捕捉 C 编程时的多数常见错误。
$ gcc bad.c -o bad
$ ./bad
Two plus two is 2.585495
一个源程序可以分成几个文件。这样便于编辑与理解,尤其是程序非常大的时候。这也使各部分独立编译成为可能。下面的例子中我们将程序 Hello
World 分割成 3 个文件:‘main.c’,‘hello_fn.c’和头文件hello.h’。这是主程序‘main.c’:
#include "hello.h"
int main(void)
{
hello ("world");
return 0;
}
在先前的例子‘hello.c’中,我们调用的是库函数 printf,本例中我们用一个定义在文件‘hello_fn.c’中的函数
hello 取代它。主程序中包含有头文件‘hello.h’,该头文件包含函数 hello
的声明。我们不需要在’main.c’文件中包含系统头文件‘stdio.h’来声明函数 printf,因为‘main.c’没有直接调用
printf。文件‘hello.h’中的声明只用了一行就指定了函数 hello 的原型。
void hello (const char * name);
函数 hello 的定义在文件‘hello_fn.c’中:
#include <stdio.h>
#include "hello.h"
void hello (const char * name)
{
printf ("Hello, %s!\n", name);
}
语句 #include “FILE.h” 与 #include <FILE.h> 有所不同:前者在搜索系统头文件目录之前将先在当前目录中搜索文件‘FILE.h’,後者只搜索系统头文件而不查看当前目录。要用gcc编译以上源文件,使用下面的命令:
$ gcc -Wall main.c hello_fn.c -o newhello
本例中,我们使用选项 -o 为可执行文件指定了一个不同的名字 newhello。注意到头文件‘hello.h’并未在命令行中指定。源文件中的的 #include “hello.h” 指示符使得编译器自动将其包含到合适的位置。
要运行本程序,输入可执行文件的路径名:
$ ./newhello
Hello, world!
源程序各部分被编译为单一的可执行文件,它与我们先前的例子产生的结果相同。
库是预编译的目标文件(object files)的集合,它们可被链接进程序。静态库以后缀为‘.a’的特殊的存档文件(archive file)存储
。
标准系统库可在目录 /usr/lib 与 /lib 中找到。比如,在类 Unix 系统中 C 语言的数学库一般存储为文件
/usr/lib/libm.a。该库中函数的原型声明在头文件 /usr/include/math.h 中。C 标准库本身存储为
/usr/lib/libc.a,它包含 ANSI/ISO C 标准指定的函数,比如‘printf’。对每一个 C 程序来说,libc.a
都默认被链接。下面的是一个调用数学库 libm.a 中 sin 函数的的例子:
#include <math.h>
#include <stdio.h>
int main (void)
{
double x = sin (2.0);
printf ("The value of sin(2.0) is %f\n", x);
return 0;
}
尝试单独从该文件生成一个可执行文件将导致一个链接阶段的错误:
$ gcc -Wall calc.c -o calc
/tmp/cckDHfI8.o: In function `main':
calc.c.text+0x1b): undefined reference to `sin'
函数 sin,未在本程序中定义也不在默认库‘libc.a’中;除非被指定,编译器也不会链接‘libm.a’。为使编译器能将 sin 链接进主程序‘calc.c’,我们需要提供数学库‘libm.a’。一个容易想到但比较麻烦的做法是在命令行中显式地指定它:
$ gcc -Wall calc.c /usr/lib/libm.a -o calc
函数库‘libm.a’包含所有数学函数的目标文件,比如sin,cos,exp,log及sqrt。链接器将搜索所有文件来找到包含 sin 的目标文件。一旦包含 sin 的目标文件被找到,主程序就能被链接,一个完整的可执行文件就可生成了:
$ ./calc
The value of sin(2.0) is 0.909297
可执行文件包含主城许的机器码以及函数库‘libm.a’中 sin 对应的机器码。为避免在命令行中指定长长的路径,编译器为链接函数库提供了快捷的选项‘-l’。例如,下面的命令
$ gcc -Wall calc.c -lm -o calc
与我们上面指定库全路径‘/usr/lib/libm.a’的命令等价。一般来说,选项 -lNAME使链接器尝试链接系统库目录中的函数库文件 libNAME.a。一个大型的程序通常要使用很多 -l 选项来指定要链接的数学库,图形库,网络库等。
分享到:
相关推荐
### C/C++编译环境搭建详解 在计算机编程领域,C和C++是两种非常重要的编程语言,广泛应用于操作系统、游戏开发、系统级编程、嵌入式系统等多个领域。搭建一个稳定高效的C/C++编译环境是每个程序员的必修课,尤其是...
配置交叉编译环境是为了在 Linux 平台下使用 Eclipse 进行嵌入式 C 开发时,能够正确地编译和生成目标代码。 配置交叉编译环境的重要性: 在 Linux 平台下使用 Eclipse 进行嵌入式 C 开发时,需要配置交叉编译环境...
本文将深入探讨如何在C++程序中调用Lua动态链接库,并讲解其编译过程和环境配置。 首先,我们需要理解Lua的动态链接库(liblua.so)。Lua是一个轻量级的脚本语言,它的动态链接库允许C/C++程序直接嵌入和调用Lua...
Linux 下 C++ 开发环境搭建 Linux 作为一个开源的操作系统,广泛应用于服务器、嵌入式系统和个人计算机等领域。作为一名 C++ 开发者,在 Linux 平台上搭建一个完整的 C++ 开发环境是非常必要的。本文将详细介绍...
1、TensorFlow C++ API的编译是线上使用TensorFlow C++ API调用预先训练好的模型完成预测项目的必经之路...2、Linux环境下编译TensorFlow C++ API生成的动态链接库:libtensorflow_cc.so,libtensorflow_framework.so。
《高级C/C++编译技术》一书由[美]斯特瓦诺维奇撰写,是一部深入探讨C和C++编译技术的专业著作。本书的核心内容涵盖了C/C++编程语言的底层细节,尤其是关于编译器的工作原理、库的加载机制以及程序打包技术等方面的...
vscode 配置c/c++编译环境(里面包含视频教程,配置文件,MinGW-W64 GCC-8.1.0安装包170MB)。适用于Win64.自己在官网下载并安装的,废了一天才搞好。 vscode 配置c/c++编译环境(里面包含视频教程,配置文件,...
### VS Code 配置C++编译环境 #### 概述 本文档旨在详细介绍如何在Visual Studio Code(简称VS Code)中快速配置C/C++的编译环境,从而实现代码的编写、编译及调试。本教程适用于Windows操作系统,并且采用的是轻量...
本文将详细讲解如何配置Vim为C/C++的开发环境,使其具备类似IDE的功能,如函数补全、小括号补全等。 首先,我们需要了解Vim的基本操作,它是一个命令行下的文本编辑器,可以通过键盘快捷键进行高效的文本处理。在...
Poco是一个开源的C++库,它为开发跨平台的应用程序提供了一系列的工具和类库。这个库包含了大量的模块,如网络、数据库访问、XML处理、JSON解析、加密、日志记录、线程管理和时间处理等,使得开发者可以快速构建复杂...
- **g++**: 用于编译C++语言源代码。 - **cc** 和 **c++**: 在某些系统中可能作为gcc或g++的别名存在,用于兼容性目的。 2. **GCC的基本用法示例:** - 编译一个名为`test.c`的C语言源文件,并生成名为`a.out`的...
#pragma指令是C语言和C++语言中最复杂的预编译命令之一,它可以设定编译器的状态或者指示编译器完成一些特定的动作。不同的编译器可能会有不同的#pragmadirectives,每个编译器都可以根据需要定义自己的#pragma指令...
支持Linux 下 C与C++混合编程的makefile 。
在Linux环境下,构建和安装MySQL 5.7.18的源码以及Connector/C++ 1.1.8是一项技术性较强的任务。首先,我们需要理解MySQL数据库系统的基础,它是世界上最流行的开源关系型数据库管理系统,而Connector/C++是MySQL...
这篇笔记主要探讨了在Linux环境下如何编译C++程序以及如何处理静态和动态链接库。以下是对这些知识点的详细说明: 1. **C++编译过程**: - C++程序的编译通常包括预处理、编译、汇编和链接四个步骤。预处理阶段...
### Linux Eclipse C++项目编译与调试 #### 一、前言 在当前的软件开发环境中,许多C++开发者仍然采用传统的文本编辑器配合gdb命令的方式进行编码和调试,这种方式虽然简单直接,但对于大型项目而言,其低效性与...
### Linux下C/C++开发入门及开发环境配置 #### C语言简介 C语言是一种历史悠久、通用性强的编程语言,最初由贝尔实验室的Dennis Ritchie为UNIX操作系统开发所设计。随着时间的发展,C语言逐渐成为了跨平台编程的...
"集成lua源码的c++编译环境"这个主题涉及了三个关键技术:Lua、Makefile以及C++。下面我们将深入探讨这些技术及其在项目中的应用。 首先,Lua是一种轻量级的脚本语言,因其简洁的语法和高效的执行性能,被广泛用于...
集成编译环境(Integrated Development Environment, IDE)是用于编写、调试和管理C++程序的软件工具集,它提供了方便的代码编辑、编译、链接和调试功能,极大地提升了程序员的生产力。 C++集成编译环境的核心组件...
总之,Dev C++ for Linux 是Linux开发者学习和实践C/C++编程的理想选择,它的集成开发环境为代码编写、编译、调试提供了全方位的支持,同时保持了开源软件的自由度和可定制性。无论是初学者还是经验丰富的开发者,都...