首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

指针会更改它所指向的地址值

指针会更改它所指向的地址值

基础概念

指针是编程语言中的一个重要概念,特别是在C和C++等语言中。指针是一个变量,其值为另一个变量的地址。通过指针,可以间接访问和修改该地址处的数据。

相关优势

  1. 动态内存管理:指针允许程序员动态分配和释放内存,这在创建复杂数据结构时非常有用。
  2. 提高效率:通过指针传递大型数据结构比复制整个结构更高效。
  3. 实现回调函数和高阶函数:指针可以用来传递函数地址,从而实现回调机制。

类型

  • 指向变量的指针:指向一个具体的变量。
  • 指向数组的指针:指向数组的首元素。
  • 指向函数的指针:指向一个函数。
  • 指向指针的指针:指向另一个指针。

应用场景

  • 数据结构:如链表、树、图等。
  • 函数参数传递:通过指针传递参数,可以实现参数的修改和优化。
  • 动态内存分配:使用mallocfree等函数动态分配和释放内存。

问题与解决

问题:指针会更改它所指向的地址值。

原因

  1. 重新赋值:程序员可以显式地将指针重新赋值为另一个地址。
  2. 动态内存分配:使用malloc等函数分配内存后,指针会指向新分配的内存地址。
  3. 指针运算:通过指针运算,指针可以移动到不同的地址。

解决方法

  1. 确保指针初始化:在使用指针之前,确保其已经正确初始化。
  2. 检查指针的有效性:在使用指针之前,检查其是否为空或指向有效的内存地址。
  3. 避免野指针:确保指针在使用过程中不会指向未知的内存区域。

示例代码

代码语言:txt
复制
#include <stdio.h>
#include <stdlib.h>

int main() {
    int a = 10;
    int *ptr = &a; // ptr指向a的地址

    printf("Initial address: %p\n", ptr);

    int b = 20;
    ptr = &b; // ptr重新指向b的地址

    printf("Updated address: %p\n", ptr);

    return 0;
}

参考链接

通过上述解释和示例代码,可以更好地理解指针及其地址值的更改机制。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

函数返回指向一个指针

定义了一个函数指针类型 callback,它指向一个没有返回,带有一个整型参数函数。...函数指针是指一个指向函数指针变量,它存储了函数地址,可以用来调用函数。函数指针定义方式与普通指针定义方式相似,只是需要在指针类型前面加上函数返回类型和参数列表。...int (*p)(int, int); 定义了一个名为 p 指向函数指针变量,这个函数返回类型是 int,有两个整型参数。这个函数指针可以指向一个具有相同返回类型和参数列表函数。...指针作为参数传递进函数时,实际上传递指针指向内存地址,函数可以通过指针来访问、修改指针指向内存中数据。 定义了一个名为 swap() 函数,它有两个参数,都是指向整型变量指针。...在 main() 函数中,定义了两个整型变量 x 和 y,并输出它们初始。然后,将 x 和 y 地址传递给 swap() 函数,让它交换这两个变量

67820

为什么无返回链表插入操作头结点一定要用指向指针指针

前言: 为什么链表插入操作头结点一定要用指向指针指针?之前自己对这个问题总是一知半解,今天终于花了点时间彻底搞懂了。 总的来说这样做目的是为了应对“空链表”情况。...为了防止往一个空链表中插入一个结点时,新插入结点那就是链表指针,这时如果链表结点是一级指针的话,那么出了链表插入函数作用域后,头结点又回到了原来。...比如下面的一段程序 1 // 链表指针为什么是指向指针指针.cpp : 定义控制台应用程序入口点。...这就是因为第20行直接将新节点赋值给Phead,导致出了insert函数后,Phead又变成了NULL结点,而没有达到想要指向新结点效果。...如果还是不太明白的话,那就先看看“函数是按传递”这方面的东西,函数按传递时候拷贝一份实参副本到形参中,而不是直接把实参赋给形参

1.3K70
  • 套接字地址结构长度之类-结果参数要用指针来传递原因

    当一个进程进行系统调用,把参数从用户空间传递到内核时,往往传递是一个,即按传递。...当一个进程进行系统调用,把上次从用户空间传递到内核时参数,从内核传递到用户空间时,传递指向该参数指针,即按址传递。...这个”——结果“参数用在套接字地址结构相关函数中,往往会将一个套接字地址结构指针和该结构长度作为函数参数。...当这个函数是将该结构从用户空间传递到内核空间时,传递长度是一个,主要目的是:由于有可能该结构是变长,比如Unix,Datalink套接字地址结构就是变长,告诉内核这个结构占用最大空间,如果对该结构进行写操作的话...而调用其他函数对该套接字结构,进行从内核空间到用户空间传递的话,这个长度参数是一个整型指针了,这个指针指向地址结构中表示长度成员。这个长度成员告诉了这个结构最终是用了多少空间。

    99610

    C++反汇编第三讲,反汇编中识别虚表指针,以及指向虚函数地址

    C++反汇编第三讲,反汇编中识别虚表指针,以及指向虚函数地址 讲解之前,了解下什么是虚函数,什么是虚表指针,了解下语法,(也算复习了) 开发知识为了不码字了,找了一篇介绍比较好,这里我扣过来了...总结: 1.没有虚表指针     1.1没有虚函数情况下没有虚表指针   2.有虚表指针     2.1虚表指针产生是看你有没有 virtual这个关键字     2.2虚表指针存储是虚表地址...熟悉了虚表指针, 通过虚表指针找构造,析构,以及虚表指针指向虚表找虚函数,那么我们看一下普通成员函数调用和虚函数调用有什么区别....认真观察可以看出   1.普通成员函数调用,直接Call    2.虚函数调用     2.1 首先获得虚表指针     2.2 间接调用虚表指针指向虚表内容(虚成员函数地址) 总结:   识别调用普通成员函数和虚函数特征则是...  1.普通成员函数直接调用Call   2.虚函数会通过虚表指针指向虚表来间接调用.

    1.5K60

    C Primer Plus(六)

    而对于数组来说,必须传递指针。有时传递地址导致一些问题,例如无意修改了源数据。在 K&R C 年代,避免类似错误唯一方法是提高警惕。ANSI C 提供了一种预防手段。...[9] = 44; /* 编译错误 */ 指向 const 指针不能用于改变,例如: double rates[5] = {88.99, 100.12, 59.45, 183.11, 340.5...}; const double * pd = rates; //使用 const 表明不能使用 pd 来更改它所指向 *pd = 29.89; // 不允许 pd[2] = 222.22; /...首先,把 const 数据或非 const 数据地址初始化为指向 const 指针或为其赋值是合法: double rates[5] = {88.99, 100.12, 59.45, 183.11...没问题,更改rates[0] 最后,在创建指针时还可以使用 const 两次,使得该指针既不能更改它所指向地址,也不能修改指向地址: double rates[5] = {88.99, 100.12

    30730

    Java 中是“传递”还是“引用传递”?

    我选择了一个比较经典答案,整理给大家! ? 最重要一点理解是 Dog myDog,它实际上是指向“Dog”指针。...参数 someDog 设置为 42,在代码 “AAA” 处,someDog 跟随 Dog,它指向(Dog 地址 42 处对象),要求Dog(地址为 42 那个)将他名字改为 Max。...在代码“BBB” 处,Dog 创建了一个新。假设它所地址是 74,我们将参数分配 someDog 给 74。...Java 工作方式与 C 完全相同。您可以分配指针,将指针传递给方法,按照方法中指针操作并更改指向数据。但是,您无法更改指针指向位置。 Java 总是按而不是通过引用传递参数。...Java 把引用地址当做进行了传递,这么说,你应该就明白了! 上面我解释,可能遇到大家!时间关系,我推荐大家去阅读原文吧。

    76720

    C:数组与指针指针与const

    数组与指针 我们都知道一个指针是代表一个地址指针,顾名思义,指向一块区域。那么数组呢?数组并不是代表一堆变量,数组其实也是一种指针指向一个地址,一般是指向数组地址,也就是 a[0]地址。...a==&a[0] a 是一个指针指向数组 a 地址。 下面四种函数原型都是等价,第一个参数均为一个地址指针)。...比如定义指针 p 指向数组 a 第三个单元。 int a[5];int p=&a[2];//如果对指针 p 赋值,则是更改 a[2]。...如以下代码: int a=10; int * const p=&a; *p=25;//通过,因为我们改变指针指向地址所对应a,a并不是一个常量。 p++;//Error!...编译器无法通过,因为指针p是一个常量(const),它所指向地址无法被改变。

    80810

    初级程序员面试不靠谱指南(一)

    const *ci_pointer=&i;//指向东西(地址)可以被修改,不可以被修改       从上面的代码开始分析,我们分别声明了这两种指针,注释说明了这两种指针不同,也正如很多书中写那样...它所占内存里面所包含应该是它所指向内容地址,也就是我们这里格子编号,也就是E1,E4pointer格子里面的是E1(不是0,而就是E1这个),同理后面两个格子也都是E1这个。...如下图所示: image.png      从格子E3开始,E3是个const,也就是说这里面的这个0是不可以更改,这很好理解,接下来,我们查看E4格子,从声明看,这是一个指针指向E1格子里面的...既然const类型是不能改变该内存所存储,那么const指针也是不能改变该内存所存储,也就是我们不能把E1改成E2,也就是说其指向地址不能被改变,但是指向能不能改变呢?...,只规定了其指向是const,虽然它不知道它指向是不是const,但是从它来看,它指向是不能更改,也就是你不能通过我来改我指向,但是我格子本身可以随便改,比如将E1改成E2,这也就是说可以修改其指向

    87590

    借问变量何处存,牧童笑称用指针,Go lang1.18入门精炼教程,由白丁入鸿儒,go lang类型指针(Pointer)使用EP05

    指针是指什么?指针是存储另一个变量内存地址变量。变量是一种使用方便占位符,用于引用计算机内存地址,一个指针变量可以指向任何一个内存地址指向那个内存地址。...,其实就是它所变量基本类型,二者类型是一致。    ...指针操作     获取一个指针意味着访问指针指向变量。...,将a变量指针对象传递到方法内,方法内修改其实是内存地址变量,如此就可以将类型对象对应更改,节省了额外内存申请空间。    ...假设我们想对方法内数组进行一些修改,并且对调用者可以看到方法内数组所做更改

    45540

    深入解析C语言数组和指针(0)

    间接访问操作符 通过一个指针访问它所地址过程称为间接访问或解引用指针。操作符为*。根据前面的声明我们有: ?   我们可以知道,d为100。...这个值得存储位置我们不清楚,所以它是非法。 ?   加入了间接操作,右及为它所指向地址'a',左为其指向地址。 ?   ...第三行中,先执行括号中*f,再执行后面的函数调用(),所以f是一个函数指针它所指向函数返回一个整型。因为函数存放于内存中某个位置,所以完全可以拥有指向那个位置指针,即函数指针。   ...第四行结合上个声明很好理解,f还是个函数指针它所指向函数返回是一个整型指针。 ?   ...所以函数一颗自由操纵它指针形参,而不必担心修改对应作为实参指针。但是也可以通过形参改变数组对应位置,从而更改数组。

    1.3K30

    指针深入解读笔记

    指针是什么 指针指向内存单元编号(地址),可以快速访问地址,加快程序运行速度....,而且在32位平台下是4字节 64位平台下是8字节 而且指针大小与它所指向东西无关,只于它运行平台有关 指针类型意义 指针变量类型虽然与大小无关,但是却决定每次或下次访问时访问字节大小有关.../决定是p指向地址不可更改,但是地址包含东西可以更改指针指向未知位置指针,一般是由于没有初始化,越界访问,指向了已经被释放空间等.我们要规避野指针存在,可以初始化时候赋值...= NULL);//如果p不是空指针就报错 如果assert接收返回是0就回报错,不是0就继续运行,而且要关闭断言可以使用 #define NDEBUG 数组名指针 首先举个小例子...每次 + 1跳过一个元素 int *pppp = &arr;//取到了整个数组首元素地址 每次+1跳过一个数组 我们根据例子也可以倒推如何使用指针去找元素,就和+1 -1和取得是什么类型指针有关

    9500

    c++基础之变量和基本类型

    k = 0; //错误,引用必须与变量绑定 指针类型 指针是一个特殊类型,它本身是一个对象,对象中存储是另一个对象地址。...指针本身应该是一个无符号整数,指针大小与程序中地址所占内存空间一致,32位程序中指针是4字节,64位程序,指针大小为8字节 使用指针限制比引用要宽泛指针可以指向对象,也可以指向另一个指针 指针不需要初始化...,而且后续可以随意更改指向(当然必须指向同一数据类型) 可以多个指针指向同一个对象 指针只能指向对象,指针本身也是一个对象。...所以顶层则是对指针本身进行修饰,底层则是对它所指向对象修饰。...指针constexpr只对指针本身有效,对它所指向对象无效 int i = 10; const int *p = &i; //指向整型常量指针 constexpr int *p = nullptr

    1.5K30

    深入探究C语言中常量指针与野指针概念及其应用

    这种指针类型是指向常量指针类型,例如 int * const p;。这意味着你不能通过这个指针来修改它所指向数据。 2....这意味着你不能修改指针 p 所指向数据。...未初始化指针:定义指针变量时,如果没有进行初始化,那么该指针是随机,可能指向任意内存地址。这种情况下,如果尝试通过这个指针去读取或写入数据,可能导致程序崩溃或其他不可预期行为。 2....触发段错误:当野指针指向一个不可访问内存地址时,尝试对其进行解引用操作可能导致段错误,这是因为程序试图访问一个非法内存区域。 2....谨慎解引用:在使用指针前,应当确保它指向是一个有效内存地址,避免对无效地址进行解引用操作。 4.

    18010

    (迷惑标题大赏)数组就是指针

    但是可以把它们赋值给指针变量(即自己定义指针变量),然后再去修改指针变量进而达到改变常量。...而指针+1增加则是一个存储单元,对于数组+1就是下一个元素地址,而不是按字节来算。 所以大家在定义数组时一定要声明指向对象类型,否则指针不知道要存储对象需要多少字节。...简述: 指针它所指向对象地址。 在指针前面用*可得到该指针指向对象指针+1,指针增加它所指向类型大小(以字节为单位哦)。...注意这里不是它们,我们知道数组可以表示为family[1],那么和family[1]相同指针表示法则为*(family+1)。...To:间接运算符(*)优先级高于+。 ? 最后的话:学到指针这一节童鞋需要多多理解哦,理解之后再刷题事半功倍。 ?

    25241

    CC++野指针

    指针:野指针不同于空指针,空指针是指一个指针为null,而野指针并不为null,野指针指向一段实际内存,只是它指向哪里我们并不知情,或者是它所指向内存空间已经被释放,所以在实际使用过程中...避免野指针只能靠我们自己养成良好编程习惯,下面说说哪些情况下产生野指针,以及怎样避免。 1....指针变量未被初始化:声明一个指针时候,没有显示对其进行初始化,那么该指针指向地址空间是乱指一气。...如果指针声明在全局数据区,那么未初始化指针缺省为空,如果指针声明在栈区,那么该指针随意指向一个地址空间。...= nullptr) { ……do_somthing } } 2.指针指向地址空间已经被free或delete:在堆上malloc或者new出来地址空间,如果已经free或

    58020

    C++指针详解

    指针指向内存区就是从指针所代表那个内存地址开始,长度为sizeof(指针指向类型)一片内存区。...以后,我们说一个指针是XX,就相当于说该指针指向了以XX为首地址一片内存区域;我们说一个指针指向了某块内存区域,就相当于说该指针是这块内存区域地址。...*p运算结果就五花八门了。总之*p结果是p所指向东西,这个东西有这些特点:它类型是p指向类型,它所占用地址是p所指向地址。...*p=24;//*p结果,在这里它类型是int,它所占用地址是p所指向地址,显然,*p就是变量a。 ptr=&p;//&p结果是个指针,该指针类型是p类型加个*,在这里是int**。...*str也是一个指针,它类型是char*,它所指向类型是char,它指向地址是字符串"Hello,this is a sample!"第一个字符地址,即'H'地址

    49420

    第七节(指针

    那么,指针如何储存多字节变量地址? 实际上,变量地址它所占用字节地址(最低位地址)。.../*其他代码已略去*/ 指针中储存它所指向变量第1个字节地址。...函数使用是真正数组元素,因此可以在函数中修改储存在该数组中。 八:小结 本次介绍了C语言重点内容一一指针指针是储存其他变量地址变量。指针指向它所储存地址变量。...5:确定变量地址要使用什么运算符? 取址运算符是& 6:通过指针确定它所指向位置上,要使用什么运算符? 要使用间接运算符*。在指针名前写上*,引用是该指针指向变量。 7:什么是指针?...直接访问:cost = 100; 间接访问:*p_cost = 100; 4.根据练习题3,打印指针它所指向

    19040

    指针

    _ *p = 20,此处 * 是解引用操作符。 &为取地址操作符 指针类型是根据原来类型来确定用什么类型指针。如:char类型,那就用char* 。...去掉指针变量名剩下就是指针类型 关于指针类型声明有人可能问用不同类型声明可以吗?当然可以,但是会出现一些问题。...,它所指向空间被返还给操作系统 再次对它解引用进行访问就造成非法访问。...要改变ip1要解引用2次才可以改变 2. 字符指针 能够指向字符数据指针 形如这样char* p 这里就讲比较难地方吧!...但是p1,p2可不能储存"abcef"这样常量字符串,它们只是储存了首字符地址,所以p1和p2相等.并且p1,p2所指向内存数据不能更改,因为初始化常量字符串是不能更改,可以这样写 c const

    29460
    领券