以void * 存储的数据在复制时需注意的问题

本文介绍了一个链表结构及其遍历算法,特别关注了如何从链表中获取整数表示,并讨论了不同类型转换的方法。

 

 

 

typedef struct _node  

{

void *data;

struct _node *next;

/* struct _node *pre;*/

}NODE;

 

typedef struct 

{

NODE *head;

NODE *last;

int size;

}LIST;

 

 

 

int getNumFromList(LIST *l)

{

NODE *n = l->head;

int  tens = 1, num = 0, i;

int temp;

for(i=0; i<l->size-1; i++)

{

tens *= 10;

}

while(n)

{

temp = (int *)(n->data);

temp *= tens;

tens /= 10;

num += temp;

n = n->next;

}

 

return num;

}

 

 

当temp为int时 temp = (int *)(n->data);或temp = (int )(n->data);都是将n->data的内存地址付给temp

所以 复制数据时应用相应的指针变量

int *temp;      

temp = (int *)(n->data);或temp = (int )(n->data);

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值