博客
关于我
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
  • 微信公众号
你可能感兴趣的文章
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>