【C++】空指针的理解

空类型指针(void *)的理解_手写的从前66的博客-CSDN博客_空类型指针

void指针是空类型指针,它不指向任何类型,即void指针仅仅是一个地址,所以空类型指针不能进行指针运算,也不能进行间接引用(因为指针运算和间接引用都需要指针的类型信息)。

例如: void * p; //仅仅表示p存放一个地址

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

原文链接: https://www.cnblogs.com/nntzhc/p/14072705.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/205641

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年2月12日 下午10:18
下一篇 2023年2月12日 下午10:18

相关推荐