网络管理系统中故障管理的目标是,线上seo关键词优化软件工具,wordpress文章页尾添加信息,怎么制作网页里面的内容#xff08;全部来自“韩顺平教育”#xff09;
常用类
一、包装类
1、包装类的分类
①针对八种基本数据类型相应的引用类型--包装类
②有了类的特点#xff0c;就可以调用类中的方法
③
基本数据类型包装类booleanBooleancharCharacterbyteByteshortShortintInteger…全部来自“韩顺平教育”
常用类
一、包装类
1、包装类的分类
①针对八种基本数据类型相应的引用类型--包装类
②有了类的特点就可以调用类中的方法
③
基本数据类型包装类booleanBooleancharCharacterbyteByteshortShortintIntegerlongLongfloatFloatdoubleDouble
2、包装类和基本数据的转换 1jdk5前的手动装箱和拆箱方式装箱基本类型 - 包装类型反之拆箱 //手动装箱 int - Integer int n1 100; Integer integer new Integer(n1); Integer integer1 Integer.valueOf(n1); //手动拆箱 Integerint - int int i integer.intValue(); 2jdk5以后含jdk5自动装箱和自动拆箱 int n2 200; //自动装箱 int - Integer Integer integer1 n2; //底层使用的是Integer.valueOf(n2) //自动拆箱 int n3 integer2; //底层仍然使用的是intValue()方法 3自动装箱底层调用的是valueOf方式比如Interger.valueOf() 3、包装类型和String类型的相互转换
//包装类(Integer) - String
Integer i 100; //自动装箱//方式1
String str1 i ;//方式2
String str2 i.toString();//方式3
String str3 String.valueOf(i);//String - 包装类(Integer)
String str4 12345;Integer i2 Integer.parseInt(str4); //使用到自动装箱Integer i3 new Integer(str4); //构造器
4、Integer类和Character类的常用方法
System.out.println(Integer.MIN_VALUE); //返回最小值
System.out.println(Integer.MAX_VALUE); //返回最大值
System.out.println(Character.isDigit(a)); //判断是不是数字
System.out.println(Character.isLetter(a)); //判断是不是字母
System.out.println(Character.isUpperCase(a)); //判断是不是大写
System.out.println(Character.isLowerCase(a)); //判断是不是小写
System.out.println(Character.isWhitespace(a)); //判断是不是空格
System.out.println(Character.toUpperCase(a)); //转成大写
System.out.println(Character.toLowerCase(A)); //转成小写 二、String类
1、String类的理解和创建对象
1String对象用于保存字符串也就是一组字符序列
2字符串常量对象是用双引号括起的字符序列
3字符串的字符使用Unicode字符编码一个字符不区分字母还是汉字占两个字节
4String类较常用的构造器 String s1 new String(); String s2 new String(String original); String s3 new String(char[] a); String s4 new String(char[] a, int startIndex, int count);
5String类实现了接口Serializable【String可以串行化即在网络上传输】 接口Comparable【String对象可以比较大小】
6String是final类不能被其他的类继承
7String有属性private final char value[]用于存放字符串内容
8注意value是一个final类型不可以修改即value不能指向新的地址但是单个字符内容是可以改变的 2、创建String对象的两种方式 方式一直接赋值 String s hsp; 先从常量池查看是否有“hsp”数据空间如果有直接指向如果没有则重新构建然后指向。s最终指向的是常量池的空间地址 方式二调用构造器 String s new String(hsp); 先在堆中创建空间里面维护了value属性指向常量池的hsp空间。如果常量池没有“hsp”重新创建如果有直接通过value指向。最终指向的是堆中的空间地址 三、字符串的特性
1、String是一个final类代表不可变的字符序列
2、字符串是不可变的。一个 字符串对象一旦被分配其内容是不可变的
3、注意String c1 ab cd; 常量相加看的是池 String c1 a b; 变量相加是在堆中 四、String类的常见方法 1equals //区分大小写判断内容是否相等 String str1 “hello”;
String str2 Hello;
System.out.println(str1.equals(str2)); 2equalslgnoreCase //忽略大小写的判断内容是否相等 String username johN;
if (john.equalsIgnoreCase(username)) {System.out.println(Success!);
} else {System.out.println(Failure!);
} 3length //获取字符的个数字符串的长度 System.out.println(韩顺平.length()); 4indexOf //获取字符在字符串中第1次出现的索引索引从0开始如果找不到返回-1 String s1 werterweg;
int index s1.indexOf();
System.out.println(index);// 3
System.out.println(weIndex s1.indexOf(we));//0 5lastIndexOf //获取字符在字符串中最后1次出现的索引索引从0开始若找不到返回-1 s1 werterweg;
index s1.lastIndexOf();
System.out.println(index);//11
System.out.println(ter 的位置 s1.lastIndexOf(ter));//4 6substring //截取指定范围的子串 String name hello,张三;
//下面 name.substring(6) 从索引 6 开始截取后面所有的内容
System.out.println(name.substring(6));//截取后面的字符
//name.substring(0,5)表示从索引 0 开始截取截取到索引 5-14 位置
System.out.println(name.substring(2,5));//llo 7trim //去前后空格 8charAt //获取某索引处的字符注意不能用Str[index]这种方式 9toUpperCase //转换成大写 String s heLLo;
System.out.println(s.toUpperCase());//HELLO 10toLowerCase //转换成小写 11concat //拼接字符串 String s1 宝玉;
s1 s1.concat(林黛玉).concat(薛宝钗).concat(together);
System.out.println(s1);//宝玉林黛玉薛宝钗 together 12replace //替换字符串中的字符 s1 宝玉 and 林黛玉 林黛玉 林黛玉;//s1.replace() 方法执行后返回的结果才是替换过的.
// 注意对 s1 没有任何影响String s11 s1.replace(宝玉, jack);System.out.println(s1);//宝玉 and 林黛玉 林黛玉 林黛玉System.out.println(s11);//jack and 林黛玉 林黛玉 林黛玉 13split //分割字符串对于某些分割字符串需转义 比如 \\ String poem 锄禾日当午,汗滴禾下土,谁知盘中餐,粒粒皆辛苦;// 1. 以 , 为标准对 poem 进行分割 , 返回一个数组
// 2. 在对字符串进行分割时如果有特殊字符需要加入 转义符 \String[] split poem.split(,); 14toCharArray //转换成字符数组 s happy;
char[] chs s.toCharArray();
for (int i 0; i chs.length; i) {
System.out.println(chs[i]);
} 15compareTo //比较两个字符串的大小 // (1) 如果长度相同并且每个字符也相同就返回 0
// (2) 如果长度相同或者不相同但是在进行比较时可以区分大小
// 就返回 if (c1 ! c2) {
// return c1 - c2;
// }
// (3) 如果前面的部分都相同就返回 str1.len - str2.len
String a jcck;// len 3
String b jack;// len 4
System.out.println(a.compareTo(b)); // 返回值是 c - a 2 的值 16format //格式字符串 at 格式字符串
/* 占位符有:
* %s 字符串 %c 字符 %d 整型 %.2f 浮点型
*
*/String name john;
int age 10;
double score 56.857;
char gender 男;//1. %s , %d , %.2f %c 称为占位符
//2. 这些占位符由后面变量来替换
//3. %s 表示后面由 字符串来替换
//4. %d 是整数来替换
//5. %.2f 表示使用小数来替换替换后只会保留小数点两位, 并且进行四舍五入的处理
//6. %c 使用 char 类型来替换String formatStr 我的姓名是%s 年龄是%d成绩是%.2f 性别是%c.希望大家喜欢我;String info2 String.format(formatStr, name, age, score, gender);System.out.println(info2 info2); 五、StringBuffer类
1、基本介绍
1java.lang.StringBuffer代表可变的字符序列可以对字符串内容进行增删
2很多方法与String相同但StringBuffer是可变长度的
3StringBuffer是一个容器
4StringBuffer的直接父类是AbstractStringBuilder
5在父类AbstractStringBuilder中有属性 char[] value不是final
6StringBuffer是一个final类不能被继承
7因为StringBuffer字符内容是存在char[] value所以增加/删除等变化不用每次都更换地址即不是每次创建新对象所以效率高于String 2、String VS StringBuffer
①String保存的是字符串常量里面的值不能更改每次String类的更新实际上就是更改地址效率较低
②StringBuffer保存的是字符串变量里面的值可以更改每次StringBuffer的更新实际上可以更新内容不用每次更新地址效率较高
③两者相互转换
//String - StringBufferString str hello tom;//方式1 使用构造器
//注意返回的才是StringBuffer对象对str本身没有影响StringBuffer stringBuffer new StringBuffer(str);//方式2 使用的是append方法StringBuffer stringBuffer1 new StringBuffer();
stringBuffer1 stringBuffer1.append();//StringBuffer - String
StringBuffer stringBuffer3 new StringBuffer(零零零零);//方式1 使用StringBuffer提供的toString方法
String s stringBuffer3.toString();//方式2 使用构造器
String s1 new String(stringBuffer3);
3、StringBuffer类常见方法
StringBuffer s new StringBuffer(hello);//增s.append(,); // hello,
s.append(张三丰);//hello,张三丰
s.append(赵敏).append(100).append(true).append(10.5);//hello,张三丰赵敏 100true10.5
System.out.println(s);//hello,张三丰赵敏 100true10.5//删
/*
* 删除索引为start end 处的字符
* 解读: 删除 11~14 的字符 [11, 14)
*/s.delete(11, 14);
System.out.println(s);//hello,张三丰赵敏 true10.5//改
//使用 周芷若 替换 索引 9-11 的字符 [9,11)s.replace(9, 11, 周芷若);
System.out.println(s);//hello,张三丰周芷若 true10.5//查找指定的子串在字符串第一次出现的索引如果找不到返回-1int indexOf s.indexOf(张三丰);
System.out.println(indexOf);//6//插
//在索引为 9 的位置插入 赵敏,原来索引为 9 的内容自动后移s.insert(9, 赵敏);
System.out.println(s);//hello,张三丰赵敏周芷若 true10.5//长度System.out.println(s.length());//22
System.out.println(s); 六、StringBuilder类
1、基本介绍
①一个可变的字符序列。此类提供一个与StringBuffer的兼容API但不保证同步StringBuilder不是线程安全。此类被设计用作StringBuffer的一个简易替换用在字符串缓冲区被单个线程使用的时候。如果可能建议优先采用该类因为在大多数实现中它比StringBuffer要快。
②在StringBuilder上的主要操作是append和insert方法可重载这些方法以接受任意类型的数据。
③StringBuilder的直接父类是AbstractStringBuilder在父类AbstractStringBuilder中有属性char[] value不是final
④StringBuilder实现Serializable接口即StringBuilder的对象可以串行化
⑤StringBuilder是一个final类不能被继承
⑥因为StringBuilder字符内容是存在char[] value所以增加/删除等变化不用每次都更换地址即不是每次创建新对象所以效率高于String
2、常用方法
StringBuilder和StringBuffer均代表可变的字符序列方法是一样的所以使用和StringBuffer一样。
注意StringBuilder的方法没有做互斥的处理即没有synchronized关键字因此在单线程的情况下使用。 3、String、StringBuffer和StringBuilder比较 ①StringBuilder和StringBuffer非常类似均代表可变的字符序列而且方法也一样 ②String不可变字符序列效率低但是复用率高 ③StringBuffer可变字符序列效率较高增删、线程安全 ④StringBuilder可变字符序列效率最高、线程不安全 ⑤String使用注意说明 string s a; //创建了一个字符串 s b; //实际上原来的“a”字符串已经丢弃了现在又产生了一个字符 串sb也就是“ab”如果多次执行这些改变串内容的操作会导致大量副本字符串对象存留在内存中降低效率。如果这样的操作放到循环中会极大影响程序的性能 结论如果我们对String做大量的修改不要使用String 4、String、StringBuffer和StringBuilder的选择 使用的原则结论 ①如果字符串存在大量的修改操作一般使用StringBuffer或StringBuilder ②如果字符串存在大量的修改操作并在单线程的情况使用StringBuilder ③如果字符串存在大量的修改操作并在多线程的情况使用StringBuffer ④如果字符串很少修改被多个对象引用使用String比如配置信息等 七、Math类
1、基本介绍
Math类包含用于执行基本数学运算的 方法如初等指数、对数、平方根和三角函数
2、方法均为静态方法 //1.abs 绝对值
int abs Math.abs(-9);
System.out.println(abs);//9//2.pow 求幂
double pow Math.pow(2, 4);//2 的 4 次方
System.out.println(pow);//16//3.ceil 向上取整,返回该参数的最小整数(转成 double);
double ceil Math.ceil(3.9);
System.out.println(ceil);//4.0//4.floor 向下取整返回该参数的最大整数(转成 double)
double floor Math.floor(4.001);
System.out.println(floor);//4.0//5.round 四舍五入 Math.floor(该参数0.5)
long round Math.round(5.51);
System.out.println(round);//6//6.sqrt 求开方
double sqrt Math.sqrt(9.0);
System.out.println(sqrt);//3.0//7.random 求随机数
// random 返回的是 0 x 1 之间的一个随机小数// 思考请写出获取 a-b 之间的一个随机整数,a,b 均为整数 比如 a 2, b7
// 即返回一个数 x 2 x 7// Math.random() * (b-a) 返回的就是 0 数 b-a// (1) (int)(a) x (int)(a Math.random() * (b-a 1) )// (2) 使用具体的数给小伙伴介绍 a 2 b 7
// (int)(a Math.random() * (b-a 1) ) (int)( 2 Math.random()*6)
// Math.random()*6 返回的是 0 x 6 小数
// 2 Math.random()*6 返回的就是 2 x 8 小数// (int)(2 Math.random()*6) 2 x 7
// (3) 公式就是 (int)(a Math.random() * (b-a 1) )for(int i 0; i 100; i) {
System.out.println((int)(2 Math.random() * (7 - 2 1)));
}//max , min 返回最大值和最小值
int min Math.min(1, 9);
int max Math.max(45, 90);
System.out.println(min min);
System.out.println(max max); 八、Arrays类
1、常见方法
Arrays里面包含了一系列静态方法用于管理或操作数组比如排序和搜索
Integer[] integers {1, 20, 90};//直接使用 Arrays.toString 方法显示数组返回数组的字符串形式System.out.println(Arrays.toString(integers));//演示 sort 方法的使用
Integer arr[] {1, -1, 7, 0, 89};//进行排序//1. 可以直接使用冒泡排序 , 也可以直接使用 Arrays 提供的 sort 方法排序
//2. 因为数组是引用类型所以通过 sort 排序后会直接影响到 实参 arr
//3. sort 重载的也可以通过传入一个接口 Comparator 实现定制排序
//4. 调用 定制排序 时传入两个参数 (1) 排序的数组 arr
// (2) 实现了 Comparator 接口的匿名内部类 , 要求实现 compare 方法
Arrays.sort(arr, new Comparator() {Overridepublic int compare(Object o1, Object o2) {Integer i1 (Integer) o1;Integer i2 (Integer) o2;return i2 - i1;}
});Integer[] arr {1, 2, 90, 123, 567};
// binarySearch 通过二分搜索法进行查找要求必须排好//1. 使用 binarySearch 二叉查找
//2. 要求该数组是有序的. 如果该数组是无序的不能使用 binarySearch
//3. 如果数组中不存在该元素就返回 return -(low 1); // key not found.
int index Arrays.binarySearch(arr, 567);
System.out.println(index index);//copyOf 数组元素的复制
//1. 从 arr 数组中拷贝 arr.length 个元素到 newArr 数组中
//2. 如果拷贝的长度 arr.length 就在新数组的后面 增加 null
//3. 如果拷贝长度 0 就抛出异常 NegativeArraySizeException
//4. 该方法的底层使用的是 System.arraycopy()
Integer[] newArr Arrays.copyOf(arr, arr.length);
System.out.println(拷贝执行完毕后);//ill 数组元素的填充
Integer[] num new Integer[]{9,3,2};//1. 使用 99 去填充 num 数组可以理解成是替换原理的元素
Arrays.fill(num, 99);
System.out.println(num 数组填充后);
System.out.println(Arrays.toString(num));//equals 比较两个数组元素内容是否完全一致
Integer[] arr2 {1, 2, 90, 123};
//1. 如果 arr 和 arr2 数组的元素一样则方法 true;
//2. 如果不是完全一样就返回 falseboolean equals Arrays.equals(arr, arr2);
System.out.println(equals equals);//asList 将一组值转换成 list
//1. asList 方法会将 (2,3,4,5,6,1)数据转成一个 List 集合
//2. 返回的 asList 编译类型 List(接口)
//3. asList 运行类型 java.util.Arrays#ArrayList, 是 Arrays 类的
// 静态内部类 private static class ArrayListE extends AbstractListE
// implements RandomAccess, java.io.Serializable
List asList Arrays.asList(2,3,4,5,6,1); 九、System类
1、常见方法
//exit 退出当前程序
// System.out.println(ok1);// //1. exit(0) 表示程序退出
// //2. 0 表示一个状态 , 正常的状态
// System.exit(0);
// System.out.println(ok2);//arraycopy 复制数组元素比较适合底层调用
// 一般使用 Arrays.copyOf 完成复制数组
int[] src{1,2,3};
int[] dest new int[3];// dest 当前是 {0,0,0}//1. 主要是搞清楚这五个参数的含义
//2.
// 源数组
// * param src the source array.
// srcPos 从源数组的哪个索引位置开始拷贝
// * param srcPos starting position in the source array.
// dest : 目标数组即把源数组的数据拷贝到哪个数组
// * param dest the destination array.
// destPos: 把源数组的数据拷贝到 目标数组的哪个索引
// * param destPos starting position in the destination data.
// length: 从源数组拷贝多少个数据到目标数组
// * param length the number of array elements to be copied.System.arraycopy(src, 0, dest, 0, src.length);
// int[] src{1,2,3};
System.out.println(dest Arrays.toString(dest));//[1, 2, 3]//currentTimeMillens:返回当前时间距离 1970-1-1 的毫秒数
System.out.println(System.currentTimeMillis()); 十、BigInteger和BigDecimal类
1、应用场景
①BigInteger适合保存比较大的整型
②BigDecimal适合保存精度更高的浮点型小数
2、常见方法
add 加 substract 减 multiply 乘 divide 除 十一、日期类
1、Date精确到毫秒代表特定的瞬间
2、SimpleDateFormat格式和解析日期的类 。它允许进行格式化日期-文本、解析文本-日期和规范化 //1. 获取当前系统时间
//2. 这里的 Date 类是在 java.util 包
//3. 默认输出的日期格式是国外的方式, 因此通常需要对格式进行转换Date d1 new Date(); //获取当前系统时间
System.out.println(当前日期 d1);
Date d2 new Date(9234567); //通过指定毫秒数得到时间
System.out.println(d2 d2); //获取某个时间对应的毫秒数//1. 创建 SimpleDateFormat 对象可以指定相应的格式
//2. 这里的格式使用的字母是规定好不能乱写
SimpleDateFormat sdf new SimpleDateFormat(yyyy 年 MM 月 dd 日 hh:mm:ss E);
String format sdf.format(d1); // format:将日期转换成指定格式的字符串
System.out.println(当前日期 format);//1. 可以把一个格式化的 String 转成对应的 Date
//2. 得到 Date 仍然在输出时还是按照国外的形式如果希望指定格式输出需要转换
//3. 在把 String - Date 使用的 sdf 格式需要和你给的 String 的格式一样否则会抛出转换异常
String s 1996 年 01 月 01 日 10:20:30 星期一;
Date parse sdf.parse(s);
System.out.println(parse sdf.format(parse));
3、第二代日期类
主要就是Calendar类日历 //1. Calendar 是一个抽象类 并且构造器是 private
//2. 可以通过 getInstance() 来获取实例
//3. 提供大量的方法和字段提供给程序员
//4. Calendar 没有提供对应的格式化的类因此需要程序员自己组合来输出(灵活)
//5. 如果我们需要按照 24 小时进制来获取时间 Calendar.HOUR 改成 Calendar.HOUR_OF_DAYCalendar c Calendar.getInstance(); //创建日历类对象//比较简单自由
System.out.println(c c);//2.获取日历对象的某个日历字段
System.out.println(年 c.get(Calendar.YEAR));// 这里为什么要 1, 因为 Calendar 返回月时候是按照 0 开始编号
System.out.println(月 (c.get(Calendar.MONTH) 1));
System.out.println(日 c.get(Calendar.DAY_OF_MONTH));
System.out.println(小时 c.get(Calendar.HOUR));
System.out.println(分钟 c.get(Calendar.MINUTE));
System.out.println(秒 c.get(Calendar.SECOND));//Calender 没有专门的格式化方法所以需要程序员自己来组合显示System.out.println(c.get(Calendar.YEAR) - (c.get(Calendar.MONTH) 1) -
c.get(Calendar.DAY_OF_MONTH) c.get(Calendar.HOUR_OF_DAY) : c.get(Calendar.MINUTE) : c.get(Calendar.SECOND) );
4、前面两代日期类的不足
JDK 1.0中包含了一个java.util.Date类但是它的大多数方法已经在JDK 1.1 引入Calendar类之后被弃用了。而Calendar也存在问题是
①可变性像日期和时间这样的类应该是不可变的
②偏移性Date中的年份是从1900开始的而月份都从0开始
③格式化格式化只对Date有用Calendar则不行
④此外它们也不是线程安全的不能处理闰秒等每隔2天多出1s
5、第三代日期类
①LocalDate日期/年月日只包含日期可以获取日期字段
LocalTime时间/时分秒只包含时间可以获取时间字段
LocalDateTime日期时间/年月日时分秒包含日期时间可以获取日期和时间字段 //1. 使用 now() 返回表示当前日期时间的 对象
LocalDateTime ldt LocalDateTime.now(); //LocalDate.now();//LocalTime.now()//2. 使用 DateTimeFormatter 对象来进行格式化
// 创建 DateTimeFormatter 对象DateTimeFormatter dateTimeFormatter DateTimeFormatter.ofPattern(yyyy-MM-dd HH:mm:ss);
String format dateTimeFormatter.format(ldt);
System.out.println(格式化的日期 format);
System.out.println(年 ldt.getYear());
System.out.println(月 ldt.getMonth());
System.out.println(月 ldt.getMonthValue());
System.out.println(日 ldt.getDayOfMonth());
System.out.println(时 ldt.getHour());
System.out.println(分 ldt.getMinute());
System.out.println(秒 ldt.getSecond());LocalDate now LocalDate.now(); //可以获取年月日
LocalTime now2 LocalTime.now();//获取到时分秒//提供 plus 和 minus 方法可以对当前时间进行加或者减
//看看 890 天后是什么时候 把 年月日-时分秒
LocalDateTime localDateTime ldt.plusDays(890);
System.out.println(890 天后 dateTimeFormatter.format(localDateTime));//看看在 3456 分钟前是什么时候把 年月日-时分秒输出
LocalDateTime localDateTime2 ldt.minusMinutes(3456);
System.out.println(3456 分钟前 日期 dateTimeFormatter.format(localDateTime2));
6、DateTimeFormatter格式日期类
DateTimeFormat dtf DateTimeFormat.ofPattern(格式);
String str dtf.format(日期对象); 7、Instant时间戳 //1.通过 静态方法 now() 获取表示当前时间戳的对象
Instant now Instant.now();
System.out.println(now);//2. 通过 from 可以把 Instant 转成 Date
Date date Date.from(now);//3. 通过 date 的 toInstant() 可以把 date 转成 Instant 对象
Instant instant date.toInstant();
8、第三代日期类更多方法