c语言没有类的概念,更没有基类和派生类的概念,但我们可以通过一些手段来实现所谓的派生类
在学libev源码中,可以看到很多c语言实现的基类和派生类的概念。这里简化的实现了一下,并且通过基类的指针强行取到派生类的成员(但这种做法并不可取)
#include <stdio.h>
//这里定义基类的所有成员
#define BASE \
int a;
struct base{
BASE
};
struct extend{
BASE
int b;
};
typedef struct base base;
typedef struct extend extend;
void test(struct extend *s)
{
base *b = (base*)s;
//这里需要先转为char*指针是因为,如果是int指针,+4就成了+4*4个字节
printf("test:%d\n",*(int*)(((char*)(&b->a))+4));
//当然也可以int*指针+1
printf("test:%d\n",*((&b->a)+1));
//验证地址
printf("test:%p\n",(int*)(((char*)(&b->a))+4));
printf("test:%p\n",(&s->b));
}
int main(){
extend e = {1,2};
test(&e);
}
运行结果:
可以看到,取到的值和地址和预想的是一样的
libev中有大量的(extend*)(void*)(base*)这样转换的操作,不太明白中间的void*转换是为什么,可能是为了通过(void *)转换使指针转换更加稳妥不出错?