网站首页 全球最实用的IT互联网站!

人工智能P2P分享Wind搜索发布信息网站地图标签大全

当前位置:诺佳网 > 软件工程 > 后端开发 > .Net >

利用C#9.0中的record提高性能 - Rick Carter - 博客园

时间:2025-03-20 22:30

人气:

作者:admin

标签:

导读:C#9.0是2020年发布的,record特性还没用上的可以看过来,一起讨论下。 下面通过一个简单的示例演示record带来的好处。 1. 通过一个示例引出问题 public class Person { public string Name { get; set...

C#9.0是2020年发布的,record特性还没用上的可以看过来,一起讨论下。
下面通过一个简单的示例演示record带来的好处。

public class Person
{
    public string Name { get; set }
...
}
public class ClassA
{
    public static List<Person> Items=new List<Person>{......};
    public List<Person> GetList()
    {
        foreach(var item in Items)
        {
            item.Name=...
            ...
        }
        return Items;
    }
}

如上代码,就是想把Items中的值修改下再返回,但是这样就会静态变量Items中的值也修改掉,导致下次再用它时数据发生变化了,这不是我们希望的。
至于为什么要修改Items中的值,实际情况可能是单位转换、翻译等等。
还有这里用静态变量,实际的情况可能是内存缓存(IMemoryCache)中取来的,我们并不想它原始值发生改变。

以前我们要解决这个问题,可能就是重新new新的对象,然后逐个属性和字段的赋值,这样写的问题是代码很啰嗦,不优雅。
还有个解决办法就是深拷贝一份,再来修改,这个问题可能就是性能不好了,内存和cpu都消耗的比较多。
可能还有其他的,欢迎讨论。

public record Person
{
    public string Name { get; set }
...
}
public class ClassA
{
    public static List<Person> Items=new List<Person>{......};
    public List<Person> GetList()
    {
        var items = Items.ToList();
        for(var i=0;i<items.Count;i++)
        {
            items[i]=items[i] with {Name=...}
        }
        return items;
    }
}

解决代码如上,使用with表达式实现record的非破环性修改,需要注意的是Items是List泛型集合,是引用类型,需要ToList下以便接下来修改的不是原来的Items。

  1. 利用record非破坏性修改特性实现对象的复制,避免重新new对象大量赋值操作,代码简单优雅性能高;
  2. 利用List的ToList方法创建新的List对象,避免原来的List对象被修改。

作者:Rick Carter
出处:http://pains.cnblogs.com/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信