【为什么】指针,动态内存的例子

简介: 【为什么】指针,动态内存的例子
#include <stdio.h>
int *pPointer;
void SomeFunction();
{
    int nNumber;
    nNumber = 25;    
    // make pPointer point to nNumber:
    pPointer = &nNumber;
}
void main()
{
    SomeFunction(); // make pPointer point to something
    // why does this fail?
    printf("Value of *pPointer: %d\n", *pPointer);
}

这个程序的问题:

您没有正确地初始化指针变量pPointer,这可能导致它指向一个无效或随机的内存地址。

您在SomeFunction函数中让pPointer指向一个局部变量nNumber,但是当该函数结束后,nNumber就会被销毁,而pPointer就会成为一个悬空指针(dangling pointer),也就是指向一个已经释放的内存区域。

您在main函数中试图打印*pPointer的值,但是由于pPointer是一个悬空指针,这可能导致未定义行为(undefined behavior),例如程序崩溃或错误输出。

要解决这些问题,您可以尝试以下几个方法:

在声明指针变量时,给它赋一个初始值NULL或nullptr,以表示它不指向任何有效的内存地址。

如果您想让pPointer指向SomeFunction函数中的一个变量,并且在该函数结束后仍然有效,那么您可以使用动态内存分配(dynamic memory allocation),例如使用new运算符来创建一个int类型的对象,并返回它的地址给pPointer。但是请注意,在使用完该对象后,您需要使用delete运算符来释放它所占用的内存空间,以避免内存泄漏(memory leak)。

如果您不想使用动态内存分配,那么您也可以将nNumber定义为一个静态变量(static variable),这样它就不会在SomeFunction函数结束后被销毁,而是一直存在于程序的生命周期中。但是请注意,在多线程环境下使用静态变量可能会导致竞争条件(race condition)或数据不一致(data inconsistency)。

new bing提供的解决办法:

#include <stdio.h>
int *pPointer; // declare a pointer variable
void SomeFunction();
{
    int *nNumber; // declare a pointer to int
    nNumber = new int; // allocate memory for an int object using new
    *nNumber = 25; // assign 25 to the int object
    // make pPointer point to nNumber:
    pPointer = nNumber;
}
void main()
{
    SomeFunction(); // make pPointer point to something
    // print the value of *pPointer:
    printf("Value of *pPointer: %d\n", *pPointer);
    delete pPointer; // free the memory allocated by new
}

在SomeFunction函数中,我使用了new运算符来为一个int类型的对象分配一块内存空间,并将它的地址赋给nNumber指针。然后我将25赋给该对象,并让pPointer指向nNumber。

在main函数中,我打印了*pPointer的值,并在使用完该对象后,使用了delete运算符来释放它所占用的内存空间。

这样就避免了悬空指针和未定义行为的问题。

原文中的解决办法:

#include <stdio.h>
int *pPointer;
void SomeFunction()
{
// make pPointer point to a new integer
    pPointer = new int;
    *pPointer = 25;
}
void main()
{
    SomeFunction(); // make pPointer point to something
    printf("Value of *pPointer: %d\n", *pPointer);
    delete pPointer;
}
相关文章
|
6天前
|
存储 Java C++
C++ 引用和指针:内存地址、创建方法及应用解析
C++中的引用是现有变量的别名,创建时需用`&`运算符,如`string &meal = food;`。指针存储变量的内存地址,使用`*`创建,如`string* ptr = &food;`。引用必须初始化且不可为空,而指针可初始化为空。引用在函数参数传递和提高效率时有用,指针适用于动态内存分配和复杂数据结构操作。选择使用取决于具体需求。
41 9
|
6天前
|
存储 Go iOS开发
掌握Go语言:探索Go语言指针,解锁高效内存操作与动态数据结构的奥秘(19)
掌握Go语言:探索Go语言指针,解锁高效内存操作与动态数据结构的奥秘(19)
|
6天前
|
安全 程序员 C++
C++中的智能指针:从原始指针到现代内存管理
C++中的智能指针:从原始指针到现代内存管理
20 0
|
6天前
|
安全 C++ 容器
C++中的智能指针:自动内存管理的利器
C++中的智能指针:自动内存管理的利器
26 0
|
6月前
|
存储 编译器 C语言
深入理解C++内存管理:指针、引用和内存分配(下)
深入理解C++内存管理:指针、引用和内存分配
|
7月前
|
存储 搜索推荐 Serverless
用指针和动态内存分配的方法输入10,2,30, 4,5,按输入顺序逆置排序,输出排序后的元素,即输出5,4,30,2,10
用指针和动态内存分配的方法输入10,2,30, 4,5,按输入顺序逆置排序,输出排序后的元素,即输出5,4,30,2,10
33 0
|
6天前
|
Java Go 区块链
【Go语言专栏】Go语言中的指针与内存管理
【4月更文挑战第30天】Go语言,由Google开发,是一种静态强类型、编译型、并发型语言,具有垃圾回收功能,常用于云计算、微服务、区块链等领域。本文聚焦Go中的指针和内存管理。指针表示变量内存地址,可用于直接访问和修改变量,如示例代码所示。指针运算有限制,仅支持相同类型变量和数组元素访问。内存管理由Go运行时的垃圾回收机制处理,自动回收无引用对象,简化管理但引入性能开销。可通过`runtime.GC()`手动触发垃圾回收。
|
6天前
|
存储 安全 编译器
C++智能指针:更简单、更高效的内存管理方法
C++智能指针:更简单、更高效的内存管理方法
37 0
|
6天前
|
C语言
指针与内存
指针与内存
19 0
|
6天前
|
存储 定位技术 C语言
C语言内存中的地图,方向盘,初始指针详解(1)
C语言内存中的地图,方向盘,初始指针详解(1)

热门文章

最新文章