为什么汇编语言(如Windows,Linux)有所不同?

我对所有这些低级别的东西,汇编语言都比较新,想要了解更多的细节.为什么 Linux与Windows汇编语言有区别?

据了解,当我编译C代码时,操作系统并不能真正产生纯机器或汇编代码,它会产生与操作系统相关的二进制代码.但是为什么?

例如,当我使用x86系统时,cpu只能理解x86 ASM我是对的?为什么我们不写纯x86汇编代码,为什么基于操作系统有不同的组合变体?如果我们写纯ASM或OS产生纯ASM,操作系统之间不会有二进制兼容性问题?

我真的很想知道背后的所有原因.任何详细的答案,文章,书都会很棒.谢谢.

没有区别.如果处理器相同,则汇编代码相同.在Windows上编译的x86代码与Linux上的x86代码是二进制兼容的.编译器不会产生与OS相关的二进制代码,但是它可能会以不同的格式打包代码(例如,PE与ELF).

区别在于使用哪些库.为了使用操作系统的东西(例如I / O),您必须链接到操作系统的库.毫不奇怪,Windows系统库在Linux机器上不可用(除非您有Wine),反之亦然.

相关文章

Windows2012R2备用域控搭建 前置操作 域控主域控的主dns:自...
主域控角色迁移和夺取(转载) 转载自:http://yupeizhi.blo...
Windows2012R2 NTP时间同步 Windows2012R2里没有了internet时...
Windows注册表操作基础代码 Windows下对注册表进行操作使用的...
黑客常用WinAPI函数整理之前的博客写了很多关于Windows编程的...
一个简单的Windows Socket可复用框架说起网络编程,无非是建...