【C++】空指针的理解
空类型指针(void *)的理解_手写的从前66的博客-CSDN博客_空类型指针
void指针是空类型指针,它不指向任何类型,即void指针仅仅是一个地址,所以空类型指针不能进行指针运算,也不能进行间接引用(因为指针运算和间接引用都需要指针的类型信息)。
例如: void * p; //仅仅表示p存放一个地址
1 2 3 | p++; //error:+、-运算离不开指针类型 *p=20.5; //error:访问p指向的变量空间需要变量类型信息 |
由于其他指针都包含有地址信息,所以将其他指针的值赋给空类型指针是合法的;反之,将空类型指针赋给其他指针则不被允许,除非进行显式转换。
例如: int a=20;
int* ptr=&a; void *p=ptr; //OK 将整型指针值赋给空类型指针 ptr=p; //error 不能将空类型指针赋给其他指针 ptr=(int*)p; //OK 显式转换
可以作为函数形参,在使用时进行显式转换。
【面试题】实现memcpy函数 - 恋恋美食的个人空间 - OSCHINA - 中文开源技术交流社区
尽管该链接说memcpy这个函数
If copying takes place between objects that overlap, the behavior is undefined.
对于地址重叠的情况,该函数的行为是未定义的。
但是在VS2019中运行的时候,发现下面代码中
memcpy(buf+2, buf, 5); //Memcpy(buf + 2, buf, 5);
的运行结果是一样的。所以该函数可能已经经过改写不再具有上述问题。
测试代码:
#include <stdio.h> #include <stdlib.h> #include <string.h> using namespace std; void* Memcpy(void* dst, const void* src, size_t size); int main(int argc, char* argv[]) { char buf[100] = "abcdefghijk"; memcpy(buf+2, buf, 5); //Memcpy(buf + 2, buf, 5); printf("%s\n", buf + 2); } void* Memcpy(void* dst, const void* src, size_t size) { char* psrc; char* pdst; if (NULL == dst || NULL == src) { return NULL; } if ((src < dst) && (char*)src + size > (char*)dst) // 自后向前拷贝 { psrc = (char*)src + size - 1; pdst = (char*)dst + size - 1; while (size--) { *pdst-- = *psrc--; } } else { psrc = (char*)src; pdst = (char*)dst; while (size--) { *pdst++ = *psrc++; } } return dst; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异