1、ArrayList的toArray
ArrayList提供了一个将List转为数组的一个非常方便的方法toArray。toArray有两个重载的方法:
(1)list.toArray();
(2)list.toArray(T[] a);
对于第一个重载方法,是将list直接转为Object[] 数组;
第二种方法是将list转化为你所需要类型的数组,当然我们用的时候会转化为与list内容相同的类型。
不明真像的同学喜欢用第一个,是这样写:
ArrayList<String> list=new ArrayList<String>();
for (int i = 0; i < 10; i++) {
list.add(""+i);
}
String[] array= (String[]) list.toArray();
结果一运行,报错:Exception in thread "main" java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to [Ljava.lang.String;
原因一看就知道了,不能将Object[] 转化为String[],转化的话只能是取出每一个元素再转化。java中的强制类型转换只是针对单个对象的,想要偷懒将整个数组转换成另外一种类型的数组是不行的,这和数组初始化时需要一个个来也是类似的。像这样:
Object[] arr = list.toArray();
for (int i = 0; i < arr.length; i++) {
String e = (String) arr[i];
System.out.println(e);
}
所以第一个重构方法就不是那么好使了。
实际上,将list转化为array的时候,第二种重构方法更方便,用法如下:
String[] array =new String[list.size()];
list.toArray(array);
//实际项目中
List<String> sList = new ArrayList<String>();
for (MergeSoft mergeSoft : list) {
if(mergeSoft.getCollectSoft() != null){
sList.add(mergeSoft.getCollectSoft().getSid());
}
}
String[] sids = sList.toArray(new String[sList.size()]);
String[] devOnlyIds = collectSoftDao.queryDevOnlyIdBySid(sids);
2、采用set去重复数据,和set转array
public String[] queryDevOnlyIdBySid(String[] sid) {
String paramsStr = ArrayUtils.joinStringForSql(sid, "'", ",");//数组数据转为:'B07D26B8A919082612F9EFA55A9AACFC','3EF11C53F437A33A47C0B363B8D661BC'
String sql = "SELECT di.devOnlyId FROM cems_device_installsoft di WHERE sId IN ( "+paramsStr+" )";
List<Object> object = getSession().createSQLQuery(sql).list();
Set<String> set = new HashSet<String>();
for (int i = 0; i < object.size(); i++) {
set.add(object.get(i).toString());//object里有重复的数据,采用set去除重复的数据
}
String[] devOnlyIds = new String[set.size()];
//Set-->数组
set.toArray(devOnlyIds);
return devOnlyIds;
}
总结:
1、集合转数组用方法,比如:list.toArray(new String[list.size()]);
2、利用set去除list里面重复的数据
Set<String> set = new HashSet<String>();
for(int i=0; i < object.size(); i++){
set.add(object.get(i).toString());
}
然后set转为数组:
set.toArray(new String[set.size()]);