JAVA中String与int转换,list与数组转换,char数组与String转换
package Al2014;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class demo2 {
public static void main(String[] args) {
//int( Double, Float, Long 转成字串的方法大同小异.)-->string
int a=10;
String str=String.valueOf(a); //直接使用String类的静态方法,只产生一个对象
String str1=Integer.toString(a);
String str2=""+a;//会产生两个String对象
//String(字串转成 Double, Float, Long 的方法大同小异)------->int
String s1="1234";
int i1=Integer.parseInt(s1);//直接使用静态方法,不会产生多余的对象,但会抛出异常
int i2=Integer.valueOf(s1).intValue();//Integer.valueOf(s) 相当于 new Integer(Integer.parseInt(s)),也会抛异常,但会多产生一个对象
//char数组---------》》String
// 这里,关键是两个方法。
// (1)String类的toCharArray()方法,将字符串转换为字符数组
// (2)String类的valueOf()方法,将char类型的数组转换为字符串
char[] ch=new char[]{'a','b'};
String ch_s=new String(ch);
String ch_s1=String.valueOf(ch);
//String ===========>>char数组
char[] s_ch=ch_s1.toCharArray();
//list=============>数组
/* 1.List转换成为数组。(这里的List的实体是ArrayList)
调用ArrayList的toArray方法。
toArray
public <T> T[] toArray(T[] a)返回一个按照正确的顺序包含此列表中所有元素的数组;
返回数组的运行时类型就是指定数组的运行时类型。如果列表能放入指定的数组,则返回放入此列表元素的数组。
否则,将根据指定数组的运行时类型和此列表的大小分配一个新的数组。
如果指定的数组能容纳列表并有剩余空间(即数组的元素比列表的多),
那么会将数组中紧跟在集合末尾的元素设置为 null。
这对确定列表的长度很有用,但只 在调用方知道列表中不包含任何 null 元素时才有用。
指定者:
接口 Collection<E> 中的 toArray
指定者:
接口 List<E> 中的 toArray
覆盖:
类 AbstractCollection<E> 中的 toArray
参数:
a - 要存储列表元素的数组,如果它足够大的话;否则,它是一个为存储列表元素而分配的、具有相同运行时类型的新数组。
返回:
包含列表元素的数组。
抛出:
ArrayStoreException - 如果 a 的运行时类型不是此列表中每个元素的运行时类型的超类型。*/
List<String> list=new ArrayList<String>();
String[] arr=new String[3];
list.add("1");list.add("bb"); list.add("afaf");
arr=list.toArray(new String[list.size()]);
for(int i=0;i<3;i++)
{
System.out.println(arr[i]);
}
//数组----------------------》》》》》list
/*调用Arrays的asList方法.
asList
public static <T> List<T> asList(T... a)返回一个受指定数组支持的固定大小的列表。
(对返回列表的更改会“直写”到数组。)此方法同 Collection.toArray 一起,
充当了基于数组的 API 与基于 collection 的 API 之间的桥梁。返回的列表是可序列化的,并且实现了 RandomAccess。
此方法还提供了一个创建固定长度的列表的便捷方法,该列表被初始化为包含多个元素: */
List list1=Arrays.asList("qingxingege","biubiu");
System.out.println(list1);
}
}