提示:静态变量用static修饰。 #include"stdio.h"//返回静态局部变量a的地址int*f1(){staticinta=9;int*pa=&a;printf("a = %d\t&a = %p \n",a,&a);printf("*pa = %d\tpa = %p \n",*pa,pa);returnpa;}intmain(){intb=5;int*pb=&b;printf("before: b = %d\t&b = %p\n",b,&b);...
函数的返回值不能是局部对象或者是局部变量的指针或引用!!! 原因: 调用函数的局部变量是存在于栈中的,在执行完调用函数之后会将局部变量的空间释放,也就是调用函数执行后局部变量将不存在与内存中。如果返回的是局部变量的指针或者是引用。返回给接收对象的是局部变量的地址,而这个地址的资源已经被释放了,也就是接...
所以这个函数体在呢内存中就销毁了。你即使能从函数中返回一个局部变量。你再去读这个地址的时候。东西都不在了。3、还有一点。编译器在分配函数的空间的时候,地址不是固定的。所以你每次运行程序,你会发现 int a=3 printf(f"%d",&a),不都是一样的。所以你的问题很明了了。
局部变量: 局部变量分为局部自动变量和局部静态变量,无论自动还是静态,返回局部变量都是没有问题的,因为返回值不是地址,虽然在函数调用结束后(栈区)局部变量的内存会被释放回收掉,但函数返回的是变量拷贝副本。 局部指针: 局部指针分为局部静态指针和局部自动指针,可以返回一个局部静态指针的地址,但不应该返回一个局...
函数返回指针是C/C++一个最基本的功能,但这不表示就可以随便返回指针,比如返回函数局部变量的指针就有...
局部变量可以和全局变量重名,但是局部变量会屏蔽全局变量。在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。上面是摘抄 局部变量的特点是:随函数调用时创建 随函数结束时析构(销毁)设想 如果返回了一个局部变量的指针 而恰好 局部变量偏偏又在函数结束后销毁 但指针并没有被销毁 ...
这个时候,子函数才会去向系统申请堆空间存放你在这个函数中定义的变量,这些空间(变量)是有生命周期的,到这个子函数执行完毕,它的生命周期就结束了,申请的堆空间就会被释放,这个时候你指向它的指针当然是无效的;而可以返回局部变量的原因是,你子函数的返回值(子函数局部变量),会被当作父函数的局部变量...
指针函数不可以返回局部变量地址解决 定义局部变量为 static变量。 str指向一个字符串常量,字符串常量和静态变量类似,都是程序结束时,才释放内存 指针函数返回一个堆空间上的地址(malloc申请的) ——这个上课经常用。。原来这个意思 对于第二种情况例子: 在函数里定义char p[] = "hello,world";返回p,p是指向栈...
如果你试图返回局部变量的指针或引用,问题就来了。因为在函数执行结束后,局部变量会被销毁,而指针或引用仍然指向那个已经被销毁的变量,这会导致未定义的行为。💣 下面是一个示例代码,它试图返回局部变量的指针: ```cpp int* getValue() { int localInt = 666; return &localInt; // 错误:返回局部变量的地...