博客
关于我
c#值类型引用类型第一章
阅读量:438 次
发布时间:2019-03-06

本文共 1197 字,大约阅读时间需要 3 分钟。

概要

本篇文章主要简单扼要的讲述值类型和引用类型更进阶的理解和使用。如果希望更多的了解和技术讨论请记得看文章末尾,望各位看官多多支持多多关注,关注和支持是我更新文章的最大动力。在这里谢谢大家。温馨提示:通篇阅读大约10分钟,后续会以一个系列方式来讲解望大家持续关注,会附上运行代码来证实理论。

内容简介

值类型和应用类型的区别

主要内容

值类型

  • 值类型分配在线程栈中。
  • 值类型传递的是值的本身,对值类型变量的操作不可能影响另外一个值类型的值。
  • 值类型值类型对象有两种表现形式:装箱和未装箱。
  • 值类型从System.ValueType派生。该类型提供了与System.Object相同的方法。但是System.ValueType重写了Equlas方法,能在两个对象的字段值完全匹配的前提下返回true。也重写了GetHashCode方法。生成哈希码是,这个重写方法所用的算法会将对象实例字段中的值考虑在内。
  • 值类型变量赋值给另一个值类型变量,会逐字段的复制。
  • 未装箱的值类型,不在被使用时为它分配的存储空间会被自动释放,而不是等待GC回收。
  • 值类型不能作为积累性来定义,新的值类型或者新的引用类型,所以不能引入任何新的虚方法。所有方法都不能是抽象的,所有方法都是隐式密封不可重写。
  • 由于值类型从System.ValueType派生的,是没有同步索引块和对象指针的,所以在内存占用上比引用类型小。操作速度比引用类型快。

引用类型

  • 引用类型分配在托管堆中。
  • 引用类型传递的是值的副本,两个或多个引用类型变量能引用堆中的同一个对象,所以对一个变量执行操作时可能影响另一个变量的值。
  • 引用类型总是处于已装箱形式。
  • 引用类型变量赋值给另一个引用类型变量,只复制内存地址。
  • 引用类型可作为基类型,派生出其他派生类。
  • 引用类型从System.Objectt派生的是有同步索引块和对象指针的,什么是同步索引块呢,在使用lock中大家都会new一个object对象所以lock的对象而就是因为有同步索引块而且空的objcet对象结构稳定不会发生变化所以lock才能发挥作用。那什么是对象指针呢,对象指针就是编译器告诉你现在用的是什么对象具体体现在引用类型的GetType()方法,实质上就是调用对象指针拿到对象类型。

结尾

到这里大致我们对值类型和应用类型的区别有个初步的认识,后面的文章中将会逐渐加深讲解并写Demo项目以供大家学习。 希望大家多多支持关注,不胜感激。

  • E-Mail:zhuzhen723723@outlook.com
  • QQ: 580749909
  • Blog: https://www.cnblogs.com/justzhuzhu/
  • Git: https://github.com/JusterZhu
  • 知乎:https://www.zhihu.com/people/juster-zhu
  • 微信公众号
你可能感兴趣的文章
mutiplemap 总结
查看>>
MySQL DELETE 表别名问题
查看>>
MySQL Error Handling in Stored Procedures---转载
查看>>
MVC 区域功能
查看>>
MySQL FEDERATED 提示
查看>>
mysql generic安装_MySQL 5.6 Generic Binary安装与配置_MySQL
查看>>
Mysql group by
查看>>
MySQL I 有福啦,窗口函数大大提高了取数的效率!
查看>>
mysql id自动增长 初始值 Mysql重置auto_increment初始值
查看>>
MySQL in 太多过慢的 3 种解决方案
查看>>
MySQL InnoDB 三大文件日志,看完秒懂
查看>>
Mysql InnoDB 数据更新导致锁表
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>
Mysql InnoDB存储引擎 —— 数据页
查看>>
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>