指针从函数返回后为NULL

Pointer is NULL after returning from a function

本文关键字:NULL 返回 函数 指针      更新时间:2023-10-16

我向一个函数发送int***,该函数完成它的工作,但当我试图在函数后面的外部使用指针时,它是NULL。以下是功能:

void pointerSort2(int* arr, unsigned int size, char ascend_flag, int*** pointers)
{
int  i, j, *temp;
int** sort=new int*[size];
for (i=0;i<size;i++)
sort[i]=&arr[i];                                                     
if (ascend_flag==true)
{
for (i=0;i<size-1;i++)
{ 
for(j=0; j<size-1-i;j++)
{
if (*sort[j]>*sort[j+1])
{
temp=sort[j];
sort[j]=sort[j+1];
sort[j+1]=temp;
}
}
}
pointers=&sort;
}

当我尝试在之后使用它时,指针是"0x000000(??)">

函数参数int*** pointers是函数的局部变量。此变量将在退出函数后销毁。

我认为这不是线

pointers=&sort;

应该有

*pointers = sort;

首先,如果这不是用于分配,那么已经存在将为您完成所有这些的容器和算法:

容器:std::vectorstd::liststd::deque排序算法:std::sort

大多数问题只需使用标准库模板即可解决。

除此之外,您似乎也没有很好地理解按值传递和按引用传递之间的区别以及指针语义。

int***传递给接受int***的函数

如果您将函数声明为

void func(int i);

并称之为:

int j = 0;
func(j);

funci参数所做的任何事情都没有反映在j中。j副本被传递给func。如果要存储funci参数所做的任何更改,则需要使用引用或指针:

void func(int& i);
// or
void func(int* pI); // requires you to call it via func(&j)

您当前的代码也是如此:

您已声明您的排序函数如下

void pointerSort2(..., int*** pointers);

如果你这样称呼它

int*** myPointer = NULL;
pointerSort2(..., myPointer);

你是在按价值传递。这将把指针的值(当前为NULL)复制到函数的局部变量pointers中。当函数返回时,myPointer保持不变。如果您的目标是在myPointer中保留更改后的值,则需要通过引用传递或传递指向int***的指针(注意:这种间接级别已经是一种代码气味了!)对此的潜在解决方案是:

void pointerSort2(..., int***& pointers);
// or
void pointerSort2(..., int**** pointers);

这将允许您以以下方式(分别)调用函数:

int*** myPointer = NULL;
pointerSort2(..., myPointer);
// or
pointerSort2(..., &myPointer);

对于第一个版本,您可以将pointers的值设置为sort的值,如下所示:

pointers = sort;

由于pointers是对myPointer的引用(别名),因此myPointer的值被改变。

对于第二个版本,您可以将pointers的值设置为sort的值,如下所示:

*pointers = sort;

由于pointers是指向myPointer位置的指针,因此您正在设置myPointer的实际值。

请注意,在这两种情况下,都将值设置为sort(指针的值),而不是&sort(指针的地址)。

旁注

CCD_ 32是用于CCD_ 33和CCD_ 34值的类型。您的ascend_flag参数最好用作bool,而不是char

以下行:

pointers = &sort;

导致了您的问题。CCD_ 38是指向指针的指针。因此,它是在函数的局部范围内创建的变量。

当函数退出时,它会被销毁。

尝试移除&

我们想转到本地指针变量,找到它指向的内容,然后更改该值。指针不是通过引用传递的,它和任何其他参数一样,在堆栈上的每个运行时函数调用中都会被复制和销毁。

*pointers = sort;