在 Delphi 中有效地将整数与静态整数列表进行比较?

Boz*_*zzy 5 delphi delphi-xe6

类似于if 语句中将整数变量与整数列表进行比较的任何方法,但在 Delphi 中,如何测试整数变量是否包含在整数的静态“列表”(宽松地说 - 预定义的集合)中(也许是if语句中的const列表或显式值列表)?

现在我会做这样的事情:

if (x = 1) or
   (x = 2263) or
   (x = 263553) or
   (x = whatever_int) then
begin
  //do something;
end;
Run Code Online (Sandbox Code Playgroud)

但我试图避免冗长的or条件序列。

我正在使用 Delphi XE6,所以如果有新的东西可以以干净的方式实现这一点,请告诉我。

Dav*_*nan 4

你目前的做法很好。编译器将生成高效的代码。如果效率至关重要,那么您可以选择比较顺序,以便首先检查最常见的值。这需要了解输入数据的分布。

另一种句法方法是case陈述。例如:

case x of
1, 2263, 263553, whatever_int:
  // do other stuff
end;
Run Code Online (Sandbox Code Playgroud)

这会产生与该语句类似(实际上我怀疑是相同)的代码if。但它可能更简洁、更容易阅读。在某些情况下,编译器能够生成跳转表。

如果效率对您来说至关重要,那么请确保检查编译器发出的代码、发布编译器选项并执行分析。

我确实想知道你所说的高效到底是什么意思。在编程中,该术语具有与运行时性能相关的特定含义。但我想知道您是否实际上更关心编写清晰简洁的代码,在这种情况下,高效是错误的术语。事实上,您的问题谈到避免重复or操作员,这让我怀疑效率对您来说是否重要。

另一方面,如果运行时性能很重要,那么请考虑放弃代码清晰度并实现索引跳转表。但是,在没有首先确定代码是瓶颈并分析您所做的任何更改之前,切勿优化代码。

  • 对于这样的测试,我通常更喜欢“case”版本;在我所做的检查中,生成的代码几乎是相同的,并且我认为代码的可读性和可维护性得到了很大的提高。 (2认同)