Opaque Pointer / Incomplete Type

核心好处是 完全隐藏结构体内部实现,头文件只需要暴露 接口声明 + 类型名 + 操作方法,源文件才是真正定义接口和操作的文件,从而达到封装+解耦,是c语言模拟面向对象私有成员的核心写法。

  1. 因为头文件隐藏了接口的具体定义,所以外部代码无法直到结构体内部成员,只能使用头文件中的操作方法来操作结构体。
  2. 底层实现可以自由修改,也就是头文件对应的源文件可以自由修改
  3. 减少了头文件的依赖,加快编译速度
  4. 统一接口规范
  5. 代码解耦,独立性强
  6. 头文件中所操作的只能是结构体的指针,不能是结构体本身,因为头文件无法知道结构体具体定义

下面用一个例子来解释,写一个计算两个数的和的接口

sum.h

复制代码
#pragma once

typedef struct sum_t sum_t;

sum_t* sum_create(int a, int b);
int sum_get_result(sum_t* s);
void sum_destroy(sum_t* s);

sum.c

复制代码
#include "sum.h"
#include <stdlib.h>

struct sum_t {
    int a;
    int b;
};
sum_t* sum_create(int a, int b) {
    sum_t* s = (sum_t*)malloc(sizeof(sum_t));
    if (s) {
        s->a = a;
        s->b = b;
    }
    return s;
}
int sum_get_result(sum_t* s) {
    if (s) {
        return s->a + s->b;
    }
    return 0; // or handle error as appropriate
}
void sum_destroy(sum_t* s) {
    free(s);
}

main.c

复制代码
#include <stdio.h>
#include "sum.h"


int main(void) {
    sum_t* s = sum_create(3, 4);
    if (s) {
        int result = sum_get_result(s);
        printf("The sum is: %d\n", result);
        sum_destroy(s);
    } else {
        printf("Failed to create sum_t instance.\n");
    }
    return 0;
}
相关推荐
JieE2121 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack203 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树3 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
clint4564 天前
C++进阶(1)——前景提要
c++