2016-09-27 144 views
2

我想基于字段值返回枚举值。根据字段值显示枚举值

例如:

如果Free value field的值是“15”,我想回到枚举值“1”,因为枚举值1的标签是:'10 -20' ,因为15是10-20的范围我想返回该值。

我想为此创建显示方法。

我想我可以用switch case的场景来完成这个。
我该如何最好地设置它?

回答

3

当然,你可以用switch/case做到这一点,但如果你对付一个范围值和一组有限的结果值(你的枚举元素)然后进行简单if/else if可能是更适合

所以不是说明你的情况,分公司每一个可能的值(1,2,3,4 BLA BLA)做这样的事情

int x; 
; 

x = yourTable.YourField; 
if (x >= 1 && x <= 15) 
{ 
    return YourEnum::1to15; 
} 
else if (x >= 16 && x <= 20) 
{ 
    return YourEnum::16to20; 
} 
// other possible ranges 
else 
{ 
    throw YourEnum::Unknown; 
} 
1

是的,用switch声明你可以做到这一点。

试试这个:

int value; 

; 

switch (value) 
{  
    case 1, 2, 3, 4 ,5: 
     //Your code 
     break; 

    case 10, 11, 12, 13, 14, 15, 16, 17, 18 ,19, 20 : 
     //Your code 
     break;      

    default :    
     //Your code 
} 
1

我个人喜欢用整数除法得到聪明的想法。

如果你的范围将是10的组,那么你可以用10除以得到枚举值。

所以看到这个代码和下面的截图:

static void Job1(Args _args) 
{ 
    int   i; 
    MyEnum  value; 

    // Test #1 
    i  = 15;   // Your number 
    value = (i/10);  // Enum result 
    info(strFmt("Test #1: %1", value)); 

    // Test #2 
    i  = 5;   // Your number 
    value = (i/10);  // Enum result 
    info(strFmt("Test #2: %1", value)); 

    // Test #3 
    i  = 22;   // Your number 
    value = (i/10);  // Enum result 
    info(strFmt("Test #3: %1", value)); 
} 

enter image description here