您好,登錄后才能下訂單哦!
小編這次要給大家分享的是詳解Java靜態泛型使用方法,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
前言:當工具類對多個模型類進行排序,比較等操作的時候,需要書寫大量重復代碼,因為懶人總要想怎么省事的,所以考慮使用泛型這個玩意簡化代碼
案例:當前存在兩個模型類,Fruit和Person,他們都需要排序方法而且業務邏輯各不相同,因此需要分別寫兩個排序方法,但因為排序相同的地方太多,唯一的區別就是判斷兩個對象的大小關系,于是在此做簡化操作。
執行步驟:
1、編寫模型類接口 interface Model
public interface Model<T> { public int compareTo(T model); }
這里僅需要定義一個比較的方法
2、編寫Person類 class Person
public class Person implements Model<Person> { private String name; public Person(String _name) { this.name = _name; } @Override public int compareTo(Person _person) { return this.name.compareToIgnoreCase(_person.name); } }
Fruit的代碼我就不放上來了,因為為了舉例我這倆的比較方法寫的是一樣的,但是實際業務代碼可能是不一樣的
3、編寫工具類 class Sort
public class Sort { public static <T extends Model<T>> void sort(List<T> list) { for (int i = 0; i < list.size() - 1; i++) { for (int j = i; j < list.size(); j++) { if (list.get(i).compareTo(list.get(j)) > 0) { T swap = list.get(i); list.set(i, list.get(j)); list.set(j, swap); } } } } }
隨便找了個排序算法就套進去了
然后就是主函數的調用
public class Main{ public static void main(String[] args){ LinkedList<Person> list = new LinkedList<>(); list.add(new Person("admin")); list.add(new Person("root")); list.add(new Person("huawei")); list.add(new Person("cisco")); Sort.sort(list); for (Person item : list) { System.out.println(item.toString()); } } }
4、Fruit類只要按照Person類一樣實現Model的compareTo方法就可以使用Sort.sort方法進行排序了
后記:最開始我的想法是寫個Model接口,在接口中寫一個compareTo方法,然后形參類型不知道咋寫了
如果寫Model的話,Person實現compareTo方法的時候形參類型也肯定是Model
我這塊的邏輯比較簡單,用name字段進行比較,如果在Model接口加上getName方法后,怎么看都不舒服
Model類不一定都有name字段,而且這樣Person類就可能會與Fruit類進行比較
雖然可以在邏輯上不這么搞,但是怎么都看得難受啊,于是就想到用泛型搞這玩意
看完這篇關于詳解Java靜態泛型使用方法的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。