c++中的内存分配方式,以及使用过程中需要小心的地方
2013-09-05 16:05
344 查看
c++中的内存分配方式,以及使用过程中需要小心的地方
内存分配方式有三种:
[1]从静态存储区域分配。内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。例如全局变量,static变量。
[2]在栈上创建。在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集中,效率很高,但是分配的内存容量有限。
[3]从堆上分配,亦称动态内存分配。程序在运行的时候用malloc或new申请任意多少的内存,程序员自己负责在何时用free或delete释放内存。动态内存的生存期由程序员决定,使用非常灵活,但如果在堆上分配了空间,就有责任回收它,否则运行的程序会出现内存泄漏,频繁地分配和释放不同大小的堆空间将会产生堆内碎块。
[4]文字常量分配在文字常量区,程序结束后由系统释放。
[5]程序代码区。
经常遇到的问题:
1. 内存分配未成功,却被使用。
对策:使用内存之前检查是否分配成功。用p!=NULL判断。
2. 内存分配成功,未初始化就被使用。
内存的缺省值没有统一的标准。大部分编译器以0作为初始值,但不完全是。
对策:内存初始化时赋初值。
3. 内存操作越界。
对策:只能是小心了。
4. 释放了内存,仍然使用。
(1) 使用显示delete和free的野指针。
对策:释放完内存,将指针置为NULL。
(2) 使用隐式delete和free的野指针。主要是指函数返回指向栈内存的指针或引用。
对策:当然是不要返回就可以了。
5. 未释放内存,导致内存泄露。
用new/malloc开辟了内存,没用delete/free释放.
对策:new和delete的个数一定相同;malloc和free的个数一定相同;new[]和[]delete一定对应。
对于野指针:
野指针,也就是指向不可用内存区域的指针。通常对这种指针进行操作的话,将会使程序发生不可预知的错误。
“野指针”不是NULL指针,是指向“垃圾”内存的指针。人们一般不会错用NULL指针,因为用if语句很容易判断。但是“野指针”是很危险的,if语句对它不起作用。野指针的成因主要有两种:
一、指针变量没有被初始化。任何指针变量刚被创建时不会自动成为NULL指针,它的缺省值是随机的,它会乱指一气。所以,指针变量在创建的同时应当被初始化,要么将指针设置为NULL,要么让它指向合法的内存。
二、指针p被free或者delete之后,没有置为NULL,让人误以为p是个合法的指针。别看free和delete的名字恶狠狠的(尤其是delete),它们只是把指针所指的内存给释放掉,但并没有把指针本身干掉。通常会用语句if (p != NULL)进行防错处理。很遗憾,此时if语句起不到防错作用,因为即便p不是NULL指针,它也不指向合法的内存块。
使用的时候:
如果在有操作系统的环境下,一般是这样的:
堆可以为不连续的内存,有虚拟指针,在申请和释放要进入内核模式,要操作系统加入分配,所以频繁申请,释放堆内存最好自己管理这些事.一次申请,多次回收等。
栈一般是为连续的内存,从申请的角度来说,栈块.无非就是一个sub操作,栈空间在创建线程的时候就已经确定了大小,申请跟释放不需要进入内核模式,即使在同样的IO环境下,栈的读写要比堆的要少点操作,所以还是要快点;这里需要注意的是,它的大小是有限的:
SunOS/Solaris(Shared Version) 8172K bytes
Linux 10240K bytes
Windows(Release Version) 1024K bytes
有时候不够用的情况下会分配到外部存储区
更详细的解释:
http://jinyongming.blog.163.com/blog/static/411404492009610102415163/
http://www.cnblogs.com/TonyEwsn/archive/2010/01/29/1659496.html
其他引用网址:
http://www.oschina.net/question/579148_75547
内存分配方式有三种:
[1]从静态存储区域分配。内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。例如全局变量,static变量。
[2]在栈上创建。在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集中,效率很高,但是分配的内存容量有限。
[3]从堆上分配,亦称动态内存分配。程序在运行的时候用malloc或new申请任意多少的内存,程序员自己负责在何时用free或delete释放内存。动态内存的生存期由程序员决定,使用非常灵活,但如果在堆上分配了空间,就有责任回收它,否则运行的程序会出现内存泄漏,频繁地分配和释放不同大小的堆空间将会产生堆内碎块。
[4]文字常量分配在文字常量区,程序结束后由系统释放。
[5]程序代码区。
经常遇到的问题:
1. 内存分配未成功,却被使用。
对策:使用内存之前检查是否分配成功。用p!=NULL判断。
2. 内存分配成功,未初始化就被使用。
内存的缺省值没有统一的标准。大部分编译器以0作为初始值,但不完全是。
对策:内存初始化时赋初值。
3. 内存操作越界。
对策:只能是小心了。
4. 释放了内存,仍然使用。
(1) 使用显示delete和free的野指针。
对策:释放完内存,将指针置为NULL。
(2) 使用隐式delete和free的野指针。主要是指函数返回指向栈内存的指针或引用。
对策:当然是不要返回就可以了。
5. 未释放内存,导致内存泄露。
用new/malloc开辟了内存,没用delete/free释放.
对策:new和delete的个数一定相同;malloc和free的个数一定相同;new[]和[]delete一定对应。
对于野指针:
野指针,也就是指向不可用内存区域的指针。通常对这种指针进行操作的话,将会使程序发生不可预知的错误。
“野指针”不是NULL指针,是指向“垃圾”内存的指针。人们一般不会错用NULL指针,因为用if语句很容易判断。但是“野指针”是很危险的,if语句对它不起作用。野指针的成因主要有两种:
一、指针变量没有被初始化。任何指针变量刚被创建时不会自动成为NULL指针,它的缺省值是随机的,它会乱指一气。所以,指针变量在创建的同时应当被初始化,要么将指针设置为NULL,要么让它指向合法的内存。
二、指针p被free或者delete之后,没有置为NULL,让人误以为p是个合法的指针。别看free和delete的名字恶狠狠的(尤其是delete),它们只是把指针所指的内存给释放掉,但并没有把指针本身干掉。通常会用语句if (p != NULL)进行防错处理。很遗憾,此时if语句起不到防错作用,因为即便p不是NULL指针,它也不指向合法的内存块。
使用的时候:
如果在有操作系统的环境下,一般是这样的:
堆可以为不连续的内存,有虚拟指针,在申请和释放要进入内核模式,要操作系统加入分配,所以频繁申请,释放堆内存最好自己管理这些事.一次申请,多次回收等。
栈一般是为连续的内存,从申请的角度来说,栈块.无非就是一个sub操作,栈空间在创建线程的时候就已经确定了大小,申请跟释放不需要进入内核模式,即使在同样的IO环境下,栈的读写要比堆的要少点操作,所以还是要快点;这里需要注意的是,它的大小是有限的:
SunOS/Solaris(Shared Version) 8172K bytes
Linux 10240K bytes
Windows(Release Version) 1024K bytes
有时候不够用的情况下会分配到外部存储区
更详细的解释:
http://jinyongming.blog.163.com/blog/static/411404492009610102415163/
http://www.cnblogs.com/TonyEwsn/archive/2010/01/29/1659496.html
其他引用网址:
http://www.oschina.net/question/579148_75547
相关文章推荐
- Windows以及c++内存分配方式
- c++ 使用动态内存分配的类需要显式复制构造函数,赋值构造函数,析构函数
- C++中数组的动态分配以及内存分配的方式
- C/C++内存分配方式以及存储分区
- C++重载内存分配时需要注意的地方
- 浅析C++内存分配与释放操作过程——三种方式可以分配内存new operator, operator new,placement new
- Mysql: Connect/C++ 使用过程中发现返回 std::string 造成的内存泄露
- C/C++内存分配方式,栈区堆区 new/delete/malloc/free
- C++内存分配方式详解——堆、栈、自由存储区、全局/静态存储区和常量存储区
- C/C++ 内存分配方式,堆区,栈区,new/delete/malloc/free
- 内存分配以及合理使用
- C++[类设计] 一个使用new动态内存分配的集合类
- 探讨C++ 变量生命周期、栈分配方式、类内存布局、Debug和Release程序的区别2
- redis__内存分配方式,以及malloc函数实现原理。
- C++内存分配方式详解——堆、栈、自由存储区、全局/静态存储区和常量存储区
- C++内存分配方式详解——堆、栈、自由存储区、全局/静态存储区和常量存储区
- Activity启动模式以及在使用时需要注意的地方
- C/C++ 内存分配方式,堆区,栈区,new/delete/malloc/free(转)
- C++中内存分配方式、空指针及野指针的区别
- C++中vectors内存分配的使用方法