1. String类:

不可变的字符序列(如:String str = “atguigu”; str += “javaEE”)底层使用char[]存放。String 是 final的。

String例子过程图:

1. 关注于String常用的方法!
2. String类与基本数据类型、包装类;与字符数组、字节数组

1.字符串 与基本数据类型、包装类之间转换
①字符串 —>基本数据类型、包装类:调用相应的包装类的parseXxx(String str);
②基本数据类型、包装类—>字符串:调用字符串的重载的valueOf()方法

2.字符串与字节数组间的转换
①字符串—->字节数组:调用字符串的getBytes()
②字节数组—->字符串:调用字符串的构造器

3.字符串与字符数组间的转换
①字符串—->字符数组:调用字符串的toCharArray();
②字符数组—->字符串:调用字符串的构造器

4.String与StringBuffer的转换
①String —>StringBuffer:使用StringBuffer的构造器:new StringBuffer(String str);
②StringBuffer—–>String:使用StringBuffer的toString()方法

StringBuffer类:可变的字符序列
StringBuilder类:可变的字符序列,jdk5.0新加入的,效率更高,线程不安全。
常用的方法:添加:append(…) 删除 delete(int startIndex, int endIndex) 修改:setCharAt(int n ,char ch) 查询:charAt(int index)
插入:insert(int index, String str) 反转reverse() 长度:length()

注:String类的不可变性

String类方法:

import org.junit.Test;public class TestString {/** 1.字符串 与基本数据类型、包装类之间转换* ①字符串 --->基本数据类型、包装类:调用相应的包装类的parseXxx(String str);* ①基本数据类型、包装类--->字符串:调用字符串的重载的valueOf()方法* * 2.字符串与字节数组间的转换* ①字符串---->字节数组:调用字符串的getBytes()* ②字节数组---->字符串:调用字符串的构造器* * 3.字符串与字符数组间的转换* ①字符串---->字符数组:调用字符串的toCharArray();* ②字符数组---->字符串:调用字符串的构造器*/@Testpublic void test5(){//1.字符串 与基本数据类型、包装类之间转换String str1 = "123";int i = Integer.parseInt(str1);System.out.println(i);String str2 = i + "";str2 = String.valueOf(i);System.out.println(str2);System.out.println();//2.字符串与字节数组间的转换String str = "abcd123";byte[] b = str.getBytes();for(int j = 0;j < b.length;j++){System.out.println((char)b[j]);}String str3 = new String(b);System.out.println(str3);System.out.println();//3.字符串与字符数组间的转换String str4 = "abc123中国人";char[] c = str4.toCharArray();for(int j = 0;j < c.length;j++){System.out.println(c[j]);}String str5 = new String(c);System.out.println(str5);}/**  public String substring(int startpoint)public String substring(int start,int end):返回从start开始到end结束的一个左闭右开的子串。start可以从0开始的。pubic String replace(char oldChar,char newChar)public String replaceAll(String old,String new)public String trim():去除当前字符串中首尾出现的空格,若有多个,就去除多个。public String concat(String str):连接当前字符串与strpublic String[] split(String regex):按照regex将当前字符串拆分,拆分为多个字符串,整体返回值为String[]*/@Testpublic void test4() {String str1 = "北京尚硅谷教育北京";String str2 = "上海尚硅谷教育";String str3 = str1.substring(2, 5);System.out.println(str3);System.out.println(str1);String str4 = str1.replace("北京", "东京");System.out.println(str4);// 东京尚硅谷教育东京System.out.println(str1);// 北京尚硅谷教育北京String str5 = "   abc   d  ";String str6 = str5.trim();System.out.println("----" + str6 + "----");System.out.println("----" + str5 + "----");String str7 = str1.concat(str2);System.out.println(str1);System.out.println(str7);System.out.println();String str8 = "abc*d-e7f-ke";String[] strs = str8.split("-");for(int i = 0;i < strs.length;i++){System.out.println(strs[i]);}}/** public int length() public char charAt(int* index):返回在指定index位置的字符。index从0开始 public boolean equals(Object* anObject):比较两个字符串是否相等。相等返回true。否则返回false public int compareTo(String* anotherString) public int indexOf(String s):返回s字符串在当前字符串中首次出现的位置。若没有,返回-1* public int indexOf(String s ,int* startpoint):返回s字符串从当前字符串startpoint位置开始的,首次出现的位置。 public int* lastIndexOf(String s):返回s字符串最后一次在当前字符串中出现的位置。若无,返回-1 public int* lastIndexOf(String s ,int startpoint) public boolean startsWith(String* prefix):判断当前字符串是否以prefix开始。 public boolean endsWith(String* suffix):判断当前字符串是否以suffix结束。 public boolean regionMatches(int* firstStart,String other,int otherStart ,int length):* 判断当前字符串从firstStart开始的子串与另一个字符串other从otherStart开始,length长度的字串是否equals*/@Testpublic void test3() {String str1 = "abccdefghijkbcc";String str2 = "bcc";String str3 = "jkbcc";System.out.println(str2.length());System.out.println(str1.charAt(10));System.out.println(str1.equals(str2));System.out.println(str2.equals("abcc"));System.out.println(str1.compareTo(str2));System.out.println(str1.indexOf(str2, 5));System.out.println(str1.lastIndexOf(str2));System.out.println(str1.startsWith("abcd"));System.out.println(str1.regionMatches(10, str3, 0, str3.length()));}/** String:代表不可变的字符序列。底层使用char[]存放。* String 是final的。*/@Testpublic void test1(){String str1 = "JavaEE";String str2 = "JavaEE";String str3 = new String("JavaEE");String str4 = "JavaEE" + "Android";String str5 = "Android";String str6 = str1 + str5;str5 = str5 + "Handoop";String str7 = str6.intern();String str8 = "JavaEEAndroid";System.out.println(str1 == str2);//trueSystem.out.println(str1 == str3);//falseSystem.out.println(str1.equals(str3));//trueSystem.out.println(str4 == str6);//falseSystem.out.println(str4.equals(str6));//trueSystem.out.println(str7 == str4);//trueSystem.out.println(str4 == str8);//truePerson p1 = new Person("AA");Person p2 = new Person("AA");System.out.println("^_^"+ (p1.name == p2.name));//true}
}class Person{String name;Person(String name){this.name = name;}
}

String小Demo:

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;/** 1.模拟一个trim方法,去除字符串两端的空格。2.将一个字符串进行反转。将字符串中指定部分进行反转。比如将“abcdefg”反转为”abfedcg”3.获取一个字符串在另一个字符串中出现的次数。比如:获取“ab”在 “abkkcadkabkebfkabkskab”中出现的次数4.获取两个字符串中最大相同子串。比如:str1 = "abcwerthelloyuiodef";str2 = "cvhellobnm"5.对字符串中字符进行自然顺序排序。练习:I am a student!   写一个方法:实现输出 !student a am I*/
public class StringDemo {public static void main(String[] args) {String str = "   abc  de  ";//str = "    ";String str1 = myTrim(str);System.out.println(str1);String str2 = "abcdefg";String str3 = reverseString(str2,2,5);String str4 = reverseString1(str2,2,5);System.out.println(str3);//abfedcgSystem.out.println(str4);int i = getTime("abkkcadkabkebfkabkskab","abk");System.out.println(i);List<String> strs5 = getMaxSubString("abcwerthelloyuiodef","abcwecvhellobnm");System.out.println(strs5);String str6 = "aediewfn";String str7 = sort(str6);System.out.println(str7);}//5.对字符串中字符进行自然顺序排序。public static String sort(String str){char[] c = str.toCharArray();Arrays.sort(c);return new String(c);}//4.获取两个字符串中最大相同子串。public static List<String> getMaxSubString(String str1,String str2){String maxStr = (str1.length() > str2.length())? str1 : str2;String minStr = (str1.length() < str2.length())? str1 : str2;int len = minStr.length();List<String> list = new ArrayList<>();for(int i = 0;i < len;i++){for(int x = 0,y = len - i;y <= len;x++,y++){String str = minStr.substring(x, y);if(maxStr.contains(str)){list.add(str);}}if(list.size() != 0){return list;}}return null;}//3.获取一个字符串在另一个字符串中出现的次数。判断str2在str1中出现的次数public static int getTime(String str1,String str2){int count = 0;int len;while((len = str1.indexOf(str2)) != -1){count++;str1 = str1.substring(len + str2.length());}return count;}//将一个字符串进行反转。将字符串中指定部分进行反转。(法二)  在考虑使用StringBuffer将此算法优化!public static String reverseString1(String str,int start,int end){String str1 = str.substring(0, start);for(int i = end;i >= start;i--){char c = str.charAt(i);str1 += c;}str1 += str.substring(end + 1);return str1;}//2.将一个字符串进行反转。将字符串中指定部分进行反转。比如将“abcdefg”反转为”abfedcg”public static String reverseString(String str,int start,int end){char[] c = str.toCharArray();//字符串--->字符数组return reverseArray(c,start,end);}public static String reverseArray(char[] c,int start,int end){for(int i = start,j = end;i < j;i++,j--){char temp = c[i];c[i] = c[j];c[j] = temp;}//字符数组--->字符串return new String(c);}//1.模拟一个trim方法,去除字符串两端的空格。public static String myTrim(String str){int start = 0;int end = str.length() - 1;while(start < end && str.charAt(start) == ' '){start++;}while(start < end && str.charAt(end) == ' '){end--;}return str.substring(start, end + 1);}
}

实现字符串反转的三种方法

public class TestString {public static void main(String[] args) {String str1 = reverse("helloworld");System.out.println(str1);String str2 = reverse1("helloworld");System.out.println(str2);String str3 = reverse2("helloworld");System.out.println(str3);}//方法一public static String reverse(String str){char[] c = str.toCharArray();for(int x=0, y = c.length-1;x < y;x++,y--){char temp = c[x];c[x] = c[y];c[y] = temp;}return new String(c);}//方法二public static String reverse1(String str){StringBuffer sb = new StringBuffer(str);StringBuffer sb1 = sb.reverse();return sb1.toString();}//方法三public static String reverse2(String str){StringBuffer sb = new StringBuffer();for (int i = str.length()-1;i >= 0; i--) {sb.append(str.charAt(i));}return sb.toString();}
}

2.时间、日期类:

2.1 System类
currentTimeMillis():返回当前时间的long型值。此long值是从1970年1月1日0点0分00秒开始到当前的毫秒数。
此方法常用来计算时间差。

2.2 Date类:java.util.Date
1. Date d = new Date();//返回当前时间的Date:Mon May 12 15:17:01 CST 2014

Date d1 = new Date(15231512541241L);//返回形参处此long型值对应的日期

//getTime():返回当前日期对应的long型值。 toString()

2.3 SimpleDateFormat:java.text.SimpleDateFormat
格式化 :日期—>文本 使用SimpleDateFormat的format()方法
解析:文本—>日期 使用SimpleDateFormat的parse()方法
1.格式化1

  SimpleDateFormat sdf = new SimpleDateFormat();String date = sdf.format(new Date());System.out.println(date);//14-5-12 下午3:24

2.格式化2

SimpleDateFormat sdf1 = new SimpleDateFormat(“EEE, d MMM yyyy HH:mm:ss Z”);
date = sdf1.format(new Date());
System.out.println(date);//星期一, 12 五月 2014 15:29:16 +0800

3.解析:

Date date1 = sdf.parse(“14-5-12 下午3:24”);
System.out.println(date1);
date1 = sdf1.parse(“星期一, 12 五月 2014 15:29:16 +0800”);
// date1 = sdf1.parse(“14-5-12 下午3:24”);
System.out.println(date1);

2.4 Calendar:日历类
2.4.1获取实例:Calendar c = Calendar.getInstance();
2.4.2 get()/set()/add()/date getTime()/setTime()

3.Math类

4.BigInteger BigDecimal类

第十二章:Java_常用类相关推荐

  1. stm32 文件系统dma大小_「正点原子NANO STM32F103开发板资料连载」第二十二章 DMA 实验...

    1)实验平台:[正点原子] NANO STM32F103 开发板 2)摘自<正点原子STM32 F1 开发指南(NANO 板-HAL 库版)>关注官方微信号公众号,获取更多资料:正点原子 ...

  2. 【JAVA SE】第十二章 流(Stream)、IO流和文件(File)

    第十二章 流(Stream).IO和文件(File) 文章目录 第十二章 流(Stream).IO和文件(File) 一.流(Stream) 1.什么是流 2.流的分类 二.IO流 1.字节输入流(I ...

  3. 第十二章_网络搭建及训练

    文章目录 第十二章 网络搭建及训练 CNN训练注意事项 第十二章 TensorFlow.pytorch和caffe介绍 12.1 TensorFlow 12.1.1 TensorFlow是什么? 12 ...

  4. 高级shell编程笔记(第十二章 外部过滤器,程序和命令)

    第十二章 外部过滤器,程序和命令 标准的UNIX命令使得脚本更加灵活.通过简单的编程结构把shell指令和系统命令结合起来,这才是脚本能力的所在. 12.1 基本命令 新手必须掌握的初级命令 ls 基 ...

  5. MLAPP————第十二章 隐线性模型

    第十二章 隐线性模型 12.1 要素分析(factor analysis) 在我们之前提到的混合模型中,数据的生成都是由某个隐状态控制的,然后是那个隐状态控制的分布生成的,但是这样的模型在表示上还是具 ...

  6. 【信息系统项目管理师】第二十二章 信息系统安全管理(考点汇总篇)

    [信息系统项目管理师]第二十二章 信息系统安全管理(考点汇总篇) 考点分析与预测 信息安全为高级科目独有的章节,在第三版教材中有66页的内容.需要掌握的知识点非常多,且知识点非常散,在考试中上午一般考 ...

  7. 【正点原子Linux连载】第六十二章 Linux SPI驱动实验 -摘自【正点原子】I.MX6U嵌入式Linux驱动开发指南V1.0

    1)实验平台:正点原子阿尔法Linux开发板 2)平台购买地址:https://item.taobao.com/item.htm?id=603672744434 2)全套实验源码+手册+视频下载地址: ...

  8. 20、【易混淆概念集】-第十二章 采购甲乙双方的职责 合同类型 采购工作说明书 索赔管理 采购管理

    本讲主要介绍PMBOK第十二章中的重要知识点,帮助你进一步理解. 本节目录 一.采购甲乙双方的职责 二.合同类型 三.采购工作说明书 四.索赔管理 五.采购管理 11 问 一.采购甲乙双方的职责 在复 ...

  9. linux脚本求命令行上整数和,《Linux命令行与shell脚本编程大全》 第二十二章 学习札记...

    <Linux命令行与shell脚本编程大全> 第二十二章 学习笔记 第二十二章:使用其他shell 什么是dash shell Debian的dash shell是ash shell的直系 ...

  10. 【Linux命令】《鸟哥Linux基础》第十二章 学习shell脚本

    第十二章 学习shell脚本 通常利用shell脚本完成服务器的检测工作,不涉及大量运算. 12.1 简单shell脚本介绍 12.2 简单shell脚本练习 12.2.1 简单范例 范例1:永远的开 ...

最新文章

  1. 公司网络推广浅析网站想要“久居”首页的方法有哪些?
  2. informix clob转oracle 乱码_Oracle 视图-序列-权限-表-事务
  3. Vue—基础概念—指令
  4. 虚拟机几种网络连接方式的区别
  5. 使用SecueCRT在本地主机与远程主机之间交互文件
  6. android studio卡顿解决方案
  7. tensorflow里面函数记录
  8. 天猫回应“双11数据造假”:已启动司法流程;小米折叠手机专利曝光;ASP.NET感染勒索软件|极客头条...
  9. Java中调用本地代码
  10. 实战篇:Oracle分区表之在线重定义
  11. 南卡Runer骨传导耳机全能战机王
  12. 如何制作启动U盘安装系统?
  13. java汉诺塔(含汉诺塔问题的详解)
  14. 论文阅读 6 | Bayesian Meta-Learning for the Few-Shot Setting via Deep Kernels
  15. 权威杂志评选出的十个最伟大的公式
  16. 一波骚操作,用 Python 给照片换颜色
  17. Apache利用.htaccess实现域名跳转
  18. 2021-04-16
  19. 尚鼎峰:抖音播放量不够高?如何制作吸睛封面?
  20. Gtalent如何帮助HR确定人才测评指标

热门文章

  1. 抢占乡镇渠道 中国手机厂商比苹果有经验
  2. js 调用 oc 的解释
  3. 彻底清除备份域服务器数据元的方法
  4. ASP.Net上传文件带进度条、显示剩余时间!
  5. flink DDL读取kafka数据-Scala嵌入DDL形式
  6. Spark Streaming在Spark Web UI上的显示办法
  7. Linux中查询显卡硬件的几种命令(记录)
  8. 深度学习(二十二)——ESPCN, FSRCNN, VESPCN, SRGAN, DemosaicNet, MemNet, RDN, ShuffleSeg
  9. 页面加载成功后调用_在微信小程序里实现图片预加载组件
  10. javaweb分页查询oracle,JavaWeb项目 利用Oracle数据库实现分页查看细讲