我今天要介绍的是一个比较另类的方法。大家都知道,case 语句只能对顺序类型
6d6Linux联盟
(ordinal type)管用,那么我们先看一下顺序类型到底有那些呢:1)整型;2)字 6d6Linux联盟
符型;3)枚举型。 6d6Linux联盟
于是也就演化出三种在 case 语句里面使用字符串的方法(耐心看下去哦,最后一 6d6Linux联盟
种方法才是今天的重点:-p): 6d6Linux联盟
6d6Linux联盟
假如我们的具体应用如下(理想的,但是错误的写法): 6d6Linux联盟
6d6Linux联盟
6d6Linux联盟
法一:字符串转为整型 6d6Linux联盟
这应该是比较通行的方法了,主要是利用 TStringList。先把备选的字符串挨个 6d6Linux联盟
Add 进去,然后调用其 IndexOf 方法。该方法返回一个整数,表示待找字符串出 6d6Linux联盟
现在列表中的位置: 6d6Linux联盟
6d6Linux联盟
6d6Linux联盟
可以看到,这是比较麻烦的方法了,不过你可得记住这个方法,因为后面的讨论 6d6Linux联盟
将会讲到,这是最通用的方法。 6d6Linux联盟
另:当然,把字符串转化为整型后用于 case 不只这一种方法。另一种是通过把 6d6Linux联盟
备选项全部转化为等长度后合并为一个字符串,然后用 Pos 函数返回某字符串的 6d6Linux联盟
位置。在此不再累述,请查阅《程序员》杂志(具体哪一期不记得了:-()。 6d6Linux联盟
6d6Linux联盟
法二:字符串转为字符型 6d6Linux联盟
6d6Linux联盟
这应该是最简单的一种方法,不过局限性比较大。如果你的备选项的第 N 个字 6d6Linux联盟
符(N 应为常数)都互不相同,那么你赚到了。这样,就可以通过取出这个字符, 6d6Linux联盟
来唯一标识你的字符串: 6d6Linux联盟
6d6Linux联盟
6d6Linux联盟
不过如果你的备选项没有这样的特性,那么你就无缘使用这种方法了。 6d6Linux联盟
6d6Linux联盟
法三:字符串转为枚举型 6d6Linux联盟
6d6Linux联盟
这种方法主要用到 RTTI 的特性。该方法的主要思路是,先把所有的备选项声名 6d6Linux联盟
为一个枚举类型的值,那么我们只要把要找的字符串也转换为枚举型,那么就可以 6d6Linux联盟
用 case 语句了。那么通过什么办法把一个字符串转化为枚举型呢?往下看: 6d6Linux联盟
6d6Linux联盟
6d6Linux联盟
稍做解释:GetEnumvalue 函数返回一个字符串对应的枚举型的值在某枚举类型 6d6Linux联盟
中的位置(要知道枚举类型是有顺序的,要不怎么叫顺序类型呢:-)),然后通过 6d6Linux联盟
一个强制类型转换将这个值转化为枚举型。于是就实现了把字符串转化为枚举型的 6d6Linux联盟
操作。 6d6Linux联盟
6d6Linux联盟
可以看到,在 case 语句这一段,我们的使用和理想中的使用方法几乎是一样的! 6d6Linux联盟
毕竟枚举类型可以做到见名知意嘛。的确比用前两种方法看起来直观得多。 6d6Linux联盟
6d6Linux联盟
当然,这并不是万能的方法,如果你的备选项有一个不符合 Delphi 的变量名命 6d6Linux联盟
名法则(如'AK-47'或中文等),则不能将其声明为一个枚举型,于是就不能使用这 6d6Linux联盟
个方法。如果是这样你就只能使用前两种方法了。极端的情况下,至少你还有第一 6d6Linux联盟
种方法可以使用 :-) 但在不少的场合,这种方法还是适用的。
(ordinal type)管用,那么我们先看一下顺序类型到底有那些呢:1)整型;2)字 6d6Linux联盟
符型;3)枚举型。 6d6Linux联盟
于是也就演化出三种在 case 语句里面使用字符串的方法(耐心看下去哦,最后一 6d6Linux联盟
种方法才是今天的重点:-p): 6d6Linux联盟
6d6Linux联盟
假如我们的具体应用如下(理想的,但是错误的写法): 6d6Linux联盟
6d6Linux联盟
6d6Linux联盟 |
法一:字符串转为整型 6d6Linux联盟
这应该是比较通行的方法了,主要是利用 TStringList。先把备选的字符串挨个 6d6Linux联盟
Add 进去,然后调用其 IndexOf 方法。该方法返回一个整数,表示待找字符串出 6d6Linux联盟
现在列表中的位置: 6d6Linux联盟
6d6Linux联盟
6d6Linux联盟 |
可以看到,这是比较麻烦的方法了,不过你可得记住这个方法,因为后面的讨论 6d6Linux联盟
将会讲到,这是最通用的方法。 6d6Linux联盟
另:当然,把字符串转化为整型后用于 case 不只这一种方法。另一种是通过把 6d6Linux联盟
备选项全部转化为等长度后合并为一个字符串,然后用 Pos 函数返回某字符串的 6d6Linux联盟
位置。在此不再累述,请查阅《程序员》杂志(具体哪一期不记得了:-()。 6d6Linux联盟
6d6Linux联盟
法二:字符串转为字符型 6d6Linux联盟
6d6Linux联盟
这应该是最简单的一种方法,不过局限性比较大。如果你的备选项的第 N 个字 6d6Linux联盟
符(N 应为常数)都互不相同,那么你赚到了。这样,就可以通过取出这个字符, 6d6Linux联盟
来唯一标识你的字符串: 6d6Linux联盟
6d6Linux联盟
6d6Linux联盟 |
不过如果你的备选项没有这样的特性,那么你就无缘使用这种方法了。 6d6Linux联盟
6d6Linux联盟
法三:字符串转为枚举型 6d6Linux联盟
6d6Linux联盟
这种方法主要用到 RTTI 的特性。该方法的主要思路是,先把所有的备选项声名 6d6Linux联盟
为一个枚举类型的值,那么我们只要把要找的字符串也转换为枚举型,那么就可以 6d6Linux联盟
用 case 语句了。那么通过什么办法把一个字符串转化为枚举型呢?往下看: 6d6Linux联盟
6d6Linux联盟
6d6Linux联盟 |
稍做解释:GetEnumvalue 函数返回一个字符串对应的枚举型的值在某枚举类型 6d6Linux联盟
中的位置(要知道枚举类型是有顺序的,要不怎么叫顺序类型呢:-)),然后通过 6d6Linux联盟
一个强制类型转换将这个值转化为枚举型。于是就实现了把字符串转化为枚举型的 6d6Linux联盟
操作。 6d6Linux联盟
6d6Linux联盟
可以看到,在 case 语句这一段,我们的使用和理想中的使用方法几乎是一样的! 6d6Linux联盟
毕竟枚举类型可以做到见名知意嘛。的确比用前两种方法看起来直观得多。 6d6Linux联盟
6d6Linux联盟
当然,这并不是万能的方法,如果你的备选项有一个不符合 Delphi 的变量名命 6d6Linux联盟
名法则(如'AK-47'或中文等),则不能将其声明为一个枚举型,于是就不能使用这 6d6Linux联盟
个方法。如果是这样你就只能使用前两种方法了。极端的情况下,至少你还有第一 6d6Linux联盟
种方法可以使用 :-) 但在不少的场合,这种方法还是适用的。