在C语言中,局部变量的作用域只在函数内部,在函数返回后,局部变量的内存就会被释放。如果函数只是返回局部变量,那么这个局部变量会被复制一份传回被调用处。但是如果函数返回的是局部变量的地址,那么就会报错,因为函数只是把指针复制后返回了,但是指针指向的内容已经被释放,这样指针指向的内容就是不可预料的内容,程序就...
当然可以,只是,这里不行。 这里的地址是一个局部变量 str 的地址,我们都知道,局部变量是存储在栈里的,当函数执行时,其中的局部变量会执行压栈操作,但是,当函数执行完毕后,栈中的数据会弹出,以便腾出栈空间。 所以,当函数执行完毕后,指针指向的地址当然是存在的,只是它指向的数据已经不在了。 真的是这样吗? ...
1、返回局部变量的地址 1#include<stdio.h>23int*local_address(void)4{5intnum;6printf("Sub function address: %p\n",&num);7return#8}910intmain(void)11{12int*pn=NULL;13pn=local_address();14printf("Main function address: %p\n",pn);15*pn=100;16printf("*pn = %d\n",*pn);17r...
#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);printf("before: *pb = %d...
[C语言]内存问题之返回局部变量地址 来看这样一段代码 intfunc() {inta =2;return&a; }voidmain() {int* p =fun();*p =20; } 1. 2. 3. 4. 5. 6. 7. 8. 这段代码非常简单,func 函数返回一个指向局部变量的地址,main 函数中调用 func 函数,获取到指针后将其设置为 20。
C/C++返回局部变量的引用/地址 程序1 下面这段程序,返回局部变量的引用,将其赋给指针p,第一次打印可以输出a的值,第二次便是一个随机数: #include<iostream> using namespace std; int *p = NULL; int& foo() { int a = 10; return a; }
c[]数组的存放地址是被传送出去了的,但是,由于c[]是局部变量, 在函数执行完成后,存放的内存空间就被释放,所以,在外部通过指针访问c[]数组时,指向的内存空间无效,而且还可能出现访问非法内存的危险。虽然这样能够运行,但是没有实际效果 test3可以运行。*c指针c是保存在栈中,"abcdef"字符串保存在文字常量区,其...
返回int不会warning,是因为函数的返回机制是将返回的值存储到寄存器中,控制权回到调用函数时,调用函数从寄存器中取得函数返回的int,函数执行完毕其中局部作用域的变量所占内存已被释放返回一个具有局部作用于的字符串的指针,当函数执行结束时,函数中为变量分配的内存已被释放,此时字符串已经不存在,其占用的内存已经被释...
return (char*)u8buf; 因为 u8buf是局部变量, 出函数体后, 变量占用的空间就被释放了, 你把u8buf地址返回 会有警告的.另外这个定义const char* u8buf[128]; 我不知你是不是这样想的, 这是定义了一个指针数组而不是字符数组, u8buf 是可以放128个指针的数组....