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.测试:
java
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.测试:
java
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.测试:
java
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);
}
}