【编程基础】C语言从源程序到可执行程序

一.0,1、文本信息和字符编码 所有的信息在计算机中都是以0、1及其组合形式存在。文本信息也不例外。文本信息是以人类容易理解的方式来呈现信息。

计算机是在美国诞生的,英文26个字母加上其他符号只有128个,只用7个bit便可以完全表示所有符号。用8个bit,及一个byte来表示一个符号的方式就叫做ascii编码。对应的有ascii码表。 比如说要在计算机中表示"i love you"这个信息,采用ascii编码方式,那么在计算机中,那就是69 20 6c 6f 76 65 20 79 6f 75(hex)

但是在其他国家,符号远远多于128个,8个bit远远不够表达所有的符号,于是便有了其他编码方式,像中国的gb2312汉字编码。当然,其他编码方式表达一个符号的字节不一定是8个bit。不同编码国家都有自己的编码方式,不同编码之间的信息之间都要转换。

为了解决这个问题,unicode编码出现了。unicode自身也存在问题。utf编码作为一种unicode的实现方式,解决了unicode的问题。utf8用一个字节表示 一个字符。utf16用2或者4个字节表示一个字符。utf32则用4个字节表示一个字符。

二.文本信息到可执行程序 不论是.c, .cpp 还是.h文件,所有的这些我们称之为程序的东西都是文本信息。他们都无法被计算机认识。计算机只认识0和1.所以要让计算机执行我们用文本信息表示的程序,必须将这些文本信息表示的程序翻译成计算机认识的01代码串。

在linux下,以helloworld.c为例,使用gcc编译器,这个翻译过程一般分为以下四个步骤: 1).preprocessing预处理。 预处理过程会把所有包含的头文件的具体内容插入到指定位置,并把所有的宏展开。gcc下,用 gcc helloworld.c -o helloworld.i -E 可以得到预处理后的文件helloworld.i

2)compilation编译 将预处理后的文件中的所有符号翻译为汇编语言表示的信息。不同的CPU有不同的汇编指令集。不同的编译器有不同的汇编语言表示方式。GCC下,用 gcc helloworld.c -o helloworld.s -S 可以得到编译后用gcc汇编语言表示的文本信息。 其中的每一条汇编语言指定在CPU硬件层都对应着特定的二进制01指令集。

3)assembling汇编 将用汇编语言表示的符号翻译成特定的硬件层支持的二进制01指令集。gcc下,用 gcc helloworld.c -o helloworld.o -c 可以得到汇编后的用01指令集表示的信息文件,我们称之为可重定位的目标文件。

4)linking链接 由于我们引用了别的库中的符号,我们需要将这些符号的二进制指令集以某种方式装入到我们程序中,最后经过一些处理后才得到了能被计算机识别的可执行程序。在linux下,是elf文件。

三. CPU的寻址能力/寻址范围 寻址能力就是CPU能查找的地址的最大范围。 CPU的寻址能力由地址总线的位数决定。 32-bit的CPU指CPU一次能处理指令长度为32bit。 1.平坦地址模式

平坦地址模式将整个存储空间看成一个大的数组,存储空间的地址是线性增长的。

2.虚拟地址空间 32-bit的CPU,虚拟地址空间范围从0到0xffffffff线性增长。我们在程序中操作内存时使用的是虚拟地址。操作系统负责将虚拟地址映射到物理地址空间。

转自csdn:TylerPen的blog

原文发布于微信公众号 - 程序员互动联盟(coder_online)

原文发表时间:2015-06-30

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java学习123

数据表或记录被锁住,解锁方法,请大家指教!

2688
来自专栏编程微刊

NumPy的文件读写

1374
来自专栏yw的数据分析

bam文件softclip , hardclip ,markduplicate的探究

  测序产生的bam文件,有一些reads在cigar值里显示存在softclip,有一些存在hardclip,究竟softclip和hardclip是怎么判断...

4259
来自专栏CDA数据分析师

【收藏】Excel中常用的十五招儿!

? 本文转自网络 1、快速填充公式 ? 2、最快求和 ? 3、对合并单元格求和 ? 4、设置列宽的3种方法 ? 5、以cm为单位设置行高列宽 ? 6、输入0开...

3416
来自专栏HansBug's Lab

1819: [JSOI]Word Query电子字典

1819: [JSOI]Word Query电子字典 Time Limit: 10 Sec  Memory Limit: 64 MB Submit: 729  ...

3314
来自专栏从流域到海域

《笨办法学Python》 第16课手记

《笨办法学Python》 第16课手记 本节课在上一节的基础之上加入了对文件的写操作,代码较长,请注意不要有遗漏。 原代码如下: from sys import...

1828
来自专栏运维一切

ceph pg分布相关的脚本 转

1002
来自专栏云计算教程系列

如何在Ubuntu 16.04上使用MySQL全文搜索提高搜索效果

全文搜索(FTS)是搜索引擎用于在数据库中查找结果的技术。您可以使用它来为商店、搜索引擎、报纸等网站上的搜索结果提供支持。

874
来自专栏GreenLeaves

EF 数据库连接约定(Connection String Conventions in Code First)

一个典型的EF应用大多数情况下是一个DbContext的派生类(derived class)来控制,通常可以使用该派生类调用DbContext的构造函数,来控制...

1919
来自专栏算法修养

pta 习题集 5-17九宫格输入法

假设有九宫格输入法键盘布局如下: [ 1,.?! ] [ 2ABC ] [ 3DEF ] [ 4GHI ] [ 5JKL ] [ 6MNO ] [...

2827

扫码关注云+社区