0

0

C#中的struct和class怎么选 C#值类型与引用类型深度解析

月夜之吻

月夜之吻

发布时间:2025-12-19 09:12:07

|

918人浏览过

|

来源于php中文网

原创

优先用struct当数据小而简单、需值语义;否则用class。struct适合小(≤16字节)、不可变、无继承需求的值类型;class支持继承、多态、资源管理,更安全灵活。

c#中的struct和class怎么选 c#值类型与引用类型深度解析

struct 还是 class,核心看两点:数据是否小而简单、是否需要值语义。小、不可变、逻辑上像基本类型(比如坐标、颜色、金额)——优先用 struct;其余绝大多数场景,用 class 更安全、更灵活。

struct 适合这些情况

它本质是值类型,分配在上(小对象时),复制是整块拷贝,语义上“等于内容相同”。适合:

  • 数据量小(一般建议 ≤ 16 字节,如 PointDateTimeGuid
  • 逻辑上不可变(推荐只读字段 + init-only 属性,避免意外修改)
  • 不需要继承、多态或复杂生命周期管理
  • 高频创建/销毁且对性能敏感(如数学计算中的向量、矩阵)

⚠️ 注意:如果 struct 成员包含引用类型(如 string 或集合),它仍是值类型,但拷贝时只复制引用,底层对象仍共享——这不是“深拷贝”,别误以为安全隔离了所有数据。

class 是默认且更稳妥的选择

它是引用类型,分配在堆上,变量存的是引用。天然支持继承、虚方法、接口实现、析构逻辑等。适合:

  • 数据较复杂或体积较大(避免栈溢出和无谓拷贝)
  • 需要多态行为(如不同形状的 Draw() 实现)
  • 对象需被多个地方共享并协同修改(如订单、用户会话)
  • 需要懒加载、事件、资源管理(IDisposable)等高级能力

即使你定义了一个“看起来很轻”的 class,只要它未来可能扩展功能,也比后期把 struct 改成 class 安全得多——因为 struct 的值语义一旦暴露给外部,改 class 会破坏行为(比如传参从拷贝变成传引用)。

AI at Meta
AI at Meta

Facebook 旗下的AI研究平台

下载

容易踩坑的细节

不是所有“小”都该用 struct。比如:

  • struct 赋值、传参、返回都会触发完整拷贝——如果内部有 100 个字段,性能反而差
  • struct 继承自 System.ValueType,但不能显式继承其他类型,也不能作为基类被继承
  • 装箱(boxing)会让 struct 上堆,一次装箱就失去值类型优势,还可能引发 GC 压力(如循环中把 struct 加入 List
  • 默认构造函数不能重写,字段必须全部初始化(C# 10+ 支持 parameterless constructor,但仍有约束)

一个实用判断流程

写新类型前,快速问自己:

  • 它的实例通常有多大?(字段总大小
  • 它代表一个“值”还是一个“东西”?(Money 是值,BankAccount 是东西)
  • 会不会需要子类化或依赖多态?
  • 有没有非托管资源要释放?(struct 不支持析构函数,IDisposable 实现也受限)
  • 团队是否容易理解并正确使用它的值语义?(误用常源于认知偏差)

基本上就这些。不复杂,但容易忽略。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

318

2023.08.02

java多态详细介绍
java多态详细介绍

本专题整合了java多态相关内容,阅读专题下面的文章了解更多详细内容。

15

2025.11.27

java多态详细介绍
java多态详细介绍

本专题整合了java多态相关内容,阅读专题下面的文章了解更多详细内容。

15

2025.11.27

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1023

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

66

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

426

2025.12.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

390

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

572

2023.08.10

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.6万人学习

Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号