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

Linux:C语言实现面向接口编程

面向接口编程不是什么新鲜玩意,说得直白点就是函数指针的使用,不过我觉得可以形成一种编程的思想来指导嵌入式程序设计,特别是对于降低代码的耦合还是比较奏效的。

代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int start(void * p);//接口函数,乙方实现具体的逻辑
int working(void * p);//接口函数,乙方实现具体的逻辑
int befree(void * p);//接口函数,乙方实现具体的逻辑
struct ApiFunc * initial (void * p,void * a, void * b, void * c, char * s); //初始化函数,甲方调用传入参数

//面向接口编程,先定义出接口
struct interface
{//包含三个接口函数
int (* start)(void );
int (
working)(void );
int (
befree)(void *);
};

//再定义出一个结构体用来传递参数
struct ApiFunc
{
struct interface inter1;
char name[20];
int a;
int b;
int c;
};

struct ApiFunc * initial(void * p,void * a, void * b, void * c, char * s)//初始化函数,接收甲方调用的参数并初始函数指针
{
struct ApiFunc *Ap = (struct ApiFunc *)p;
Ap->a = *(int *)a;
Ap->b = *(int *)b;
Ap->c = *(int *)c;
strcpy(Ap->name,s);
printf(“%s\n”,Ap->name);
Ap->inter1.start = start;
Ap->inter1.working = working;
Ap->inter1.befree = befree;
return Ap;
}

int start(void * p)
{
struct ApiFunc *Ap = (struct ApiFunc *)p;

printf("%d:%s %s\n",Ap->a,Ap->name,"start work");

return 0;

}

int working(void * p)
{
struct ApiFunc *Ap = (struct ApiFunc *)p;
printf(“%d:%s %s\n”,Ap->b,Ap->name,“is working”);
return 0;
}

int befree(void * p)
{
struct ApiFunc *Ap = (struct ApiFunc *)p;
printf(“%d:%s %s\n”,Ap->c,Ap->name,“is free!”);
return 0;
}

int main(int argc, const char * agrv[])
{
int a = 1;
int b = 2;
int c = 3;
char buf [20] = {“I am a worker”};
struct ApiFunc myapi;
struct ApiFunc * p = initial(&myapi,(void *)&a,(void *)&b,(void *)&c,buf);//调用initial函数初始化ApiFunc结构体
myapi.inter1.start§;
myapi.inter1.working§;
myapi.inter1.befree§;
}

结果:

在这里插入图片描述


http://www.kler.cn/a/1543.html

相关文章:

  • FPGA的 基本结构(Xilinx 公司Virtex-II 系列FPGA )
  • 【HTML+CSS+JS+VUE】web前端教程-2-HTML5介绍和基础骨架
  • 第3章:Go语言复合数据类型
  • 单片机软件定时器V4.0
  • Boost.Asio 同步读写及客户端 - 服务器实现详解
  • 软件23种设计模式完整版[附Java版示例代码]
  • 【Linux】写一个基础的bash
  • 文法和语言的基本知识
  • 2023前端面试题(硬货-持续更新)
  • 怎样在外网登录访问CRM管理系统?
  • 【Linux】进程的基础概念 进程的相关操作 进程的状态
  • oracle和mysql的区别
  • 【Vue3】利用vite创建vue3项目
  • (算法基础)Bellman-ford算法
  • vue后台管理系统——添加i18n国际化功能——技能提升
  • #D. 竞选班长
  • Linux中的标准IO【下】
  • CSDN-猜年龄、纸牌三角形、排他平方数
  • GEE:计算1990-2021年的指数最大值和最小值,并根据最大最小值对每一副影像归一化
  • 微信小程序项目实例——扫雷
  • Redis高级
  • 操作系统之内存
  • c++11_14学习之c++14新特性
  • 基础篇:09-Feign远程调用
  • C++线程池理解
  • 《Roller: Fast and Efficient Tensor Compilation for Deep Learning》