C语言是怎么经过转换将变量的值存储在内存中的?

例如: char i = 10; 这时候内存是00001010吗,就这样存进去吗还是要经过什么步骤

C语言编译器负责将源代码中的十进制的10翻译成4字节数据:0A(16进制)(实际存储为二进制,但描述起来太长不方便一般用16进制显示和描述),而一个字节的10实际上的二进制就是你说的00001010。

实际上在处理存储之前需要先分配一个内存给变量 i,并在编译环境中注册登记这个变量名-地址关系(变量表),方便后续代码访问此变量时匹配到该地址,比如遇到 i=i+2时,编译器就会生成一个指令对该地址的值进行+2操作。此外还需要生成一个MOV指令代码指挥CPU执行:数据保存到该地址。

如果你对编译后的细节感兴趣,可以在调试时按CTRL+ALT+D(VS的快捷键,也可以通过菜单导航到“调试-窗口-反汇编”,其他编译器在调试菜单中找)切换到反汇编窗口查看编译结果,系统会逐条显示每一条语句对应的汇编指令。

当你对汇编指令感到好奇之后,可以看看汇编、编译原理、8086 CPU原理、以及数字电路的译码器 等书籍,不需要完全看懂,了解下会对你学习任何编程语言有帮助,不仅仅局限于C语言。

温馨提示:答案为网友推荐,仅供参考
第1个回答  2021-03-18
在系统为一个程序分配的空间中,分成许多段,比如有代码段,存放程序可执行代码,有数据段,可以分配变量,有常量段,专门存放常量,是只读的。常量变量可以位于数据段中,仍然是变量,只是程序没有改动权限。在程序执行到main之前,系统负责将常量区存储的常量赋值给常量。
第2个回答  2021-03-18
如果你要弄明白必须学两门课:计算机原理和汇编语言,这个简单两句说不清楚
相似回答