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

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

 

 

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);

`void **` 是指向 `void` 指针的指针,通常用于动态内存分配或函数返回多个值的情况。而 `char *` 是字符数组的指针,常用于存储字符串或字符数据。将 `void **` 转换为 `char *` 是为了访问其中存储的内容,但这只有在 `void **` 指向的确实是一个字符串(即 `void *` 包含了一个字符数组的地址)的前提下才能进行。 转换的过程一般分为以下几步: 1. **检查类型安全**:首先确认 `void **` 指向的是 `char` 或 `char[]` 结构,如果不是,不能直接转换,否则可能导致程序错误。 2. **解引用**:使用 `(*p)`, 其中 `p` 是 `void **`,获取实际的 `void *` 地址。 3. **假设 `void *` 存储的是 `char *`**:如果 `void *` 是一个字符串的首地址,那么它就可以被视为 `char *`。注意这不是强制类型转换,而是依赖于原始数据的结构。 4. **复制数据**:如果要确保安全性,可以选择拷贝字符串到一个新的 `char` 数组,然后返回新数组的指针。例如,可以用 `strcpy` 函数或手动遍历直到遇到空字符 `\0` 来完成复制。 5. **释放旧资源**:如果 `void *` 原本是由其他函数分配的,记得在转换后释放它,以避免内存泄漏。 示例代码(仅用于演示,实际上应结合具体情况和异常处理机制): ```c++ void **p_void_ptr; // 假设已填充了有效值 char *str; if (p_void_ptr != NULL && *(p_void_ptr) != NULL) { str = static_cast<char*>(*(p_void_ptr)); // 解引用并假设是 char* // 如果想确保安全,可以先复制数据 if (str) { char temp[strlen((char*)*(p_void_ptr)) + 1]; // 加上 null 字符 strcpy(temp, str); str = temp; } } // 注意:在使用完str之后,要确保释放原始的(void *)资源 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值