# 四、String与其他数据类型的转换:
Java基础学习大纲
5.1.String与基本数据类型、包装类之间的转换:
a.结论:
- 1.字符串String --> 基本数据类型、包装类:
调用包装类的静态方法
:parseXxx(str)
- Integer包装类的public static int parseInt(String s):可以将由“数字”字符组成的字符串转换为整型。
- 2.基本数据类型、包装类 --> 字符串:
调用String重载的valueOf(xxx)方法
- 调用String类的public String valueOf(int n)可将int型转换为字符串
- 相应的
valueOf(byte b)、valueOf(long l)、valueOf(float f)、valueOf(double d)、valueOf(boolean b)
可由参数的相应类型到字符串的转换
b.测试:
package com.Java常用类;import org.junit.Test;import java.io.UnsupportedEncodingException;import java.util.Arrays;public class StringTest1 { @Test public void test1(){ String s1 = \"123\"; //int num = (int)s1;//错误的 int num = Integer.parseInt(s1); String s = String.valueOf(num);//\"123\" String s3 = num + \"\"; }
5.2.String 与 char[]之间的转换
a.结论:
- String --> char[] :
- 调用String 的
toCharArray()
:将字符串中的全部字符存放在一个字符数组中的方法 - getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin):提供了将指定索引范围内的字符串存放到数组中的方法。
- 调用String 的
- char[] --> String :
- 调用String的构造器:new String(arr)
- 调用String的构造器: new String(char[],int offset,int length)
b.测试:
package com.Java常用类;import org.junit.Test;import java.io.UnsupportedEncodingException;import java.util.Arrays;public class StringTest1 { @Test public void test2(){ String str1 = \"abc123\"; char[] charArray = str1.toCharArray(); for (int i = 0; i < charArray.length; i++) { System.out.println(charArray[i]); } char [] arr = new char[]{\'a\',\'b\',\'c\',\'d\'}; String s = new String(arr); System.out.println(s); }
5.3.String 与byte 之间的转换
a.结论:
- 1.
在utf-8中,一个汉字占用3字节,一个英文字母占用1字节;在GBK中,一个汉字占用2字节,一个英文字母占用1字节
- 1.编码:String --> byte[]:
- 调用String的
getBytes()
:使用平台的默认字符集将此 String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中 - 调用String的getBytes(String charsetName) :使用指定的字符集将此 String 编码到 byte 序列,并将结果存储到新的 byte 数组。
- 调用String的
- 2.解码:byte[] --> String:
调用String的构造器new String(arr)
:通过使用平台的默认字符集解码指定的 byte 数组,构造一个新的 String- 调用String的构造器new String(byte[],int offset,int length) :用指定的字节数组的一部分,即从数组起始位置offset开始取length个字节构造一个字符串对象
- 调用String的构造器new String(byte[], String charsetName ) 或 new String(byte[], int, int,String charsetName ):解码,按照指定的编码方式进行解码
b.说明:
- 编码:字符串 -->字节(看得懂—>看不懂的二进制数据)
- 解码:编码的逆过程,字节–>字符串(看不懂的二进制数据–>看得懂)
- 解码时,要求解码使用的字符集必须与编码时使用的字符集一致,否则就会出现乱码
c.测试:
package com.Java常用类;import org.junit.Test;import java.io.UnsupportedEncodingException;import java.util.Arrays;public class StringTest1 { @Test public void test3() throws UnsupportedEncodingException { String s1 = \"abc123中国\"; byte[] bytes = s1.getBytes();//使用默认的字符集utf-8,进行转换 System.out.println(Arrays.toString(bytes));//遍历转换过来的数组 byte[] gbks = s1.getBytes(\"gbk\");//使用gbk编码 System.out.println(Arrays.toString(gbks));//遍历转换过来的数组 System.out.println(\"*****************\"); String s = new String(bytes);//使用默认的字符集进行解码,把字节数组转字符串 System.out.println(s); String s2 = new String(gbks); System.out.println(s2);//乱码 String gbk = new String(gbks, \"gbk\");//使用gbk字符集解码 System.out.println(gbk); }}