package cn.itcast.p1.generic.demo;
import java.util.ArrayList;
import java.util.Iterator;
public class GenericDemo {
/**
* @param args
*/
public static void main(String[] args) {
int[] arr = new int[4];
// arr[0] = 3.0;
//如何将一个Integer类型转成String类型呢
//首先设计编程就不合理,不能将Integer和String放到同一个容器中
//也就是,在申明容器的时候,只能装同一种类型的元素,不同的类型就用不同的容器装
ArrayList<String> al = new ArrayList<String>();
al.add("abc");//public boolean add(Object obj)
al.add("hahah");
// al.add(4);//al.add(new Integer(4));
Iterator<String> it = al.iterator();
while(it.hasNext()){
String str = it.next();
System.out.println(str);
}
}
}
package cn.itcast.p1.generic.demo;
import java.util.Iterator;
import java.util.TreeSet;
import cn.itcast.p2.bean.Person;
import cn.itcast.p3.comparator.ComparatorByName;
public class GenericDemo2 {
/**
* @param args
*/
public static void main(String[] args) {
TreeSet<Person> ts = new TreeSet<Person>(new ComparatorByName());
ts.add(new Person("lisi8",21));
ts.add(new Person("lisi3",23));
ts.add(new Person("lisi",21));
ts.add(new Person("lis0",20));
Iterator<Person> it = ts.iterator();
while(it.hasNext()){
Person p = it.next();
System.out.println(p.getName()+":"+p.getAge());
}
}
}
package cn.itcast.p2.bean;
public class Person implements Comparable<Person> {
private String name;
private int age;
public Person() {
super();
}
public Person(String name, int age) {
super();
this.name = name;
this.age = age;
}
public int compareTo(Person p){
// Person p = (Person)obj;
int temp = this.age - p.age;
return temp==0?this.name.compareTo(p.name):temp;
}
//!!!!用IDE快捷生成,重写hashCode对应本类属性的判断唯一性,将重复的对象去掉
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + age;
result = prime * result + ((name == null) ? 0 : name.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Person other = (Person) obj;
if (age != other.age)
return false;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
return true;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Person1111:"+getName()+":"+getAge();
}
package cn.itcast.p3.comparator;
import java.util.Comparator;
import cn.itcast.p2.bean.Person;
public class ComparatorByName implements Comparator<Person> {
@Override
public int compare(Person o1, Person o2) {
int temp = o1.getName().compareTo(o2.getName());
return temp==0? o1.getAge()-o2.getAge(): temp;
}
}
分享到:
相关推荐
cpp代码-模板 泛型 template<typename> template<class>
day14-ArrayList集合 1.ArrayList 1.1ArrayList类概述【理解】 ...ArrayList<String> array = new ArrayList<String>(); //添加元素 array.add("hello"); array.add("world"); array.add("java");
Java谜题1——表达式谜题 3<br>谜题1:奇数性 3<br>谜题2:找零时刻 4<br>谜题3:长整除 6<br>谜题4:初级问题 7<br>谜题5:十六进制的趣事 8<br>谜题6:多重转型 10<br>谜题7:互换内容 11<br>谜题8:Dos Equis 13...
为什么要有泛型集合(List<T>,Dictionary<K,V>,LinkedList<T>)? 1.为了避免装箱拆箱; 2.复用集合类里的 代码(算法) List<string> List<int> 1.概念 1.1官方:是一种特殊的【算法重用】机制。允许程序员在代码...
If you're confused about Android development, maybe it's time to open the door to a new world . TMVP is a Aop Architecture with Apt、AspectJ、Javassisit, which based on Realm+Databinding+MVP ...
泛型类vector<T>源码分析
Maven 依赖项: <dependency> <groupId>org.hibernate.javax.persistence</groupId> <artifactId>hibernate-jpa-2.0-api</artifactId> <version>1.0.1.Final</version></dependency><dependency> <groupId>org....
C++设计新思维:泛型编程与设计模式之应用.pdf 带目录书签
List<string> listS=new List<string>(); listS.Add(str); listS.Add(hello); string[] str=listS.ToArray(); 二、数组转List (从string[]转到List<string>) string[] str={str,string,abc}; List<string> listS=...
NULL 博文链接:https://840198532-qq-com.iteye.com/blog/1490705
1;继承一个泛型类时,必须为其传递泛型参数 ...public class Son<W,Y>:Father<int,string> 5:一个泛型子类继承一个泛型父类时,父类 的站位符是之前定义好的参数,不可以出现其他占位符 知识点 B:
C# 解析json格式数据为IList<T>
在C++标准中,STL被组织为下面的几个头文件:<string>、<vector>、<list>、<deque>、<algorithm>、<iterator>、<set>、<map>、<memory>、<numeric>、<queue>、<functional>、<stack>和<utility>。文件中主要介绍了...
在C++标准中,STL被组织为下面的几个头文件:<string>、<vector>、<list>、<deque>、<algorithm>、<iterator>、<set>、<map>、<memory>、<numeric>、<queue>、<functional>、<stack>和<utility>。文件中主要介绍了...
} }泛型函数: 代码如下:public T ReturnElement<T>() { throw new NotImplementedException(); } 但是当需要对MyElement进行实例化的时候,却不能使用new(),只要添加如下代码即可进行实例化了: 泛型类: 代码...
原书名: C++必知必会——图灵程序设计丛书 - <br>原出版社: <br>作者: (美)杜赫斯特 著,荣耀 译 <br>出版社: 人民邮电出版社 <br>书号: 7115141019 <br>出版日期:2006-1-1 <br>开本: 大16开 <br>页码: ...
例如,List<String>[] lists = Arrays.asList(new List<String>() {{ add("hello"); add("world"); }}); 泛型边界:可以使用泛型边界来限制类型参数的类型。例如,public static <T extends Comparable<T>> T max(T...
原书名: C++必知必会——图灵程序设计丛书 - <br>原出版社: <br>作者: (美)杜赫斯特 著,荣耀 译 <br>出版社: 人民邮电出版社 <br>书号: 7115141019 <br>出版日期:2006-1-1 <br>开本: 大16开 <br>页码: ...