博客
关于我
linux下c++编程环境搭建,运行过程以及调试
阅读量:782 次
发布时间:2019-03-25

本文共 2325 字,大约阅读时间需要 7 分钟。

安装g++环境

安装g++环境在Linux系统中非常简单。安装两个RPM包即可搞定。

sudo yum install libstdc++-devel-4.4.5-6.i686.rpmsudo yum install gcc-c++-4.4.5-6.i686.rpm

安装完成后可以验证g++的版本:

g++ -v

gcc与g++的区别

gcc是GNU C编译器,用于编译C或C++代码,但通常我们使用g++来编译C++程序。虽然gcc可以编译C++代码,但它无法自动链接C++程序所需的库文件,而g++可以自动生成所需的依赖。

编写一个简单的C++程序

以下是一个简单的C++程序示例(存储在myfirst.cpp文件中):

// myfirst.cpp - 显示消息#include 
using namespace std;int main() { cout << "Come up and C++ me some time."; cout << endl; cout << "You won't regret it!" << endl; return 10;}

在命令行窗口中编译:

g++ -o test1 test.cpp

-o test1 test.cpp命令会将test.cpp编译生成test1可执行文件。若没有指定-o选项,默认会生成a.out文件。

运行可执行文件:

./a.out

查看main函数的返回值:

echo?

c/c++运行流程分解

在Linux中,C/C++程序的运行流程包括以下几个阶段:

  • 预处理(Preprocessing)结果生成.i文件:

    g++ -E funcuse.c -o e.i
  • 编译(Compiling)结果生成.s文件:

    g++ -S e.i -o e.s

    可以合并为:

    g++ -s e.i -o e.s
  • 汇编(Assembling)生成目标文件(.o文件):

    g++ -c e.s -o e.o
  • 链接(Linking)生成可执行文件:

    g++ e.o -o result
  • 运行(Executing)运行结果文件:

    ./result
  • 在Linux中运行程序之前通常需要使用./指定程序的路径,除非程序已被添加到PATH环境变量中。

    头文件与源文件

    头文件(Header Files)通常用于包含其他文件(.cpp文件)所需的功能说明,头文件本身不参与编译,但其内容被多个源文件引用。我应该将常量、函数声明放置在头文件中,而不要在头文件中定义这些内容。以下是头文件的三大例外:

  • 常量的定义
  • 内联函数(inline)的定义
  • 类(class)的定义
  • 分离式编译

    以下是一个分离式编译的示例,分为三个文件:

  • Circle.h:头文件
  • #ifndef CIRCLE_H#define CIRCLE_Hclass Circle {private:    double r;public:    Circle();    Circle(double R);    double Area();};#endif
    1. Circle.cpp:源文件
    2. #include "Circle.h"#include 
      using namespace std;Circle::Circle() { this->r = 5.0;}Circle::Circle(double R) { this->r = R;}double Circle::Area() { return 3.14 * r * r;}// 其他代码
      1. main.cpp:主程序文件
      2. #include "Circle.h"#include 
        using namespace std;int main(int argc, char *argv[]) { Circle c(3); cout << "Area = " << c.Area() << endl; return 0;}

        编译命令:

        g++ -c Circle.cpp -o Circle.og++ -c main.cpp -o main.og++ main.o Circle.o -o main

        运行程序:

        ./main

        Makefile

        Makefile是用于自动化编译的重要工具,特别适用于大型项目。大部分项目都需要将源文件分为多个文件,Makefile可以帮助我们自动编译并生成最终可执行文件。

        # 生成所有源文件all:    g++ -c main.cpp -o main.o    g++ -c Circle.cpp -o Circle.o    g++ main.o Circle.o -o main# 清理构建文件clean:    rm -rf main.o Circle.o main

        使用命令:

        makemake clean

        GDB调试

        GDB(GNU Debugger)是Linux下的强大调试工具。以下是使用GDB的示例:

      3. 编译并添加调试信息:

        g++ -g funcuse.c -o debug
      4. 启动GDB:

        gdb debug
      5. 使用GDB调试:

        (gdb) list 3(gdb) break 5(gdb) run(gdb) continue(gdb) whatis i(gdb) print i(gdb) display i(gdb) step(gdb) finish
      6. 通过GDB,我可以在程序执行过程中设置断点,观察变量值,单步执行代码文件。

    转载地址:http://lesuk.baihongyu.com/

    你可能感兴趣的文章
    OSG学习:场景图形管理(三)——多视图相机渲染
    查看>>
    OSG学习:场景图形管理(二)——单窗口多相机渲染
    查看>>
    OSG学习:场景图形管理(四)——多视图多窗口渲染
    查看>>
    OSG学习:新建C++/CLI工程并读取模型(C++/CLI)——根据OSG官方示例代码初步理解其方法
    查看>>
    Sql 随机更新一条数据返回更新数据的ID编号
    查看>>
    OSG学习:空间变换节点和开关节点示例
    查看>>
    OSG学习:纹理映射(一)——多重纹理映射
    查看>>
    OSG学习:纹理映射(七)——聚光灯
    查看>>
    OSG学习:纹理映射(三)——立方图纹理映射
    查看>>
    OSG学习:纹理映射(二)——一维/二维/简单立方图纹理映射
    查看>>
    OSG学习:纹理映射(五)——计算纹理坐标
    查看>>
    OSG学习:纹理映射(六)——灯光
    查看>>
    OSG学习:纹理映射(四)——三维纹理映射
    查看>>
    OSI七层模型的TCP/IP模型都有哪几层和他们的对应关系?
    查看>>
    OSM数据如何下载使用(地图数据篇.11)
    查看>>
    OSPF 四种设备角色:IR、ABR、BR、ASBR
    查看>>
    OSPF 概念型问题
    查看>>
    SQL Server 存储过程分页。
    查看>>
    OSPF不能发现其他区域路由时,该怎么办?
    查看>>
    OSPF两个版本:OSPFv3与OSPFv2到底有啥区别?
    查看>>