专栏首页程序员互动联盟【编程基础】C语言从源程序到可执行程序

【编程基础】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)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

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

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

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 【答疑解惑】推荐给新手的Java学习资料

    国际惯例,每天更新答疑解惑。网友们在群里有很多问题讨论,小编挑几个很有代表性的问题给大家叨叨几句。 一、关于Java学习资料: 昨天有网友对于Java群中资料少...

    程序员互动联盟
  • 程序员最喜欢的4个编辑器

    程序员对于编程的工具存在很大的差异性,而且一般的程序员一旦选择了一种编程器基本上就不再选择别的编辑器,这算是程序员独有的一种特性,一旦喜欢就很难选择放弃,现在就...

    程序员互动联盟
  • 浏览器开发系列第五篇:Debugging with WinDBG

    Windbg相信windows开发的人都知道,有些人用的溜儿溜儿的,有个crash,直接拿这个工具一分析,就定位出来了。非常好用。以前有个同事,做sdk开发的...

    程序员互动联盟
  • 什么是四层应用架构?

      随着移动应用的不断普及,传统后端三层架构已经不能再满足需要了,这种三层架构我们通常称为monolithic(巨石 整体的 铁板一块的)的架构。

    物流IT圈
  • 不用绿幕也能做特效,谷歌「LED蛋」让你告别五毛特效,光线、影子都能调

    「灯光」在影视作品、游戏和虚拟环境中的作用至关重要——有时候它是决定一个场景表演质量的关键,这个很容易理解。比如某些古装剧的某些场景会让人非常出戏,除了演员的演...

    OpenCV学堂
  • 12000+star的GANSynth,音乐与AI的完美结合

    简介:GANSynth是一种利用生成对抗网络合成音频的算法,它比NSynth数据集上的标准WaveNet基线能获得更好的音频质量,并且合成音频的速度快数千倍。

    昱良
  • 看看Qt里那些使用了匿名函数

    Qt君
  • 基于流量的OpenSSL漏洞利用检测方法

    CVE-2014-0160漏洞背景 2014年4月7日OpenSSL发布了安全公告,在OpenSSL1.0.1版本中存在严重漏洞(CVE-2014-0160)...

    FB客服
  • 张小龙微信公开课PRO演讲:信息互联的7个思考

    其实我是故意不来现场的。记得第一次公开课,我提到说,参加各种会议可能是很浪费时间的。

    业余草
  • 张小龙微信公开课PRO演讲:信息互联的7个思考

    其实我是故意不来现场的。记得第一次公开课,我提到说,参加各种会议可能是很浪费时间的。

    数据猿

扫码关注云+社区

领取腾讯云代金券