String[] data = new string[]{
"-3A01","-03A02",
"-301","-302",
"-201","-202",
"-101","-102",
"101","102",
"201","202",
"301","302",
"3A01","3A02",
"T3A01","T3A02"
};
我想按照字符串排序,排序原理,我理所应当的想到是单个字符比较大小后,进行排序,但是我排序后结果是:
-03A02 |
101 |
-101 |
102 |
-102 |
201 |
-201 |
202 |
-202 |
301 |
-301 |
302 |
-302 |
3A01 |
-3A01 |
3A02 |
T3A01 |
首先我感觉排序顺序错了,因为按照预想的规则应该负号开头的字符串是在一起的才对。
然后我查找资料在MSDN上看到这样一段话:
使用字词排序规则的操作执行一个区域敏感比较,在这个比较中可能会为非字母数字的 Unicode 字符分配特殊权重。 使用字词排序规则和特定区域的约定,连字符(“-”)的权重可能非常小,因此“coop”和“co-op”在排序列表中是紧挨着出现的。
然后基本就明白了,在C#中“-”负号的权限因为英文本身的缘故,自动降低的权限,导致这样的排序问题出现。
随后我寻找了下解决方案:
在List.sort方法中可以自己写排序方法,或者实现一个类继承IComparer这个接口,在实现的Compare中比较字符串的语句可以这样写:
string.Compare(x, y, StringComparison.Ordinal);
第三个参数给出的解释是“比较字符串使用序号排序规则”
如此比较“-”就不会自动被降低权限了。
还有一种可能性就是不存在这样的sort方法给我们用,比如DataTable中,在DataTable中我选择了这样的方法:
public class String2 : IComparable, IComparable
{
private string val;
public String2(string str)
{
val = str;
}
public override string ToString()
{
return this.val;
}
public int CompareTo(String2 obj)
{
if (obj == null)
return 1;
else
return string.Compare(val, obj.val, StringComparison.Ordinal);
}
public int CompareTo(object obj)
{
String2 other = obj as String2;
if (other == null)
return 1;
else
{
return string.Compare(val, other.val, StringComparison.Ordinal);
}
}
}
首先我自己声明了一种类型,继承了IComparable, IComparable,实现了里面的CompareTo方法;
然后在DataTable中列的类型设定为String2,如此排序就是正常的了。
以上就是在字符串排序上的遇到的问题和解决方案,不知道有没有更好的解决方案,希望大家指出错误,还是小菜鸟一个。