1. 程式人生 > 實用技巧 >Java字串06-字串排序

Java字串06-字串排序

package doudou;

import java.util.Arrays;
import java.util.Comparator;

public class test_stringSort {
    public static void main(String[] args) {
        String a = "11,44,22,3,321,55,33,0";
        String[] b = a.split(",");
        Arrays.sort(b, new Comparator<String>() {
            public
int compare(String o1, String o2) { return Integer.parseInt(o1) > Integer.parseInt(o2) ? -1 : Integer.parseInt(o1) < Integer.parseInt(o2) ? 1 : 0; } }); System.out.println(Arrays.toString(b)); System.out.println(b.getClass()); String replace
= Arrays.toString(b).replaceAll("[\\[\\]]", "\""); System.out.println(replace); System.out.println(replace.getClass()); } }

執行結果:

[321, 55, 44, 33, 22, 11, 3, 0]
class [Ljava.lang.String;
"321, 55, 44, 33, 22, 11, 3, 0"
class java.lang.String

請注意:  

Arrays.sort 排序有坑 如下圖,要排序的話,還是指定排序規則吧!
Array的sort()方法預設把所有元素先轉換為String再排序,
'
321'排在了'33'的前面:第一位相同,則比較第二位,因為第二位字元'2'比字元'3'的ASCII碼小,所以321 排在33前面