补充!引用类型和值类型

1. 变量之间相互赋值的时候.将源变量中的值拷贝1份,将这个副本赋值给目标变量.
 
 2. 赋值表达式要求 赋值符号 右边的数据的类型 和左边的数据的类型一致
 就可以成功赋值.

 3. 内存的作用:存储数据:
 内存中主要分为两个空间:
 栈空间:
 堆空间:
 栈空间与堆空间他们是用来存储数据的. 不同的数据存储在不同的空间中,这么做的好处在于方便管理.
 
 4. 那么栈中存储哪些数据?
 堆中存储哪些数据呢?
 int 类型的变量 开辟在栈空间中,其值直接存储在该变量中的.
 
 int[] arr = new int[3];
 int[]是1个数据类型.
 arr是1个变量. 那么既然是1个变量,它里面是不可能存储多个数据的.
 new int[3]; 这是1个表达式 。
 new是1个运算符.
 
 这个int[]类型的变量arr 仍然开辟在栈空间中.
 new int[3]做的事情 在堆内存中开辟连续的3块int类型的空间.
 然后将第1个元素的内存地址返回 通过 赋值符号 赋值给arr变量.
 arr变量并不会分成几个等分. 真正的数组是存储在堆空间中的. arr变量中存储的是数组的地址.
 
 5. 在即时窗口中, 我们可以使用 &变量名 然后可以清晰的查看这个变量的地址以及这个变量中存储的值.
 
 
 6. 数据类型.
 现在学习的数据类型:
 数值类型: long int short byte decimal double float
 非数值类型: char string bool 数组

 在此之前:我们将我们学习到的数据类型分为两大类:
 数值类型
 非数值类型
 划分的依据: 数据的样式.
 
 我们现在要将我们学习到的所有的数据类型 按照1种 新的依据 重新划分.
 这个时候我们划分的依据: 是他们在内存中存储的结构不同.
 值类型:
 所有的数值类型(long int short byte decimal double float uint ushrot ulong sbyte)
 char
 bool
 引用类型:
 string
 数组

 7. 值类型与引用类型的异同:
 a. 相同点: 无论是值类型还是引用类型 它们的变量始终开辟在栈空间中.
 b. 不同点:
 值类型的变量的真实的值 直接存储在该变量中.
 引用类型的变量的真实的值是存储在堆空间中. 引用类型变量中存储的是真实值在堆空间中的地址.
 c. so 值类型的变量中存储真实的数据.
 引用类型的变量中存储1个引用地址 指向堆空间中的真实的数据.
 
 d. 所有的值类型的数据,都是这么存储的.
变量开辟在栈中. 变量中直接存储真实的值.
 
 所有的引用类型的数据 都是这么存储的
 变量开辟在栈中,真实的数据存储在堆中,变量中存储的是真实的值在堆空间中的应用地址,
 
 8. 正因为值类型与引用类型有以上的区别,
所以就造就了值类型的变量在相互赋值的时候 和 引用类型的变量相互赋值 效果是不同的.
 
 变量之间相互赋值,如果变量的类型不同 那么赋值的效果就会不同.
 
 a. 变量在相互赋值的时候, 无论是引用类型的变量还是值类型的变量.都是源变量的值拷贝1份 将副本赋值给目标变量.
 
 b. 不同点:
 如果是值类型的变量之间相互赋值. 因为值类型的变量中存储的是真实的值. 所以拷贝传递的也是真实的值.
 赋值完成以后,对1个变量的值进行修改 不会影响另外1个变量的值 。

 引用类型的变量之间相互赋值. 因为引用类型的变量中存储的是真实的值在堆空间中的地址,所以拷贝传递的也是地址.
 赋值完成以后 两个变量指向了同1个在堆空间中的真实的数据 对1个变量进行修改,会影响另外的1个变量的值.
 
 9. string类型是1个特殊的引用类型

 监视变量的地址和值:

补充!引用类型和值类型

时间: 2024-11-10 07:09:09

补充!引用类型和值类型的相关文章

【转】c#引用类型与值类型的区别大盘点

解析:CLR支持两种类型:值类型和引用类型.用Jeffrey Richter(<CLR via C#>作者)的话来说,“不理解引用类型和值类型区别的程序员将会把代码引入诡异的陷阱和诸多性能问题”.这就要求我们正确理解和使用值类型和引用类型. 值类型包括C#的基本类型(用关键字int.char.float等来声明),结构(用struct关键字声明的类型),枚举(用enum关键字声明的类型):而引用类型包括类(用class关键字声明的类型)和委托(用delegate关键字声明的特殊类).C#中的每

C#引用类型和值类型的区别

1***.C#中有两种类型: 值类型和引用类型: 值类型的变量直接包含他们的数据,而引用类型的变量存储 引用类型存储对他们的数据的引用,后者称为对象: 简单说:值类型直接存储其值,引用类型存储对值得引用.引用类型分为引用和引用的对象. 2***. 值类型:简单类型.枚举.结构 引用类型: 类类型.接口类型.数组类型和委托类型 3***.值类型与引用类型的内存存储 单纯的说值类型存储在栈上,引用类型存储在托管堆上是不对的. 4***.区别: 1. 托管堆: 同步块和方法表, x,y,托管堆上的需要

12-12面向对象--引用类型与值类型、命名空间与类库

五.引用类型与值类型 .NET将变量的类型分为值类型与引用类型.例如int和float之类的变量属于值类型,而“类“类型的变量属于引用类型. 值类型与引用类型的变量在使用上是有区别的. 值类型的变量在一定义之后就可以马上使用. 引用类型的变量定义之后,还必须用new关键字创建对象后才可以使用. 如上图,创建两个新的对象时,直接比较两个对象是否相等,返回的bool值为false.因为两个对象都是新开辟的一个空间变量,彼此没有任何关系,所有是不相等的. 如图2:1)创建的第一个新的对象ss1,给ss

引用类型与值类型在编码上的区别

一.引入类型与值类型简介 值类型:直接存放于栈中,取的时候是直接取得值.值类型继承自System.ValueType.(自定义对象) 引用类型:存在于托管堆中,取的时候取的是该对象的地址,然后用这个地址去托管堆中取值.引用类型继承自System.Object.(int,bool) 二.在代码编写上的区别 在赋值的时候,值类型是复制一份,新的和旧的在以后的操作中互不影响,而引用类型复制的只是地址,在以后的修改中,修改新的旧的也会受到影响. 代码示例: static void Main(string

.NET 基础 一步步 一幕幕[面向对象之堆、栈、引用类型、值类型]

堆.栈.引用类型.值类型 内存分为堆和栈(PS:还有一种是静态存储区域 [内存分为这三种]),值类型的数据存储在栈中,引用类型的数据存储在堆中. 堆.栈: 堆和栈的区别: 栈是编译期间就分配好的内存空间,因此你的代码中必须就栈的大小有明确的定义:局部值类型变量.值类型参数等都在栈内存中. 堆是程序运行期间动态分配的内存空间,你可以根据程序的运行情况确定要分配的堆内存的大小. 引用类型.值类型 1.将一个值类型变量赋给另一个值类型变量时,将复制包含的值.引用类型变量的赋值只复制对对象的引用,而不复

5.基元类型、引用类型和值类型

5.1 基远类型 编译器直接支持的数据类型称为基远类型(primitive type). 以下4行到吗生成完全相同的IL int a = 0; //最方便的语法 System.Int32 b = 0; //方便的语法 int c = new int(); //不方便的语法 System.Int32 d = new System.Int32(); //最不方便的语法 C#基元类型与对应的FCL类型 C#中的基元类型 FCL类型 是否与CLS兼容 描述 sbyte System.SByte N 有符

JavaScript引用类型和值类型

thead>tr>th,.table>tbody>tr>th,.table>tfoot>tr>th,.table>thead>tr>td,.table>tbody>tr>td,.table>tfoot>tr>td{padding:8px;line-height:1.45;vertical-align:top;border-top:1px solid #ddd}.table>thead>tr&g

CLR via C#深解笔记三 - 基元类型、引用类型和值类型 | 类型和成员基础 | 常量和字段

编程语言的基元类型 某些数据类型如此常用,以至于许多编译器允许代码以简化的语法来操纵它们. System.Int32 a = new System.Int32();  // a = 0 a = 1; 等价于: int a = 1; 这种语法不仅增强了代码的可读性,其生成的IL代码与使用System.Int32时生成的IL代码是完全一致的. 编译器直接支持的数据类型称为基元类型(primitive type).基元类型直接映射到Framework类库(FCL)中存在的类型.如C#中,int直接映射

引用类型和值类型

CLR支持两种类型:引用类型和值类型. 虽然FCL中大多数都是引用类型,但开发人员用的最多的还是值类型.引用类型总是在托管堆上分配的,C#的new操作符会返回对象的内存地址——也就是指向对象数据的内存地址. 使用引用类型必须注意到一些性能问题,首先考虑一下事实: 1)内存必须从托管堆上分配. 2)对上分配的每个对象都有一些额外的成员(比如前面提到过得"类型对象指针"和"同步块索引"),这些成员必须初始化. 3)对象中的其他字节(为字段而设)总是设为零. 4)从托管堆