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()]);