1、ArrayList的toArray
ArrayList提供了一个将List转为数组的一个非常方便的方法toArray。toArray有两个重载的方法:
(1)list.toArray();
(2)list.toArray(T[] a);
对于第一个重载方法,是将list直接转为Object[] 数组;
第二种方法是将list转化为你所需要类型的数组,当然我们用的时候会转化为与list内容相同的类型。
不明真像的同学喜欢用第一个,是这样写:
ArrayListlist=new ArrayList ();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);
//实际项目中ListsList = new ArrayList ();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
总结:
1、集合转数组用方法,比如:list.toArray(new String[list.size()]);
2、利用set去除list里面重复的数据
Setset = new HashSet ();for(int i=0; i < object.size(); i++){ set.add(object.get(i).toString());}
然后set转为数组:
set.toArray(new String[set.size()]);