继这个问题之后,在C#中编写Char.IsHex()函数的最佳方法是什么.到目前为止,我有这个,但不喜欢它:
bool CharIsHex(char c) {
c = Char.ToLower(c);
return (Char.IsDigit(c) || c == 'a' || c == 'b' || c == 'c' || c == 'd' || c == 'e' || c == 'f')
}
Run Code Online (Sandbox Code Playgroud)
Jef*_*tes 18
您可以将其编写为扩展方法:
public static class Extensions
{
public static bool IsHex(this char c)
{
return (c >= '0' && c <= '9') ||
(c >= 'a' && c <= 'f') ||
(c >= 'A' && c <= 'F');
}
}
Run Code Online (Sandbox Code Playgroud)
这意味着您可以将其称为它的成员char.
char c = 'A';
if (c.IsHex())
{
Console.WriteLine("We have a hex char.");
}
Run Code Online (Sandbox Code Playgroud)
Jer*_*ten 10
bool is_hex_char = (c >= '0' && c <= '9') ||
(c >= 'a' && c <= 'f') ||
(c >= 'A' && c <= 'F');
Run Code Online (Sandbox Code Playgroud)
Mic*_*urr 10
请注意,Char.IsDigit()返回true的代码点多于ASCII范围0x30到0x39中的数字.
例如,true从Char.IsDigit()返回的泰语数字字符:'0''1''2''3''4''5''6''7''8''9'
还有"全宽"字符,Char.IsDigit()对于:0xff10through ,返回true 0xff19.这些字形看起来就像ASCII字符0x30-0x39,所以如果你要接受他们,你也应该接受可能0xff21-0xff26和0xff41-0xff46它看起来就像"A" - "F"和"A" - "F".
如果您要支持ASCII范围之外的数字,您的用户可能希望您支持与其他地方存在的拉丁语'a'...'f'和'A'...'F'对应的字形ASCII范围之外的脚本.
就我个人而言,我认为我会更喜欢以下内容:
bool isHexChar = ('0' <= c) && (c <= '9') ||
('a' <= c) && (c <= 'f') ||
('A' <= c) && (c <= 'F');
Run Code Online (Sandbox Code Playgroud)
我认为这对人们来说可能不那么令人惊讶.