8:String类

String类

String类的特点: 字符串对象一旦被初始化就不会被改变。 

字符串是最常用的类型之一,所以为了使用方便java就给封装成了对象方便使用

 
  
  1.  public static void stringDemo2() { 
  2.  String s = "abc";//创建一个字符串对象在常量池中。   
  3.   String s1 = new String("abc");//创建两个对象一个new一个字符串对象在堆内存和常量池中。
  4. System.out.println(s==s1);//false 

System.out.println(s.equals(s1));

string类中的equals复写Object中的equals建立了string类自己的判断字符串对象是否相同的依据。

其实就是比较字符串内容。

 

 演示字符串定义的第一种方式,并明确字符串常量池的特点.

   池中没有就建立,池中有,直接用。

 
  
  1.  private static void stringDemo1() {
  2.   String s = "abc";//"abc"存储在字符串常量池中。
  3. // s = "nba";
  4.   String s1 = "abc";
  5.   System.out.println(s==s1);//true
  6. // System.out.println("s="+s);
  7. /输出nabss1是俩个字符串对象,s一开始指向了abc,又指向了nbaabc不变说的是这个意思
  8. }


常量池:

因为String类型一旦被初始化是不能被改变的,所以存放在常量池,存放在常量池中还有个很重要的原因:String s1 = “abs”;String s2=“abs”,这时s2并没有新建立一个对象,而是指向了s1这个对象。也就是说每当创建一个字符串时,并不是直接创建而是先到常量池中区找需要创建的对象是否存在,如果存在就不会再创建了。常量池中的元素是不会重复的,这也就是所谓的享元模式,例如当已经存在abs,这时需要创建ahk,这时常量池中只会增加两个字符h和k,然后在从常量池中抽出ahk对象。

特点:

1、String是一种特殊的数据类型,可创建对象。

2、通过String创建的对象分别可存在于常量池和堆内存中

3、String是一个final的类型,即不可被继承修改,一经初始化就终生不可改变。(要改变也是改变的引用)

4、常量池中的数据可共享,即两个引用变量可指向同一个字符串池中的字符串

5、Java中的任何对象都可写成字符串的形式。

6、既然String是对象,那就不得不说说null和“”的区别了。null是String对象指向为空,就是没有指向。而“”代表的是String对象指向的是一个空的字符串。

827512-20151026173303950-1013271408.png

匿名对象

匿名对象就是表示没有名字的对象,那么什么叫对象的名字了?

827512-20151026173308232-829006079.jpg 

 

一个字符串就是一个string的匿名对象

827512-20151026173312560-956566765.jpg 



String类的构造器

将字节数组或者字符数组转成字符串可以通过String类的构造函数完成。 

 
  
  1.  private static void stringConstructorDemo2() { 
  2.   char[] arr = {'w','a','p','q','x'};//字符串转换成数组
  3.   String s = new String(arr,1,3);//字符的一部分转换成数组,从1角标取
  4.   System.out.println("s="+s); 输出s=apq
  5.  }

 
  
  1.  public static void stringConstructorDemo() {
  2.   String s = new String();
  3. //等效于String s = ""内容一样,地址不一样,都是指向空字符串; 但不等效String s = null;
  4. 一般用String s = "",就行了,能被共享,当需要用构造器传数据,需要用new
  5.  byte[] arr = {97,66,67,68}; 
  6. String s1 = new String(arr); //将数组变为字符,输出了abcd,编码转成了字节存储起来
  7.   System.out.println("s1="+s1);
  8.    } 


String类的方法(常见功能
 按照面向对象的思想对字符串进行功能分类

  字符串常见的操作方法:(String str = "hello java")

1、获取。
1.1 字符串中的包含的字符数,也就是字符串的长度。
int length():获取长度。str.length()//结果为10
1.2 根据位置获取位置上某个字符。
char charAt(int index)://charAt(1),结果是e
1.3 根据字符获取该字符在字符串中位置。//indexOf(’l‘)结果是2
int indexOf(int ch):返回的是ch在字符串中第一次出现的位置。
int indexOf(int ch, int fromIndex) :从fromIndex指定位置开始,获取ch在字符串中出现的位置。
int indexOf(String str):返回的是str在字符串中第一次出现的位置。
int indexOf(String str, int fromIndex) :从fromIndex指定位置开始,获取str在字符串中出现的位置。
int lastIndexOf(int ch) :从后往前找,但是字符串中的角标是没有变的。

 

  827512-20151026173315747-896805571.png
System.out.println("substring:"+s.substring(2,4));//cd

   
2、判断。
2.1 字符串中是否包含某一个子串。
boolean contains(str):
特殊之处:indexOf(str):可以索引str第一次出现位置,如果返回-1.表示该str不在字符串中存在。所以,也可以用于对指定判断是否包含。if(str.indexOf("aa")!=-1)
而且该方法即可以判断,有可以获取出现的位置。
2.2 字符中是否有内容。
boolean isEmpty(): 原理就是判断长度是否为0. 
2.3 字符串是否是以指定内容开头。
boolean startsWith(str);
2.4 字符串是否是以指定内容结尾。
boolean endsWith(str);
2.5 判断字符串内容是否相同。复写了Object类中的equals方法。
boolean equals(str);
2.6 判断内容是否相同,并忽略大小写。
boolean equalsIgnoreCase();
   

3、转换。
3.1 将字符数组转成字符串。
构造函数:String(char[])
 String(char[],offset,count):将字符数组中的一部分转成字符串。
静态方法:
static String copyValueOf(char[]);
static String copyValueOf(char[] data, int offset, int count) 
static String valueOf(char[]):
3.2 将字符串转成字符数组。**
char[] toCharArray():
3.3 将字节数组转成字符串。
String(byte[])
String(byte[],offset,count):将字节数组中的一部分转成字符串。
3.4 将字符串转成字节数组。
byte[]  getBytes():
3.5 将基本数据类型转成字符串。
static String valueOf(int)
static String valueOf(double)
//3+"";//String.valueOf(3);
特殊:字符串和字节数组在转换过程中,是可以指定编码表的。
4,替换
String replace(oldchar,newchar);
5,切割
String[] split(regex);
6,子串。获取字符串中的一部分。
String substring(begin);
String substring(begin,end);
7,转换,去除空格,比较。
7.1 将字符串转成大写或则小写。
String toUpperCase();
String toLowerCase();
7.2 将字符串两端的多个空格去除。
String trim();
7.3 对两个字符串进行自然顺序的比较。
int compareTo(string);//大于返回正数,等于返回0,小于返回负数,且值为ASSII值之差。


827512-20151026173319200-2082633142.png
827512-20151026173321497-561711704.png
 
 
     
  1.  private static void stringMethodDemo_4() {
  2.  
  3.  System.out.println("abc".compareTo("aqz"));
  4.  }
  5.   stringMethodDemo_4();
  6.  }

827512-20151026173325013-1110043213.png
 
    
  1. public class StringObjectDemo {
  2. public static void main(String[] args) {
  3. // String s1 = "abc";
  4. // String s2 = "abc";
  5. // intern():对字符串池进行操作的
  6. String s1 = new String("abc");
  7. String s2 = s1.intern();
  8. System.out.println(s1 == s2); // false
  9. }
  10. }
 
 
     
  1. public class StringDemo {
  2. public static void main(String[] args) {
  3. String str = "asdfghjaszxsa.java";
  4. method_get(str);
  5. print("------------------------------------------");
  6. method_is(str);
  7. print("------------------------------------------");
  8. method_transform(str);
  9. print("------------------------------------------");
  10. method_replace(str);
  11. print("------------------------------------------");
  12. method_split(str);
  13. print("------------------------------------------");
  14. method_sub(str);
  15. print("------------------------------------------");
  16. method_change();
  17. }
  18. /*
  19. * String获取方法 凡是获取的字符或者是字符串不存在,就返回-1
  20. */
  21. private static void method_get(String str) {
  22. // 获取字符串的长度
  23. int length = str.length();
  24. print("length: " + length);
  25. // 根据位置获取位置上的某个字符
  26. char ch = str.charAt(1);
  27. print("ch: " + ch);
  28. // 根据字符获取该字符在字符串中的位置
  29. int index = str.indexOf("index: " + 'a');// 获取该字符第一次出现的位置
  30. print("index: " + index);
  31. // int indexOf(int ch, int fromIndex) :从fromIndex指定位置开始,获取ch在字符串中出现的位置。
  32. int indexf = str.indexOf('a', 2);
  33. print("indexf: " + indexf);
  34. // int indexOf(String str):返回的是str在字符串中第一次出现的位置。
  35. int indexs = str.indexOf("as");
  36. print("indexs: " + indexs);
  37. // int indexOf(String str, int fromIndex)
  38. // :从fromIndex指定位置开始,获取str在字符串中出现的位置。
  39. int indexsf = str.indexOf("as", 3);
  40. print("indexsf: " + indexsf);
  41. // int lastIndexOf(int ch)
  42. int indexlast = str.lastIndexOf('a');
  43. print("indexlast: " + indexlast);
  44. }
  45. /*
  46. * String中的判断
  47. */
  48. private static void method_is(String str) {
  49. // 字符串中是否包含某一个子串
  50. /*
  51. * 特殊之处:indexOf(str):可以索引str第一次出现位置,如果返回-1.表示该str不在字符串中存在。
  52. * 所以,也可以用于对指定判断是否包含。 if(str.indexOf("aa")!=-1) 而且该方法即可以判断,有可以获取出现的位置。
  53. */
  54. boolean iscon = str.contains("asd");
  55. print("iscon: " + iscon);
  56. // 字符中是否有内容。boolean isEmpty(): 原理就是判断长度是否为0.
  57. boolean isemp = str.isEmpty();
  58. print("isemp: " + isemp);
  59. // 字符串是否是以指定内容开头。boolean startsWith(str);
  60. boolean start = str.startsWith("asd");
  61. boolean startoffset = str.startsWith("sd", 1);
  62. print("start: " + start);
  63. print("startoffset: " + startoffset);
  64. // 字符串是否是以指定内容结尾。boolean endsWith(str);
  65. boolean end = str.endsWith(".java");
  66. print("end: " + end);
  67. // 判断字符串内容是否相同。复写了Object类中的equals方法。boolean equals(str);
  68. boolean equal = str.equals("asdfghjaszxsa.java");
  69. print("equal: " + equal);
  70. // 判断内容是否相同,并忽略大小写。boolean equalsIgnoreCase();
  71. boolean equ = "AASD".equalsIgnoreCase("Aasd");
  72. print("equ: " + equ);
  73. }
  74. /*
  75. * 转换
  76. */
  77. private static void method_transform(String str) {
  78. char[] chs = { 'a', 's', 'd', 'f', 'g' };
  79. byte[] bts = { 'a', 's', 'd', 'f', 'g' };
  80. // 将字符数组转成字符串
  81. String trChStr = new String(chs);
  82. String trChStrO = new String(chs, 1, 3);
  83. print("trChStr: " + trChStr + "....trChStrO: " + trChStrO);
  84. String copyvalueof = String.copyValueOf(chs);
  85. print("copyvalueof: " + copyvalueof);
  86. // 将字符串转成字符数组****
  87. char[] tochar = str.toCharArray();
  88. for (int x = 0; x < tochar.length; x++) {
  89. print("char[" + x + "] = " + tochar[x]);
  90. }
  91. // 将字节数组转成字符串。
  92. String trBtStr = new String(bts);
  93. String trBtStrO = new String(bts, 1, 3);
  94. print("trBtStr: " + trBtStr + "....trBtStrO: " + trBtStrO);
  95. // 将字符串转成字节数组。byte[] getBytes():
  96. // 特殊:字符串和字节数组在转换过程中,是可以指定编码表的。
  97. byte[] getBts = str.getBytes();
  98. for (int x = 0; x < getBts.length; x++) {
  99. print("byte[" + x + "] = " + getBts[x]);
  100. }
  101. // 将基本数据类型转成字符串。static String valueOf(数据类型)
  102. // 3+"";//String.valueOf(3);
  103. String num = String.valueOf(2);
  104. print("num: " + num);
  105. }
  106. /*
  107. * 替换
  108. */
  109. private static void method_replace(String str) {
  110. // 如果要替换的字符不存在,返回的还是原串。
  111. String newStr = str.replace('a', 'm');// 替换掉所有的该字符
  112. print(str);
  113. print(newStr);
  114. String newSt = str.replace("asd", "qqq");
  115. print(str);
  116. print(newSt);
  117. }
  118. /*
  119. * 切割
  120. */
  121. private static void method_split(String str) {
  122. // String[] split(regex);
  123. String[] strs = str.split("s");
  124. for (int x = 0; x < strs.length; x++) {
  125. print("String[" + x + "] = " + strs[x]);
  126. }
  127. }
  128. /*
  129. * 获取字符串中的一部分
  130. */
  131. private static void method_sub(String str) {
  132. print(str.substring(2));// 从指定位置开始到结尾。如果角标不存在,会出现字符串角标越界异常。
  133. print(str.substring(2, 4));// 包含头,不包含尾。s.substring(0,s.length());
  134. }
  135. /*
  136. * 转换,去除空格,比较。
  137. */
  138. private static void method_change() {
  139. String s = " Hello Java ";
  140. print(s.toLowerCase());// 转小写
  141. print(s.toUpperCase());// 转大写
  142. print(s.trim());// 去空格
  143. // 对两个字符串进行自然顺序的比较
  144. String s1 = "aaa";
  145. String s2 = "aaa";
  146. print(s1.compareTo(s2));// 大于返回正数,小于返回负数,相等返回0
  147. }
  148. private static void print(Object obj) {
  149. System.out.println(obj);
  150. }

System.out.println("abc".concat("kk"));连接字符串,没什么用,直接连就行
System.out.println("abc"+"kk");

System.out.println(String.valueOf(4)+1);//41将基本数据类型变为字符串,再连接
System.out.println(""+4+1);和上一样

练习
 * 1,给定一个字符串数组。按照字典顺序进行从小到大的排序。 
 * {"nba","abc","cba","zz","qq","haha"}
 *
 * 思路:
 * 1,对数组排序。可以用选择,冒泡都行。
 * 3,问题:以前排的是整数,比较用的比较运算符,可是现在是字符串对象。
 *   字符串对象怎么比较呢?对象中提供了用于字符串对象比较的功能。
 
 
    
  1. public class StringTest_1 {
  2. public static void main(String[] args) {
  3. String[] arr = { "nba", "abc", "cba", "zz", "qq", "haha" };
  4. printArray(arr); // 原来的
  5. sortString(arr);
  6. printArray(arr); // 比较后的
  7. }
  8. public static void sortString(String[] arr) {
  9. for (int i = 0; i < arr.length - 1; i++) {
  10. for (int j = i + 1; j < arr.length; j++) {
  11. if (arr[i].compareTo(arr[j]) > 0)// 字符串比较用compareTo方法
  12. swap(arr, i, j);
  13. }
  14. }
  15. }
  16. private static void swap(String[] arr, int i, int j) {
  17. String temp = arr[i];
  18. arr[i] = arr[j];
  19. arr[j] = temp;
  20. }
  21. public static void printArray(String[] arr) {
  22. System.out.print("[");
  23. for (int i = 0; i < arr.length; i++) {
  24. if (i != arr.length - 1)
  25. System.out.print(arr[i] + ", ");
  26. else
  27. System.out.println(arr[i] + "]");
  28. }
  29. }
  30. }
2,一个子串在整串中出现的次数。
 * "nbaernbatynbauinbaopnba"
 * 思路:
 * 1,要找的子串是否存在,如果存在获取其出现的位置。这个可以使用indexOf完成。
 * 2,如果找到了,那么就记录出现的位置并在剩余的字符串中继续查找该子串,
 * 而剩余字符串的起始位是出现位置+子串的长度.
 * 3,以此类推,通过循环完成查找,如果找不到就是-1,并对 每次找到用计数器记录。
 
    
  1. public class StringTest_2 {
  2. public static void main(String[] args) {
  3. String str = "nbaernbatnbaynbauinbaopnba";
  4. String key = "nba";
  5. int count = getKeyStringCount_2(str, key);
  6. System.out.println("count=" + count);
  7. }
  8. public static int getKeyStringCount_2(String str, String key) {
  9. int count = 0;
  10. int index = 0;
  11. while ((index = str.indexOf(key, index)) != -1) {
  12. index = index + key.length();
  13. count++;
  14. }
  15. return count;
  16. }
  17. /**
  18. * 获取子串在整串中出现的次数。
  19. */
  20. public static int getKeyStringCount(String str, String key) {
  21. // 1,定义计数器。
  22. int count = 0;
  23. // 2,定义变量记录key出现的位置。
  24. int index = 0;
  25. while ((index = str.indexOf(key)) != -1) {
  26. str = str.substring(index + key.length());//这个前面的str别不写
  27. count++;
  28. }
  29. return count;
  30. }
  31. }

 * 3,两个字符串中最大相同的子串。
 * "qwerabcdtyuiop"
 * "xcabcdvbn"
 *
 * 思路:
 * 1,既然取得是最大子串,先看短的那个字符串是否在长的那个字符串中。
 * 如果存在,短的那个字符串就是最大子串。
 * 2,如果不是呢,那么就将短的那个子串进行长度递减的方式去子串,去长串中判断是否存在。
 * 如果存在就已找到,就不用在找了。
 
 
    
  1. public class StringTest_3 {
  2. public static void main(String[] args) {
  3. String s1 = "qwerabcdtyuiop";
  4. String s2 = "xcabcdvbn";
  5. String s = getMaxSubstring(s2, s1);
  6. System.out.println("s=" + s);
  7. }
  8. /**
  9. * 获取最大子串
  10. *
  11. * @param s1
  12. * @param s2
  13. * @return
  14. */
  15. public static String getMaxSubstring(String s1, String s2) {
  16. String max = null, min = null;
  17. max = (s1.length() > s2.length()) ? s1 : s2;
  18. min = max.equals(s1) ? s2 : s1;
  19. System.out.println("max=" + max);
  20. System.out.println("min=" + min);
  21. for (int i = 0; i < min.length(); i++) {
  22. for (int a = 0, b = min.length() - i; b != min.length() + 1; a++, b++) {
  23. String sub = min.substring(a, b);
  24. // System.out.println(sub);
  25. if (max.contains(sub))
  26. return sub;
  27. }
  28. }
  29. return null;
  30. }
  31. }

 * 4,模拟一个trim功能一致的方法。去除字符串两端的空白
 * 思路:
 * 1,定义两个变量。
 * 一个变量作为从头开始判断字符串空格的角标。不断++。
 * 一个变量作为从尾开始判断字符串空格的角标。不断--。
 * 2,判断到不是空格为止,取头尾之间的字符串即可。
 
 
    
  1. public class StringTest_4 {
  2. public static void main(String[] args) {
  3. String s = " ab c ";
  4. s = myTrim(s);
  5. System.out.println("-" + s + "-");
  6. }
  7. public static String myTrim(String s) {
  8. int start = 0, end = s.length() - 1;
  9. while (start <= end && s.charAt(start) == ' ') {
  10. start++;
  11. }
  12. while (start <= end && s.charAt(end) == ' ') {
  13. end--;
  14. }
  15. return s.substring(start, end + 1);
  16. }
  17. }


练习五:将字符串反转。  
 
    
  1. /*
  2. 思路:
  3. 1,将字符串变成数组。
  4. 2,对数组反转。
  5. 3,将数组变成字符串。
  6. */
  7. public class ReverseString {
  8. public static void main(String[] args) {
  9. String str = "shag klh";
  10. String out = reverseString(str);
  11. System.out.println(out);
  12. }
  13. /*
  14. * 将字符串反转
  15. */
  16. private static String reverseString(String str) {
  17. // 将字符串变成数组
  18. char[] chs = str.toCharArray();
  19. // 将数组反正,也就是收尾调换
  20. reverseArray(chs);
  21. return new String(chs);
  22. }
  23. private static void reverseArray(char[] chs) {
  24. char temp;
  25. for (int start = 0, end = chs.length - 1; start < end; start++, end--) {
  26. temp = chs[start];
  27. chs[start] = chs[end];
  28. chs[end] = temp;
  29. }
  30. }


StringBuffer

   * StringBuffer:就是字符串缓冲区。

   * 用于存储数据的容器。

   * 特点:

   * 1,长度的可变的。

   * 2,可以存储不同类型数据。

   * 3,最终要通过toString方法变成字符串进行使用。

   * 4,可以对字符串进行修改。

Stringbuffer类:可以被修改的字符序列

827512-20151026173336341-1961625535.png 

827512-20151026173359685-2042336403.png 

   * 既然是一个容器对象。应该具备什么功能呢?

 

1、存储。
StringBuffer append():将指定数据作为参数添加到已有数据结尾处。不支持byte和char,需要对其进行转换才能操作。
StringBuffer insert(index,数据):可以将数据插入到指定index位置。
2、删除。
StringBuffer delete(start,end):删除缓冲区中的数据,包含start,不包含end。
StringBuffer deleteCharAt(index):删除指定位置的字符。
3、获取。
char charAt(int index) 
int indexOf(String str) 
int lastIndexOf(String str) 
int length() 
String substring(int start, int end) 
4、修改。
StringBuffer replace(start,end,string);
void setCharAt(int index, char ch) ;
5、反转。
StringBuffer reverse();
6、将缓冲区中指定数据存储到指定字符数组中。
void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)//第一个参数是说StringBuffer 从哪开始取值,第二个就是在哪结束啦,第三个参数是插入到哪个数据,第四个是说从数组中的哪个索引开始插入。

   *

   * 增删改查  C(create)U(update)R(read)D(delete)

   *

 
   
  1. public class StringBufferDemo {
  2. public static void main(String[] args) {
  3. bufferMethodDemo_2();
  4. }
  5. private static void bufferMethodDemo_2() {
  6. StringBuffer sb = new StringBuffer("abce");
  7. // sb.delete(1, 3);//ae
  8. // 清空缓冲区
  9. // sb.delete(0,sb.length());
  10. // sb = new StringBuffer();
  11. // sb.replace(1, 3, "nba");
  12. // sb.setCharAt(2, 'q');
  13. // sb.setLength(10);
  14. // System.out.println("sb:"+sb);
  15. // System.out.println("len:"+sb.length());
  16. System.out.println(sb.reverse());
  17. }
  18. private static void bufferMethodDemo_1() {
  19. StringBuffer sb = new StringBuffer("abce");
  20. // sb.append("xixi");
  21. sb.insert(2, "qq");
  22. System.out.println(sb.toString());
  23. }
  24. public static void bufferMethodDemo() {
  25. // 创建缓冲区对象。
  26. StringBuffer sb = new StringBuffer();
  27. sb.append(4).append(false);// .append("haha");输出4falsehahh,连起来了
  28. sb.insert(1, "haha");//4hahhfalse
  29. // sb.append(true);//4hahhfalsetru,一个一个append和.append效果一样
  30. System.out.println(sb);
  31. }
  32. }

StringBuilder

   * jdk1.5以后出现了功能和StringBuffer一模一样的对象。就是StringBuilder

   * 不同的是:

   * StringBuffer是线程同步的。通常用于多线程。

   * StringBuilder是线程不同步的。通常用于单线程。 它的出现提高效率。

   *

   * jdk升级:

   * 1,简化书写。

   * 2,提高效率。

   * 3,增加安全性。

eg:

 
   
  1. public class StringBuilderTest {
  2. public static void main(String[] args) {
  3. int[] arr = { 3, 1, 5, 3, 8 };
  4. String s = arrayToString_2(arr);
  5. System.out.println(s);
  6. }
  7. public static String arrayToString_2(int[] arr) {
  8. StringBuilder sb = new StringBuilder();
  9. sb.append("[");
  10. for (int i = 0; i < arr.length; i++) {
  11. if (i != arr.length - 1)
  12. sb.append(arr[i] + ", ");
  13. else
  14. sb.append(arr[i] + "]");
  15. }
  16. return sb.toString();
  17. }
  18. /**
  19. *
  20. * 将一个int数组变成字符串。
  21. */
  22. public static String arrayToString(int[] arr) {
  23. String str = "[";
  24. for (int i = 0; i < arr.length; i++) {
  25. if (i != arr.length - 1)
  26. str += arr[i] + ", ";
  27. else
  28. str += arr[i] + "]";
  29. }
  30. return str;
  31. }
  32. }
 
    
  1. public class StringBuilderTest {
  2. public static void main(String[] args) {
  3. StringBuilder s1 = new StringBuilder("hello");
  4. StringBuilder s2 = new StringBuilder("java");
  5. show(s1, s2);
  6. System.out.println(s1 + "......." + s2);
  7. }
  8. private static void show(StringBuilder s1, StringBuilder s2) {
  9. s1.append(s2);
  10. s1 = s2;
  11. //输出hellojava.......java
  12. }
  13. }


 基本数据类型对象包装类

   * 为了方便操作基本数据类型值,将其封装成了对象,在对象中定义了属性和行为丰富了该数据的操作。

   * 用于描述该对象的类就称为基本数据类型对象包装类。

   * byte Byte

   * short Short

   * int Integer

   * long Long

   * float Float

   * double Double

   * char Character

   * boolean Boolean

   * 该包装对象主要用基本类型和字符串之间的转换。

  •  基本类型--->字符串

  1. 基本类型数值+""
  2. 用String类中的静态方法valueOf(基本类型数值);
  3. 用Integer的静态方法valueO(基本类型数值);

  • 字符串--->基本类型

  1. 使用包装类中的静态方法   xxx parseXxx("xxx类型的字符串");*****

   * int parseInt("intstring");

   * long parseLong("longstring");

   * boolean parseBoolean("booleanstring");

   * 只有Character没有parse方法

     2.如果字符串被Integer进行对象的封装。

   * 可使用另一个非静态的方法,intValue();

   * 将一个Integer对象转成基本数据类型值。

 
   
  1. System.out.println(Integer.MAX_VALUE);
  2. System.out.println(Integer.toBinaryString(-6));
  3. int num = 4;
  4. Integer i = new Integer(5);
  5. int x = Integer.parseInt("123");
  6. System.out.println(Integer.parseInt("123")+1);
  7. Integer i = new Integer("123");

  8. System.out.println(i.intValue());

    1.  
             
      1. Integer a = new Integer("89");
      2. Integer b = new Integer(89);
      3. System.out.println(a==b);//flase
      4. System.out.println(a.equals(b));//ture
      5. // System.out.println(3>3);
      6. System.out.println(a.compareTo(b));//0,内容相同,地址不同

  * 整数具备不同的进制体现。

   *

   * 十进制-->其他进制。

   * toBinaryString

   * toOctalString

   * toHexString

   *

   * 其他进制-->十进制。

   * parseInt("string",radix)

   *

  十进制-->其他进制。

 
   
  1.   System.out.println(Integer.toBinaryString(60));
  2.   System.out.println(Integer.toOctalString(60));
  3.   System.out.println(Integer.toHexString(60));
  4. // System.out.println(Integer.toString(60,16));
其他进制-->十进制。

 
   
  1. class IntegerDemo
  2. {
  3. public static void sop(String str)
  4. {
  5. System.out.println(str);
  6. }
  7. public static void main(String[] args)
  8. {
  9. //整数类型的最大值。
  10. //sop("int max :"+Integer.MAX_VALUE);
  11. // 将一个字符串转成整数。
  12. int num = Integer.parseInt("123");//必须传入数字格式的字符串。
  13. //long x = Long.parseLong("123");
  14. // sop("num="+(num+4));
  15. // sop(Integer.toBinaryString(-6));
  16. // sop(Integer.toHexString(60));
  17. int x = Integer.parseInt("3c",16); //后面传入前面是什么进制的
  18. sop("x="+x);
自动装箱拆箱

 
      
  1. class IntegerDemo1   
  2. {  
  3.     public static void main(String[] args)   
  4.     {  
  5.           
  6. //      Integer x = new Integer(4);  
  7.   
  8.         Integer x = 4;//自动装箱。//new Integer(4)  
  9.   
  10.         x = x/* x.intValue() */ + 2;//x+2:x 进行自动拆箱。变成成了int类型。和2进行加法运算  
  11.                     //再将和进行装箱赋给x  
  12.   
  13.         Integer m = 128;  
  14.         Integer n = 128;  
  15.   
  16.         sop("m==n:"+(m==n));//结果为false  
  17.   
  18.         Integer a = 127;  
  19.         Integer b = 127;  
  20.   
  21.         sop("a==b:"+(a==b));//结果为true。因为a和b指向了同一个Integer对象 
  22.           //因为当数值在byte范围内容,对于新特性,如果该数值已经存在,则不会在开辟新的空间  
  23.     }  
  24.   
  25.     public static void method()  
  26.     {  
  27.         Integer x = new Integer("123");  
  28.   
  29.         Integer y = new Integer(123);  
  30.   
  31.         sop("x==y:"+(x==y));  
  32.         sop("x.equals(y):"+x.equals(y));  
  33.     }  


 






转载于:https://www.cnblogs.com/sixrain/p/4911860.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值