int main()
{
char *p = "hello world";
return 0;
}
p和“hello world”储存在内存哪个区域
答案: 栈,只读储存区
(1)从静态存储区域分配:
内存在程序编译时就已经分配好这块内存在程序的整个运行期间都存在。速度快、不容易出错,因为有系统会善后。例如全局变量, static变量等。
(2)在栈上分配:
在执行函数时,函数内局部变量的存储单元都在桟上创建函数执行结束时这些存储单元自动被释放。 投内存分配运算内置于处理器的指令集中,效率很高,但是分配的内存容量有限。
(3)从堆上分配:
即动态内存分配。 程序在运行的时候用
mal1oc或new申请任意大小的内存,程序员自己负责在何时用free或delete释放内存。动态内存的生存期由程序员決定,使用非常灵活。如果在堆上分配了空间就有责任回收它,否则运行的程序会出现内存世漏,另外频繁地分配和释放不同大小的堆空间将会产生堆内碎块。
一个C、 C++程序编译时内存分为5大存储:堆区,栈区,全局区,文字常量区,程序代码区。
{
char *p = "hello world";
return 0;
}
p和“hello world”储存在内存哪个区域
答案: 栈,只读储存区
(1)从静态存储区域分配:
内存在程序编译时就已经分配好这块内存在程序的整个运行期间都存在。速度快、不容易出错,因为有系统会善后。例如全局变量, static变量等。
(2)在栈上分配:
在执行函数时,函数内局部变量的存储单元都在桟上创建函数执行结束时这些存储单元自动被释放。 投内存分配运算内置于处理器的指令集中,效率很高,但是分配的内存容量有限。
(3)从堆上分配:
即动态内存分配。 程序在运行的时候用
mal1oc或new申请任意大小的内存,程序员自己负责在何时用free或delete释放内存。动态内存的生存期由程序员決定,使用非常灵活。如果在堆上分配了空间就有责任回收它,否则运行的程序会出现内存世漏,另外频繁地分配和释放不同大小的堆空间将会产生堆内碎块。
一个C、 C++程序编译时内存分为5大存储:堆区,栈区,全局区,文字常量区,程序代码区。