微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

为什么汇编语言(如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),反之亦然.

原文地址:https://www.jb51.cc/windows/371179.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐