C# 字符串按 ASCII碼 排序,注意其中的小坑

在和銀行作數據對接時,涉及到數據傳輸時的驗籤及加密。其中數據簽名方案中就要求數據項根據屬性名按 ASCII碼 進行升序排序。C#中的ASCII碼排序並非表面上那麼簡單,一不當心就入坑了。由於C#的排序默認並非按照ASCII碼進行排序的。舉個例子, 我有這樣一個字符串數組,而後對其排序。html

string[] vv = { "1", "2", "A", "a", "B", "b" };

Array.Sort(vv); //結果 1 2 a A b B

 

若是是按照ASCII碼進行排序的話,順序應該是: 1, 2, A, B, a, b  而實際排序後的結果則是:1, 2, a, A, b, B . 這也就是說Sort()方法默認狀況下並非按ASCII碼進行排序的。以後我也一樣測試了C#中的OrderBy()的排序,發現它默認狀況下也並非按照ASCII碼進行的排序。數組

string[] vv = { "1", "2", "A", "a", "B", "b" };

vv.OrderBy(x => x); //結果 1 2 a A b B

 

那麼既然默認排序不是按ASCII碼進行的排序,咱們要怎麼作呢? 看下面代碼,只須要在原來排序方法上再加個參數: string.CompareOrdinal。string.CompareOrdinal會把每一個字符先轉成相應的數值(如 a 轉爲數值 97),而後再對數值進行比較。post

Array.Sort(vv, string.CompareOrdinal); //ASCII排序

 

注:掉入這個坑是由於起初不知道如何對字符作ASCII碼排序,因而百度了一把。獲得的結果就是這個 C# 參數按照ASCII碼從小到大排序(字典序)  而當我採用這種方式時,銀行驗籤那步始終通不過,調試發現我排序後的結果和銀行那邊的不一樣。這篇博文的博主可能本身也沒發現這個坑吧。測試

相關文章
相關標籤/搜索