我对所有这些低级别的东西,汇编语言都比较新,想要了解更多的细节.为什么
Linux与Windows汇编语言有区别?
据了解,当我编译C代码时,操作系统并不能真正产生纯机器或汇编代码,它会产生与操作系统相关的二进制代码.但是为什么?
例如,当我使用x86系统时,cpu只能理解x86 ASM我是对的?为什么我们不写纯x86汇编代码,为什么基于操作系统有不同的组合变体?如果我们写纯ASM或OS产生纯ASM,操作系统之间不会有二进制兼容性问题?
我真的很想知道背后的所有原因.任何详细的答案,文章,书都会很棒.谢谢.
没有区别.如果处理器相同,则汇编
代码相同.在Windows上编译的x86
代码与Linux上的x86
代码是二进制兼容的.编译器不会产生与OS相关的二进制
代码,但是它可能会以不同的格式打包
代码(例如,PE与ELF).
区别在于使用哪些库.为了使用操作系统的东西(例如I / O),您必须链接到操作系统的库.毫不奇怪,Windows系统库在Linux机器上不可用(除非您有Wine),反之亦然.