typedef struct node{
struct node* next;
struct node* prev;
}NODE
typedef struct list{
NODE * head;
NODE * tail;
}LIST
typedef struct a{
NODE node;
LIST list;
}A
A * a;
LIST * l;
a=(void*)(l->head)
最后一步这个赋值我就看不懂了
赋值后a指向哪里,它的成员又变成什么了?
这样看,l->head 是NODE,也就是指向一个NODE 的内存,NODE 的内存里面有什么?有nodenext 和 node*prev
a 内存中第一块内存是什么?是一个NODE 的内存
当你这样转换,其实就是指向了 list 中head 所指向的那个NODE