java - short 的性能/内存优势是否因向下转换而无效?

标签 java performance primitive downcast

我正在编写一个大型应用程序,我试图在其中尽可能多地节省内存并提高性能。因此,当我有一个我知道只会有 0 - 10 或 -100 - 100 值的字段时,我尝试使用 short 数据类型而不是 int.

不过,这对其余代码意味着,当我调用这些函数时,我必须将简单的 int 向下转换为 short秒。例如:

方法签名

public void coordinates(short x, short y) ...

方法调用

obj.coordinates((short) 1, (short) 2);

在我的整个代码中都是这样,因为文字被视为 int 并且不会根据函数参数自动向下转换或类型化。

因此,一旦发生这种向下转换,任何性能或内存增益是否真的很重要?还是转换过程如此高效以至于我仍然可以获得一些 yield ?

最佳答案

在 32 位平台上使用 short 与 int 没有任何性能优势,除了 short[] 与 int[] 的情况外 - 即便如此,缺点通常也超过了优点。

假设您在 x64、x86 或 ARM-32 上运行:

  • 在使用时,16 位 SHORT 存储在 32 位或 64 位长的整数寄存器中,与整数相同。 IE。使用 short 时,与 int 相比,您不会获得内存或性能优势。
  • 在堆栈中时,16 位 SHORT 存储在 32 位或 64 位“槽”中,以保持堆栈对齐(就像整数一样)。对于局部变量使用 SHORT 与 INT 相比,您不会获得任何性能或内存优势。
  • 当作为参数传递时,SHORT 会在压入堆栈时自动扩展为 32 位或 64 位(与刚刚压入的整数不同)。与使用 int 相比,此处的代码实际上性能稍差,并且(代码)内存占用量稍大。
  • 存储全局(静态)变量时,这些变量会自动扩展以占用 32 位或 64 位槽,以保证指针(引用)对齐。这意味着对于全局(静态)变量使用 SHORT 与 INT 相比,您不会获得任何性能或内存优势。
  • 在存储字段时,这些字段位于堆内存中映射到类布局的结构中。在此类中,字段会自动填充为 32 位或 64 位,以保持堆上字段的对齐。与 INT 相比,对字段使用 SHORT 不会带来性能或内存优势。

与 INT 相比,使用 SHORT 的唯一好处是在分配它们的数组的情况下。在这种情况下,N 个短整数数组的长度大约是 N 个整数数组的一半。

除了在大量短裤数组中进行复杂但局部化的数学运算的情况下,热循环中的变量一起带来的性能优势外,您永远不会看到使用 SHORTS 与 INT 相比有什么好处。

ALL 其他情况下——例如用于字段、全局变量、参数和局部变量的 shorts,除了它可以存储的位数之外,没有 SHORT 和 INT 之间的区别。

我一如既往的建议是,在让您的代码更难阅读和受到更多人为限制之前,尝试基准您的代码以查看内存和 CPU 瓶颈在哪里,然后解决这些问题.

我强烈怀疑,如果您曾经遇到过您的应用程序使用整数而不是短裤的情况,那么您早就放弃了 Java 以换取更少的内存/CPU 运行时,所以做所有的前期的这项工作是浪费精力。

关于java - short 的性能/内存优势是否因向下转换而无效?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13589183/

相关文章:

java - JApplet多页面应用

java - XP 和 7 中的重点 Windows

c++ - C++中的递归函数和性能

c# - 避免在 foreach 循环中等待

java - 整数不是Java中的对象,仅仅因为它们不是类的实例?

具有 Comparable 接口(interface)的 Java 通用语法

java - Java 中最好的企业购物车是什么?

c# - 创建一个方法以返回另一个方法的执行时间

java - 为什么原始类型允许在每个循环中进行收集?

Javascript [Symbol.toPrimitive](hint) 转换函数