博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
解决C# 7.2中的结构体性能问题
阅读量:5807 次
发布时间:2019-06-18

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

在某些使用了readonly关键字的情况下,C#编译器会创建出结构体的防御副本。虽然这个问题已经众所周知并被下来了,但仍然值得重新审视,因为它与C# 7.2的几个特性有关。in和ref readonly关键字的使用让这个问题出现得更频繁,而readonly结构体提供了一种解决方法。

\\

C#中的结构体通常用于提升性能,减少用于分配和销毁内存的开销。然而,潜在的陷阱限制了它们的使用。C# 7.2增加了一个改进的readonly结构体来解决这个问题。

\\

在如下几种情况下,C#编译器将为结构体创建副本:

\\
  •  结构体不是只读的。\
  •  机构提变量使用了readonly修饰符。\
  •  调用方法(包括属性)。\
\public struct SomeStruct  \{\ private int _x;\\ \ public int X { get { return _x; } }\}\\ \private readonly SomeStruct s = new SomeStruct(42);\\ \s.X; // 编译器创建了一个防御副本。\
\\

当x是in参数、ref readonly局部变量或通过readonly reference返回值的方法调用的结果时,适用相同的规则。

\\
\public void BadFunction(in SomeStruct s)\\{\  s.X; // 编译器创建了一个防御副本。\}\
\\

C# 7.2增加了声明readonly结构体的可能性,并提供了避免创建防御副本的解决方案。声明为readonly的结构体不能具有属性设置器,并且不能对结构体成员赋值。

\\

我们可以通过静态分析来检测防御性副本问题。的灵感来自于ErrorProne,一个Java静态分析工具。移植到.NET的版本由一组Roslyn分析器组成,侧重于准确性和性能。其中有一部分分析器,以Nuget包的方式供下载使用。

\\

查看英文原文

转载地址:http://peubx.baihongyu.com/

你可能感兴趣的文章
org.hibernate.MappingException: No Dialect mapping for JDBC type: -1 搞定!
查看>>
热点热词新闻资讯API开放接口(永久免费开放)
查看>>
8.1_Linux习题和作业
查看>>
11.排序算法_6_归并排序
查看>>
Redis redis-cli 命令列表
查看>>
.NET框架设计—常被忽视的框架设计技巧
查看>>
BigDecimal 舍入模式(Rounding mode)介绍
查看>>
开源 免费 java CMS - FreeCMS1.2-标签 infoSign
查看>>
开源 免费 java CMS - FreeCMS1.9 移动APP生成栏目列表数据
查看>>
git reset 三种用法总结
查看>>
hdfs笔记
查看>>
虚拟机新增加硬盘,不用重启读到新加的硬盘
查看>>
Java IO流详尽解析
查看>>
邮件服务系列之四基于虚拟用户的虚拟域的邮件系统(安装courier-authlib以及部分配置方法)...
查看>>
Linux VSFTP服务器
查看>>
DHCP中继数据包互联网周游记
查看>>
Squid 反向代理服务器配置
查看>>
Java I/O操作
查看>>
Tomcat性能调优
查看>>
项目管理心得
查看>>