gpt4 book ai didi

c# - 小数的不同位整数内的显着性能差异

转载 作者:太空宇宙 更新时间:2023-11-03 17:55:43 25 4
gpt4 key购买 nike

我将第一次使用非常少量的非常小的数字(因为每个 int 将在 1 到 10 之间,并且一次有 100 个这样的变量),我想知道是否有任何显着的性能使用 16 位整数与 32 位的区别。我的大多数用户将使用 64 位处理器,但有些用户将使用 32 位。

最佳答案

中央处理器

使用单个数字时,使用更紧凑的表示可能会略有改进。那是,

ushort a;
ushort b;

// @mikez pointed a & b are promoted to int when added
// C# spec, 7.3.6.2 Binary numeric promotions
ushort result = (ushort)(a + b);

可能比
ulong a;
ulong b;

ulong result = a + b;

取决于你的算法。原因是当单个数字较小时,更多的数据可以放入 CPU 缓存中,最终需要从 RAM 传输到 CPU 的数据更少。

另一方面,由于读/写数据未与 64 位地址边界对齐,它可能会稍微慢一些。

这两个因素相互影响。衡量您的用例,从 CPU 的角度了解您的情况是好是坏。

在内存中

使用 List<ushort>而不是 List<ulong>将节省 75% 的内存成本。如果这阻止了交换,它将使您的应用程序受益。

磁盘上

如果您正在保存到数据库,并且如果您的工作集太大而无法容纳数据库引擎可用的 RAM,则使用较小的大小可能会对性能产生巨大影响,因为更多的记录适合较少的磁盘扇区,从而减少了磁盘寻道时间(假设没有 SSD)并增加每单位时间内可以通过 IO channel 传输的数据点数量。

警告

请注意,所有这些仅在 时才重要。真的大批量与计算机的处理能力相比,这是正确的。如果您有足够的 RAM 将所有数据保存在内存中,则不会交换。如果您的数据库服务器和/或存储 Controller 缓存可以将您的工作集保存在内存中,那么磁盘存储大小的考虑将无关紧要。

底线

如果您对要处理的值的范围有误,那么使用较小的数据类型只会对您造成伤害,并且您突然需要更大的数据类型来保存所有值。

快速制作关键算法的原型(prototype)。使用 ushort、uint、ulong 的各种选择执行一些测量。

如果您的“100 个变量”每个都只包含一个数字(而不是一个包含大量数字的列表),那么这些都不重要。只有当您开始对您的计算机施加压力时(可能在 10 到 100 的数百万或更多数据点,具体取决于您在做什么),这些优化才会对您的用户真正重要。

关于c# - 小数的不同位整数内的显着性能差异,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11730193/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com