代码原来是这样被CPU跑起来的

CPU对我们来说既熟悉又陌生,熟悉的是我们知道代码是被CPU执行的,当我们的线上服务出现问题时可能首先会查看CPU负载情况 。陌生的是我们并不知道CPU是如何执行代码的,它对我们的代码做了什么 。本文意在简单解释我们代码的生命周期,以及代码是如何在CPU上跑起来的 。

代码原来是这样被CPU跑起来的

文章插图
 
编译-让计算机认识我一个漂亮 control+c 加上一个漂亮的 control+v,啪~,我们愉快的写下了代码,当代码被保存后,它就被存在我们磁盘的某个地方,它可能是像JAVA或者Python这些高级语言写的,也可能是像c这种古老语言写的,但是现在它肯定没法被运行,因为计算机不认识它们,计算机只认识0、1这样的二进制,简称机器码,那为什么我们不直接写机器码?如果你有这样的思考,我只能呵呵了,请你帮我翻译下以下机器码:
001010100101001001001100100101000101010101复制代码很明显作为高质量人类的我们也无法识别出这段代码写的是什么,于是出现类似java这样的高级语言,它们给机器码穿上了一层外衣,然后交给伟大的程序员来创造未来 。
所以反过来我们的代码需要被替换成机器码,这样才能被计算机认识,计算机才能帮我们干事 。这个转换的过程我们通常叫编译 。
#include <studio.h>int main() {printf("Hello Worldn");return 0;}复制代码这是一段应该每个程序员都写过的代码(hello.c),在linux下,当我们使用GCC来编译Hello World程序时,只需要最简单的命令:
gcc hello.c./hello# Hello World复制代码看似很简单的一行,但是其实编译的过程很复杂,并不是我们想象中的编译,真实是分为4个步骤,分别是


    推荐阅读