C#编程(七十三)----------浅析C#中内存管理

浅析C#中内存管理

前言:个人觉得C#吸收了各种语言的优点,可谓集大成者,但是不知但,这种集所有语言于一身的情况是好是坏.C#编程的一个优点就是程序员不需要关心具体的内存管理,尤其是垃圾收集器会处理所有的内存清理工作.虽然不比手工管理内存,但是如果要编写高质量的代码,还是要理解后台发生的情况,理解C#的内存管理.

用户可以得到像C++语言那样的效率,而不需要考虑像在C++中那样内存管理工作的复杂性.

注意:这一章的许多内容,可以说全部,都是没有经过事实验证的.您应把这一届看做是一般规则的简化向导,而不是实现的确切说明.

首先C#将数据分为两种:值数据类型和引用数据类型,这两种数据类型存储在内存中的不同的地方:值数据类型存储在堆栈中,而引用类型存储在内存的托管堆中.

一.内存简介

windows使用一个系统:虚拟寻址系统.这个系统的作用是将程序可用的内存地址映射到硬件内存中的实际地址.其实际结果就是32位的机子上每个进程都可以使用4GB的内存,当然,64位的机器4,这个数字就更大了.这4G的内存实际上包含了程序的所有的部分,可执行代码,DLL以及程序运行时使用的所有变量的内容.这个4GB内存称为虚拟地址空间或虚拟内存.为方便,着了成为内存.

4GB中的每个存储单元都是从零开始向上存储的.要访问存储在内存中的某个空间中的值,就必须提供表示该存储单元的一个数字.在高级编程语言中,比哪一期的一个重要作用就是负责将人们可以理解的变量名称编程处理器可以理解的内存地址.

二.堆栈

在内存中,有一个区域称为堆栈,存储对象.

对象成员的值数据类型调用方法时,传递给所有方法的参数的副本.注意:调用方法时,堆栈存储的是所有参数的副本,因此,经值类型A传递给函数,A的值是不会变化的.当然,引用类型时会变化的,因为堆栈中存储的是引用类型的地址.

案例:

{

int a;

//do domething

{

int b;

//do domething

}

}

分析:首先声明a,在内部的代码块中声明b,然后内部的代码块终止,b就出了作用域,最后a出作用域.所以b的声明周期总是包含在a的声明周期内,在释放变量的时候,其顺序总是和分配内存的顺序相反.即:变量的生存周期都是嵌套的.这就是堆栈的工作方式.

三.托管堆

堆栈具有相当高的性能,但是变量的生命周期必须是嵌套的,这个要求在有的时候过于苛求.我们希望有一种别的方法来分配内存,存储一些数据,并在方法退出的很长一段时间内,这些户数仍然是可用的,这时就可以使用托管堆.

托管堆(简称堆)是内存中的另一个区域,我们仍然用一个例子来说明堆的工作方式:

{

Customer customer1;

customer1=new Customer();

Customer customer2=new Customer();

//do domething

}

分析:首先,声明一个Customer:customer1,在堆栈上给这个引用分配空间.注意:仅仅是给这个引用分配存储空间,并不是实际的Customer对象.customer1占用4个字节的空间(32位机),来表示Customer对象在内存中的地址.

然后.执行第二行代码,完成以下操作:

在堆上分配存储空间,用来存储CUstomer对象,注意,这里是Customer对象.

将变量customer1的值设为分配给Customer对象的内存地址从这个例子中可以看出,建立引用类型的变量的过程要比建立值类型变量的过程复杂,且不能避免性能的降低.但是,我们可以将一个引用变量的值赋给另一个引用变量,当一个变量出了作用域时,他会从对战中删除,但是对象的数据仍然保留在内存中,直到程序停止.

这样,我们将一个引用变量A传递给函数时,仅仅是将变量A的引用传递给了函数,即:仅仅是在对站上分配内存,即变量B两者指向同一个内存地址.因此,当变量发生变化时,变量A也会发生变化.

四.拆装箱

拆装箱就是值类型和引用类型的项目转化,装箱可以将值类型转化为引用类型,拆箱的作用恰好相反,经引用类型转化为值类型.

五.垃圾回收

一般情况下. .NET运行库会在认为需要的时候运行垃圾收集器来释放托管资源,这在大多数情况下是足够的,就是说我们没有必要去关心内存.但在有的情况下,我们会强制垃圾回收器在代码的某个地方运行,释放内存.这就用到了System.GC.Collect;System.GV表示一个垃圾回收期.这种情况很少见,例如,代码中大量的对象刚刚停止引用,就是和调用垃圾收集器.

时间: 2024-07-30 06:41:36

C#编程(七十三)----------浅析C#中内存管理的相关文章

[转载]对iOS开发中内存管理的一点总结与理解

对iOS开发中内存管理的一点总结与理解 做iOS开发也已经有两年的时间,觉得有必要沉下心去整理一些东西了,特别是一些基础的东西,虽然现在有ARC这种东西,但是我一直也没有去用过,个人觉得对内存操作的理解是衡量一个程序员成熟与否的一个标准.好了,闲话不说,下面进入正题. 众所周知,ObjectiveC的内存管理引用的一种叫做“引用计数“ (Reference Count)的操作方式,简单的理解就是系统为每一个创建出来的对象,(这里要注意,只是对象,NSObject的子类,基本类型没有‘引用计数’)

Linux中内存管理

转载自:http://blog.chinaunix.net/uid-26611383-id-3761754.html 前一段时间看了<深入理解Linux内核>对其中的内存管理部分花了不少时间,但是还是有很多问题不是很清楚,最近又花了一些时间复习了一下,在这里记录下自己的理解和对Linux中内存管理的一些看法和认识. 我比较喜欢搞清楚一个技术本身的发展历程,简而言之就是这个技术是怎么发展而来的,在这个技术之前存在哪些技术,这些技术有哪些特点,为什么会被目前的技术所取代,而目前的技术又解决了之前的

简述OC中内存管理机制。

1        简述OC中内存管理机制.与retain配对使用的方法是dealloc还是release,为什么?需要与alloc配对使用的方法是dealloc还是release,为什么?readwrite,readonly,assign,retain,copy,nonatomic .atomic.strong.weak属性的作用? OC使用了一种叫做引用计数的机制来管理对象,如果对一个对象使用了alloc.[Mutable]copy,retain,那么你必须使用相应的realease或者aut

OC中内存管理(转)

OC内存管理 一.基本原理 (一)为什么要进行内存管理. 由于移动设备的内存极其有限,所以每个APP所占的内存也是有限制的,当app所占用的内存较多时,系统就会发出内存警告,这时需要回收一些不需要再继续使用的内存空间,比如回收一些不再使用的对象和变量等. 管理范围:任何继承NSObject的对象,对其他的基本数据类型无效. 本质原因是因为对象和其他数据类型在系统中的存储空间不一样,其它局部变量主要存放于栈中,而对象存储于堆中,当代码块结束时这个代码块中涉及的所有局部变量会被回收,指向对象的指针也

七.OC基础加强--1.内存管理 2.野指针,内存泄露 3.set方法的内存管理 [email&#160;protected]参数 [email&#160;protected]和循环retain的使用 6.NSString的内存管理

1,内存管理简单介绍 1,为什么要有内存管理? malloc selloc dealloc```需要回头复习 一般的内存 4s 是512m内存:6 是1024m内存: 当内存过大时,会耗尽内存.出现程序闪退. 2.OC内存管理的范围 : 管理任何继承NSObject的对象,对其他的基本数据类型无效. 3.对象类型是程序运行过程中动态分配的,存储在堆区:内存管理主要是对 堆区中的对象的内存管理. 4.OC内存管理的原理 为了防止内存泄露 对象的引用计数器 : 每个OC对象都有自己的引用计数器,是一

cocos2dx 使用过程中内存管理的理解

关于引擎内存管理的细节,网上有大量的详解,这里概括一下: cocos2d-x 的世界是基于 CCObject 类构建的,所以内存管理的本质就是管理一个个 CCObject. //CCObject 内部维护着一个引用计数,引用计数为 0 就自动释放 unsigned int m_uReference; //管理内存的实质就是管理这些 "引用计数" 了,使用 retain 和 release 方法对引用计数进行操作 void release(void);//引用计数:--m_uRefere

iOS中内存管理

iOS中创建对象的步骤: 1,分配内存空间,存储对象 2,初始化成员变量 3,返回对象的指针地址 第一:非ARC机制: 1,对象在创建完成的同时,内部会自动创建一个引用计数器,是系统用来判断是否回收对象的唯一标示,当我们的应用计数retainCount = 0的时候,系统会回收当前对象2,[对象 release] retainCount - 1:3,[对象 retain] retailCount + 1:4,当应用计数retailCount = 0的对象就会被销毁; 5,dealloc函数,当一

ARM裸机开发中内存管理库RT_HEAP的使用

在使用arm芯片进行裸机开发的时候,很多时候都需要内存管理的功能,我们可以使用自己写的内存管理程序,也可以直接使用标准库,不过我一般比较喜欢标准库,速度快,今天就来说说在C语言环境下怎么样进行内存的动态使用 首先,应该初始化C堆,初始化代码如下 #include "malloc.h" #pragma import (__use_realtime_heap) //这个函数在rt_heap.h中声明,需要用户自己去实现,返回任意值 unsigned __rt_heap_extend(uns

OC中内存管理

内存管理: 谁retain ,谁release 谁alloc ,谁release 每一个对象在创建时都会创建一个引用计数器,系统会根据引用计数器判断对象需要不需要被回收 对象在创建时引用计数器是1 当调用retain消息 计数器 +1   返回对象本身 当调用release消息 计数器 -1 retainCount 获取计数器 当对象的计数器变0之后,当前对象就变成僵尸对象(野指针) 对象在被销毁时,系统会发送一条dealloc消息 1> 一般都会重写dealloc方法,在这里释放相关资源,所有