C++程序设计——编译链接运行原理

  通常情况下,我们编写的.c或.cpp文件称为源文件,这一类文件是不能够在计算机上运行的,因为计算机只认识机器指令(及01代码),而我们通常使用的C语言、C++或者是Java都属于高级语言(高级语言的引入很大程度提高了程序的易读性、开发效率和可移植性),因此,源文件要想执行,就必须将源文件经过处理转换成机器指令,这就引入了我们的编译链接原理。
1.编译链接原理
  首先从我们的编译指令(Linux环境下的编译)开始逐步深入:
在这里插入图片描述Add.c
1.1预编译
预编译指令:gcc -E main.c -o main.i
在这里插入图片描述
tail -n 20 main.i查看main.i文件的最后20行,结果如下
在这里插入图片描述
综合以上信息,我们可以得出预编译阶段做了以下事情:
a.删除#define,进行文本替换
b.处理预编译指令(#if #dendif #elif)
c.递归展开#include
d.删除注释
e.添加行号(便于编译时编译器产生调试用的行号信息及用于编译时产生编译错误或警告时能欧够显示行号 )和文件标识
f.保留所用的#program编译器指令,因为编译器需要使用它们

1.2编译
编译指令:gcc -S main.c -o main.s
在这里插入图片描述
查看mian.s的内容如下:
在这里插入图片描述
综合以上信息,我们可以得出编译阶段做了以下事情:
a.词法分析(产生一堆单词)
b.语法分析(生成语法树)
c.语义分析(带变量的语法树)
d.代码优化
e.生成汇编指令

1.3汇编
汇编指令:gcc -c main.s -o main.o
在这里插入图片描述
使用readelf -s main.o查看符号表
在这里插入图片描述
综合以上信息,我们可以得出汇编阶段做了以下事情:
a.将汇编指令转换为二进制指令
b.形成符号表(将编译阶段汇总的符号形成一张符号表)

1.4链接
链接的过程如下图所示:
在这里插入图片描述
汇编指令:gcc -o main main.o
在这里插入图片描述
综合以上信息,我们可以得出链接阶段做了以下事情:
a.合并段和符号表
b.符号解析
c.分配地址和空间
4.符号重定位(text段)

  将汇编阶段生成的符号表进行合并。可重定位目标文件之中用来存放变量和其入口地址的符号表,重定位是指在链接阶段连接器会查找符号表,当发现某个符号表存在没有决议的内存地址时,连接器就会查找所有符号表,一直发现这些这些尚未决议的符号变量的内存地址写进符号表。直达所有的符号变量都能够找到合法的内存地址时,链接阶段重定位完成。否则会出现链接错误。

运行阶段在后边的地址空间介绍。

实验一 C++简单程序设计(2学时) 1.编程计算形的面积。程序可以计算圆形、长方形、正方形的面积、运行时先提示用户选择形类型,然后,对圆形要求用户输入半径、对长方形要求用户输入长和宽的值,对正方形要求用户输入边长,计算出面积后将其显示出来。要求使用debug调试功能观察程序运行中变量值的变化情况。 2.定义一个表示时间的结构体,可以精确的表示年、月、日、小时、分、秒;提示用户输入年、月、日、小时、分、秒的值,然后完整地显示出来。 实验二 函数的应用(2学时) 1.编写重载函数Max1,分别求出两个整数,两个双精度数,三个整数,三个双精度数的最大值。 2.使用重载函数模板重新实现上面的函数Max1。 要求:(1)练习重载函数的使用;(2) 练习函数模板的使用。 实验三 类与对象(2学时) 1.声明一个Dog类,包含age、weight等属性,以及对这些属性操作的方法。实现并测试这个类。 2.设计并测试一个名为Rectangle的矩形类,其属性为矩形的左下角和右上角两个点的坐标,有成员函数能计算矩形的面积。 3.定义一个CPU类,包含等级、频率,电压等属性,并编写构造函数、析构函数,以及成员函数run、stop模拟CPU的状态。其中,等级为整型,频率为单位是兆赫兹的整数,电压为浮点型。要求自己设计各个属性的标识。 4.定义一个简单的Computer类,包含数据成员cpu、ram、cdrom等等,有两个成员函数run、stop。其中cpu为CPU类的一个对象,ram为RAM类的一个对象,cdrom为CDROM类的一个对象,定义并实现这个类。 5.(必做)设计一个用于人事管理的People类。考虑到通用性,可以只抽象出所有人员都 具有的属性:number(编号),sex(性别) ,birthday(出生日期),id(身份证号)等等。其中“出生日期”定义为一个“日期”类内嵌子对象。用成员函数实现对人员函数的录入和显示。要求包括:编写构造函数和析构函数、拷贝构造函数、内联成员函数,类的组合。 实验四 C++程序的结构(2学时) 1.编写程序,实现并测试客户机(Client)类。定义字符型静态数据成员ServerName[10],保存其服务器名称;整型静态数据成员ClientNum,记录定义的客户数量;定义静态函数ChangeServerName()改变服务器名称。在头文件client.h中定义类,在文件client.cpp中实现,在文件test.cpp中测试这个类,观察相应的成员变量的取值的变化情况。 2、在实验三题目5编写的人员类中设计适当的方法来实现类中数据的共享性,并采用多文件结构实现程序。 3.(选做)定义类X、Y、Z,函数h(X *),满足:类X有私有成员i,Y的成员函数g(X *)是X的友元函数,实现对X的成员i加1,类Z是类X的友元类,其成员函数f(X *)实现对X的成员i加5,函数h(X *)是X的友元函数,实现对X的成员i加10。在一个文件中声明类,在一个文件中实现类,在另一个文件中测试类。 实验五 继承和派生(2学时) 1.设计并定义一个交通工具类,并通过该类派生出新的类,编写程序定义这些类并测试它; 2.(选做)声明一个基类Shape,在此基础上派生Rectangle和Circle,二者都有GetArea()函数计算对象的面积,编写程序测试。 3.(选做)声明一个哺乳动物类Mammal,再由此派生出狗类Dog,定义一个Dog类的对象,观察基类与派生类的构造函数和析构函数的调用顺序。 4.完善实验四第2题的程序,具体要求如下: 任务1:从people(人员)类派生出student(学生)类,添加属性:学校、学院、专业、班号、入学成绩,设计相应的成员函数(构造函数,拷贝构造函数,录入函数,显示函数)。 任务2:从people类派生出teacher(教师)类,添加属性:职务,部门,职称。并设计相应的成员函数。 任务3:从student类派生出graduate(研究生)类,添加属性:导师,研究方向。并设计相应的成员函数。 任务4:编写程序来测试这个类。 实验六 小型学生管理系统的设计与实现1(2学时) 设计学生类、课程类、成绩类及相应的成员函数。要求能实现学生的信息、课程信息和成绩信息的增加、修改、删除与查询。 实验七 多态性(2学时) 1.定义Point类,有坐标X和Y两个成员变量,对Point类重载++和――运算符,实现对坐标值的改变。 2.定义一个车(Vehicle)类,有run,stop等成员函数,由此派生出自行车(bicycle)类、汽车(car)类,由bicycle类和car类派生出摩托车(motocar)类,它们都包含run,stop等成员函数,编写相应的虚函数并测试
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值