当前位置: 首页 > news >正文

ABI与API定义及区别

一.概述

1.定义

ABI(Application Binary Interface,应用二进制接口)和 API(Application Programming Interface,应用程序接口)是软件工程中两个核心概念,本质区别在于作用层级与交互对象。

二.关键区别详解

1.作用层级不同

2.变更影响对比

(1)API 变更示例:

// v1.0 API

void process_data(int input);

// v2.0 API (变更参数类型)

void process_data(float input);  // 重新编译即可适配

→ 只需修改调用方代码并重新编译。

(2)ABI 变更示例:

修改结构体字段顺序(影响内存布局):

// v1.0 ABI

struct Point { int x; int y; };  // 内存: [x][y]

// v2.0 ABI (字段顺序变化)

struct Point { int y; int x; };  // 内存: [y][x]

→ 旧版二进制库调用新版结构体将内存解释错误,必须重新编译所有依赖模块。

三.技术要素对比

1.API 包含的要素

函数/方法名称(如 open())

参数类型与顺序(如 int open(const char *path, int flags))

返回值类型(如 ssize_t read(int fd, void *buf, size_t count))

错误处理约定(如返回 -1 表示错误)

2.ABI 包含的要素

(1)调用约定(Calling Convention)

参数传递顺序(寄存器 vs 栈)

返回值存储位置(如 x86: eax;ARM: r0)

栈清理责任方(调用者清理 vs 被调用者清理)

assembly:

; x86_64 System V ABI 示例 (Linux)

; 参数顺序: rdi, rsi, rdx, rcx, r8, r9 → 栈

mov rdi, 123    ; 第一个参数

call function   ; 调用函数

(2)数据表示规范

数据类型大小(如 long 在 Linux x86_64 = 8字节)

结构体/联合体的内存对齐(如 struct { char c; int i; } 对齐到4字节)

字节序(大端/小端)

(3)系统调用机制

系统调用号(如 x86: sys_open 对应 0x05)

陷入内核的方式(如 int 0x80 / syscall)

(4)异常处理

栈回溯格式(DWARF调试信息)

信号处理帧(Signal Frame)结构

四.实际场景示例

1.场景1:Linux 动态库兼容性

API 兼容:

libcurl.so.4 → libcurl.so.5 的函数签名不变,仅内部优化 → 无需重编译应用程序。

ABI 破坏:

libpython3.8.so → libpython3.9.so 修改了 PyObject 结构布局 → Python 3.8 编译的C扩展无法加载到3.9环境。

2.场景2:跨平台开发

API 一致:

使用POSIX API(如 pthread_create)可在Linux/macOS源码级兼容。

ABI 差异:

相同源码在Linux(System V ABI)和Windows(Microsoft ABI)编译后二进制不兼容:

五.总结

1.核心区别与关联

2.关键结论:

API 是开发者之间的契约 → 解决“如何正确调用功能”

ABI 是机器之间的契约 → 解决“如何正确执行指令”

稳定性要求:API 可迭代演进,ABI 必须严格保持兼容,否则引发“DLL Hell”等问题。

相关文章:

  • JVM内存模型与Arthas诊断实战
  • AR/VR显示为何视场受限?OAS对标波导案例来解决
  • Ubuntu 和 CentOS 中配置静态 IP
  • 微信小程序获取指定元素,滚动页面到指定位置
  • 为什么主动关闭 TCP 连接的一方需要 TIME_WAIT 状态?
  • 使用Haporxy搭建Web群集
  • 嵌入Linux快速入门第3篇
  • JavaEE->多线程2
  • 【Bluedroid】蓝牙启动之 btif_init_ok 流程源码解析
  • 小智AI玩具市场爆发:四大品牌领跑情感交互新赛道
  • 3DTiles三维模型
  • Linux 核心知识点整理(高频考点版)
  • Mac电脑 Office 2024 LTSC 长期支持版(Excel、Word、PPT)
  • 《超级处理器》怎么安装到WPS/excel(最后有下载地址)
  • 李宏毅《生成式人工智能导论》| 第1讲:什么是生成式人工智能
  • 一体机主板步入大存储时代,存储突围到性能质变
  • OpenAI 公布《走向理解与预防失准泛化:由“角色特征”驱动的突现性失准》研究总结
  • MySql升级安装、socket 及密码重置
  • 3.1 Hector_mapping初体验
  • langchain框架中各种Agent(LLMSingleAgent ReactAgent Plan-and-Execute Agent)原理方式对比
  • 查看注册过的网站/杭州网站优化
  • 石家庄商城网站搭建多少钱/站长数据
  • 招聘网站开发/投广告的平台有哪些
  • 如何避免网站模板侵权/网络推广费用预算表
  • 自己做的电影网站打开很慢/百度搜索入口
  • 建设网站包括哪些费用/免费的模板网站