java类的包装类
包装类的基本用法
为什么需要包装类(Wrapper Class)
java并不是纯面向对象的语言,java语言是一个面向对象的语言,但是java中的基本数据类型却不是面向对象的,但是我们在实际使用中经常将基本数据类型转换成对象,便于操作,比如,集合的操作中,这时,我们就需要将基本类型数据转化成对象!
包装类和基本数据类型的关系
基本数据类型 包装类
byte Byte
boolean Boolean
short Short
char Character
int Integer
long Long
float Float
double Double
包装类的继承关系
包装类的基本操作
详见jdk api
public class TestInteger { public static void main(String[] args) {
// TODO Auto-generated method stub
Integer i1=new Integer(123);
Integer i2 = new Integer("123");
System.out.println("i1=i2:"+(i1==i2));//false
System.out.println("i1.equals(i2):"+i1.equals(i2));
System.out.println(i2);
System.out.println(i2.toString());//说明重写了toString方法
Integer i3=new Integer(128);
System.out.println(i1.compareTo(i3));//-1
System.out.println(i1.compareTo(i2));//
System.out.println(i3.compareTo(i2));//1
//(1)Integer-->int 包装对象.intValue()
int i=i1.intValue();
System.out.println(Integer.max(10, 20));//返回最大值
//(2)String -->int 包装类类名.parseInt(String s)
int ii=Integer.parseInt("234");
//(3)int -->Integer
Integer i4=Integer.valueOf(123);
//(4)int-->String
String str=ii+"";
String s=String .valueOf(ii);
//(5)String-->Integer;
Integer i5=new Integer("345");
//(6)Integer-->String
String ss=i5.toString();
System.out.println(ss);
} }
4.StringBuilder_StringBuffer 用法_JDK 底
层源码分析---->请见源码查看
4.1 可变的字符串
StringBuilder:效率高,安全性低
StringBuffer:效率低,安全性高
4.2StringBuilder 的常用方法的使用
- append()
- delete()
- insert()
- StringBuilder()构造函数
package com.bjsxt.stringbuilder; public class TestStringBuffer {
public static void main(String[] args) {
StringBuilder sb = new StringBuilder();
// 字符串的追加
sb.append("hello");
sb.append(true);
sb.append('你');
sb.append();
System.out.println(sb.toString()); sb.delete(, );// 含头不含尾
System.out.println(sb);
sb.deleteCharAt();// 删除指定位置上的字符
System.out.println(sb); sb.insert(, '好');
System.out.println(sb);
System.out.println(sb.indexOf("t") + "\t" + sb.indexOf("k"));
}
}
package com.bjsxt.stringbuilder; public class TestStringBuilder2 {
public static void main(String[] args) { StringBuilder sb=new StringBuilder();//实际上创建了一个长度为16的char类型的数组
StringBuilder sb2=new StringBuilder("hello");//5+16
sb2.append("world");
sb2.append("world");
sb2.append("world");
sb2.append("world");
sb2.append("world");
sb2.append("world");
sb2.append("world");
sb2.append("world");
System.out.println(sb2);
System.out.println("容量"+sb2.capacity()+"\tsb2的长度"+sb2.length());
}
}
4.3StringBuilder 的 JDK 源码分析
5.不可变字符序列和可变字符序列的深入
javap 是 JDK 自带的一个工具,可以反编译,也可以查看 Java
编译器生成的字节码,是分析代的一个好工具。
-c 对代码进行反汇编
package com.bjsxt.test; public class Test {
public static void main(String[] args) {
String str1="abc"+"dbc";
String str4="abcdbc";
//在运行时会在堆中创建对象
/**
* StringBuilder sb=new StringBuilder();
* sb.append("abcdbc");
* sb.append("cde");
* String str2=sb.toString();
*
* */
String str2=str1+"cde"; String str3=new String("hello");
System.out.println(str1==str4);
/**在等号的右侧有变量参与运行或new关键字,将在堆内存开辟空间*/ String str6="";
for(int i=;i<;i++){
StringBuilder sb2=new StringBuilder();
sb2.append(str6);
sb2.append(i);
str6=sb2.toString();
//str6=str6+i;
}
System.out.println(str6);
/**只创建了一个对象,sb对象*/
StringBuilder sb=new StringBuilder();
for(int i=;i<;i++){
sb.append(i);
}
System.out.println(sb); }
}
6.java.util.Date 类
6.1java.util.Date 类
long getTime()
- 返回自 1970 年 1 月 1 日以来,由此 Date 对象表示的00:00:00 GMT 的毫秒数
6.2java.sql.Date 类
6.3java.sql.Date 类
package com.bjsxt.testdate; import java.util.Date; public class TestDate {
public static void main(String[] args) {
Date d=new Date();
System.out.println(System.currentTimeMillis());//1970-1-1 00:00:00 Date d2=new Date(1000L);
System.out.println(d2.toGMTString());
System.out.println(d.getTime()); System.out.println(d.before(d2)); //false
System.out.println(d.after(d2)); //true System.out.println(d.getTime()<d2.getTime());
System.out.println(d.getTime()>d2.getTime()); //
System.out.println(d2.toString()); /**java.util.Date类的子类*/
java.sql.Date sqlDate=new java.sql.Date(1000L);
System.out.println(sqlDate); java.sql.Time sqlTime=new java.sql.Time(1000L);
System.out.println(sqlTime.toGMTString()); java.sql.Timestamp timestamp=new java.sql.Timestamp(1001L);
System.out.println(timestamp);
}
}
7.DateFormat 和 SimpleDateFormat 类
完成字符串和时间对象的转换
package String; import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Scanner; public class TestDateFormat { public static void main(String[] args) throws ParseException {
// TODO Auto-generated method stub
DateFormat d=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
/**
* Date-->String format(Date d)
* String-->Date parse(String s)
*/
Date date=new Date(3456465434131346L);
System.out.println(date);
String strDate=d.format(date);
System.out.println(strDate); Scanner input=new Scanner(System.in);
System.out.println("请输入一个时间:yyyy-MM-dd hh:mm:ss.SSS");
String str=input.nextLine();
Date d2=d.parse(str); System.out.println(d2);
} }
package String; import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Scanner; public class TestDateFormat { public static void main(String[] args) throws ParseException {
// TODO Auto-generated method stub
DateFormat d=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
/**
* Date-->String format(Date d)
* String-->Date parse(String s)
*/
Date date=new Date(3456465434131346L);
System.out.println(date);
String strDate=d.format(date);
System.out.println(strDate); Scanner input=new Scanner(System.in);
System.out.println("请输入一个时间:yyyy-MM-dd hh:mm:ss.SSS");
String str=input.nextLine();
Date d2=d.parse(str); System.out.println(d2);
} }
8.Calendar 类
8.1Calendar 的类
人们对于时间的认识是:某年某月某日,这样的日期概念。计算机是 long 类型的数字。通过 Calendar 在二者之间搭起桥梁!
GregorianCalendar 是 Calendar 的一个具体子类,提供了世界上大多数国家/地区使用的标准日历系统。
注意:
月份:一月是 0,二月是 1,以此类推,是 12 月是 11
星期:周日是 1,周一是 2,。。。周六是 7
package com.bjsxt.calendar; import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.GregorianCalendar;
import java.util.Scanner; public class Test {
public static void main(String[] args) throws ParseException {
Scanner input=new Scanner(System.in);
System.out.println("请输入一个日期:yyyy-MM-dd");
String str=input.next();
//创建DateFormat对象,用于将String转Date
DateFormat df=new SimpleDateFormat("yyyy-MM-dd");
Date d=df.parse(str);
//Date对象所表示的时间设置到Calendar中
Calendar cal=new GregorianCalendar();
cal.setTime(d); //获取输入的日期中的date部分
int nowDate=cal.get(Calendar.DAY_OF_MONTH); //14 //将日期设置为1号,设置成2030-2-1
cal.set(Calendar.DAY_OF_MONTH, 1);
//获取1号是星期几?
int dayOfWeek=cal.get(Calendar.DAY_OF_WEEK); System.out.println("日\t一\t二\t三\t四\t五\t六");
for(int i=1;i<dayOfWeek;i++){
System.out.print("\t");
}
//获取输入的月份的最后一天
int maxDay=cal.getActualMaximum(Calendar.DAY_OF_MONTH);
//System.out.println(maxDay);
for(int i=1;i<=maxDay;i++){
System.out.print(i);
if(i==nowDate){
System.out.print("*");
}
System.out.print("\t");
if(cal.get(Calendar.DAY_OF_WEEK)==Calendar.SATURDAY){
System.out.println();
}
cal.add(Calendar.DAY_OF_MONTH, 1);
} }
}
package com.bjsxt.calendar; import java.util.Calendar;
import java.util.Date;
import java.util.GregorianCalendar; public class TestCalendar {
public static void main(String[] args) {
//父类引用指向子类对象
Calendar cal=new GregorianCalendar();
cal.set(2030, 1, 14);
System.out.println("年"+cal.get(1));
System.out.println("年:"+cal.get(Calendar.YEAR));
//getTime(),将Calendar转换成Date对象
Date d=cal.getTime();
System.out.println(d);
//setTime(Date) 将Date对象所表示的时间设置到日历中
Date date=new Date(1000L);
cal.setTime(date);
System.out.println("年:"+cal.get(Calendar.YEAR));
System.out.println("月:"+cal.get(Calendar.MONTH));
System.out.println("日:"+cal.get(Calendar.DAY_OF_MONTH));
cal.add(Calendar.DAY_OF_MONTH, 10); System.out.println("日:"+cal.get(Calendar.DAY_OF_MONTH));
cal.add(Calendar.DAY_OF_MONTH, -100);
System.out.println("年:"+cal.get(Calendar.YEAR));
System.out.println("月:"+cal.get(Calendar.MONTH));
System.out.println("日:"+cal.get(Calendar.DAY_OF_MONTH)); }
}
9.Math 类
9.1Math 类的常用方法
package String; public class TestMath {
public static void main(String[] args) {
System.out.println("绝对值:"+Math.abs(23)+"\t"+Math.abs(-23)+"\t"+Math.abs(0));
System.out.println("向上取整,再转double:"+Math.ceil(23.0001)+"\t"+Math.ceil(-9.9999));
System.out.println("向下取整再转double"+Math.floor(23.9999)+"\t"+Math.floor(-23.0001));
System.out.println("最值:"+Math.max(20, 10)+"\t"+Math.min(2, 40));
System.out.println("5的2次方:"+Math.pow(5, 2)+"5的立方"+Math.pow(5, 3));
System.out.println("随机数[0,1):"+Math.random());
int ran=(int)(Math.random()*9000)+1000;
System.out.println("1000-9999之间的随机数:"+ran);
System.out.println("四舍五入:"+Math.round(34.566)+"\t"+Math.round(34.345));
System.out.println("开方:"+Math.sqrt(55));
}
}
9.2 静态导入
package String;
import static java.lang.Math.*;//静态导入
public class TestStaticImport {
public static void main(String[] args) {
System.out.println(abs(-20));
System.out.println(Math.abs(-2));
System.out.println(random());
}
public static int abs(int number){
return number;
}
}
JDK1.5
10.File 类
文件和目录路径名的抽象表示形式。一个 File 对象可以代表一个文件或目录
- 可以实现获取文件和目录属性等功能
- 可以实现对文件和目录的创建、删除等功能
常用方法有:
- createNewFile() //有则不创建 返回false,没有则创建 返回true
- delete() //删除成功 返回true ,失败返回false
- getAbsoluteFile() //返回绝对路径
- getPath() //返回相对路径
- getName() //返回文件名
- isFile() //是否为文件 boolean
- length //长度
- mkdir() //创建单层目录
- mkdirs() //创建多级目录
- delete() //只能删除空目录
- list() //返回一个字符串数组,命名由此抽象路径名表示的目录中的文件和目录。
- listFiles() //返回一个抽象路径名数组,表示由该抽象路径名表示的目录中的文件和目录。
File 不能访问文件内容
10.1File 类操作文件
10.2File 类操作目录
package dead; import java.io.File;
import java.io.IOException; public class TestFile {
//使用file类去操纵文件
public static void main(String[] args) throws IOException {
//创建File类的文件
File f1=new File("D:/a1.txt");//绝对路径
File f2=new File("D:\\a2.txt");
File f3=new File("a.txt");//相对路径
File f5=new File("D:\\test");//目录
File f4=new File(f5,"a4.txt");
File f6=new File("D:"+File.separator+"a5.txt");
/**
* File操作文件的相关方法
*/
//System.out.println(f1.createNewFile());
System.out.println(f1.delete());//直接从磁盘上删除
System.out.println(f1.exists());
System.out.println("绝对路径:"+f3.getAbsolutePath());
System.out.println("相对路径:"+f3.getPath());
System.out.println(f3); //相对路径
System.out.println("是否是文件"+f3.isFile());
System.out.println("是否是文件"+f5.isFile());
System.out.println("文件中内容的长度"+f3.length());
}
}
package com.bjsxt.file; import java.io.File; public class TestDirectory {
public static void main(String[] args) {
//创建File类的对象
File f=new File("D:"+File.separator+"test");
f.mkdir(); //用于创建目录 ,单层目录
System.out.println("目录是否存在"+f.exists());
System.out.println("是目录还是文件:"+f.isDirectory());
System.out.println("是目录还是文件:"+f.isFile()); File f2=new File("D:\\aa\\bb\\cc");
f2.mkdirs(); //用于创建目录,多层目录
f.delete();
File parent=f2.getParentFile(); //获取cc目录的父级目录
System.out.println(parent);
parent.delete(); //delete删除目录时,只允许删除空目录
f2.delete();//删除cc
parent.delete();//删除bb File f3=new File("D:\\");
String [] strFile=f3.list();
System.out.println(strFile.length); //数组中元素的个数
for(String s:strFile){
System.out.println(s);
}
System.out.println("\n--------------------------------\n");
File [] flist=f3.listFiles();
for(File file:flist){
System.out.println(file);
} }
}
11.使用递归算法遍历目录结构和树结构
编写一个程序:以树状结构展现特定的文件夹及其子文件
(夹)(使用递归来做)
package Testfile; import java.io.File; public class TestFile {
public static void main(String[] args) {
File f=new File("E:\\eclipse");
printFile(f,0);
}
public static void printFile(File file,int level){
//打印树状结构的层次关系
for(int i=0;i<level;i++){
System.out.print("-");
}
//输出目录或者文件的名称
System.out.println(file.getName());
if(file.isDirectory()){//判断file对象是否是目录
File[] listFiles = file.listFiles();
for(File temp:listFiles){
//自己调用自己
printFile(temp,level+1);
}
}
}
}
12.枚举
12.1 枚举的定义
只能够取特定值中的一个
使用 enum 关键字
12.2 枚举的使用
而每个被枚举的成员实质就是一个枚举类型的实例,他们默认都是 public static final 的。可以直接通过枚举类型名直接使用它们。)
强烈建议当你需要定义一组常量时,使用枚举类型尽量不要使用枚举的高级特性,事实上高级特性都可以使用普通类来实现,没有必要引入复杂性!
12.3 枚举与类的关系
所有的枚举类型隐性地继承自 java.lang.Enum。(枚举实质上还是类!)
package com.bjsxt.enumpro; public enum Gender {
男,女; //男,女 public static final
private String name;
public void setName(String name){
this.name=name;
}
public String getName(){
return this.name();
}
}
package com.bjsxt.enumpro;
/**枚举在自定义类中的使用*/
public class Person {
private String name;//姓名
private int age;//年龄
private Gender gender;//性别
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public Gender getGender() {
return gender;
}
public void setGender(Gender gender) {
this.gender = gender;
}
public Person(String name, int age, Gender gender) {
super();
this.name = name;
this.age = age;
this.gender = gender;
}
public Person() {
super();
} }
package com.bjsxt.enumpro; public class TestGender {
public static void main(String[] args) {
Gender sex=Gender.女;
//
//Gender g=new Gender();//错误的,因为枚举不是类,不能有构造方法
sex.setName("张三");
//System.out.println(sex.getName());
/**枚举与String类型之间的转换*/
String str=sex.toString();
System.out.println(str);
/**枚举-->String toString()方法
* String -->枚举*/
Gender g=Enum.valueOf(Gender.class, "男");
System.out.println(g);
/**枚举在switch中的使用*/
switch(g){
case 男:
System.out.println("男----------");
break;
case 女:
System.out.println("女---------------");
break;
}
/**枚举在自定义类中的使用*/
Person p=new Person("marry", 20, Gender.女);
}
}
java类的包装类的更多相关文章
- java基本数据类型包装类
Java语言是一个面向对象的语言,但是Java中的基本数据类型却是不面向对象的,这在实际使用时存在很多的不便,为了解决这个不足,在设计类时为每个基本数据类型设计了一个对应的类进行代表,这样八个和基本数 ...
- Java 类的一些高级特征
1. 面向对象的特征二:继承性 * 1.为什么要设计继承性? 继承的出现提高了代码的复用性. 继承的出现让类与类之间产生了关系,提供了多态的前提. * 2.通过"class A extend ...
- Java类和对象初始化
类的生命周期: Java类的初始化: 本阶段负责为类变量赋正确的初始值.(类变量即静态变量) Java编译器把所有的类变量初始化语句和静态初始化器通通收集到<clinit>方法中,该方法只 ...
- Java内置包装类
Java内置包装类有Object.Integer.Float.Double.Number.Charcter.Boolean.Byte.System. Number,是抽象类,也是超类(父类).Numb ...
- JAVA基本类型和包装类
JAVA的包装类 Java语言是一个面向对象的语言,但是Java中的基本数据类型却是不面向对象的,这在实际使用时存在很多的不便,为了解决这个不足,在设计类时为每个基本数据类型设计了一个对应的类进行代表 ...
- 再学Java 之 Integer 包装类缓存
前言:本博文将涉及的Java的自动装箱和自动拆箱,可以参考 这篇文章 和 官方教程 ,这里不再赘述. 首先,先看一个小程序: public class Main { public static voi ...
- (1)Object类 (2)包装类和数学处理类 (3)String类
1.Object类1.1 基本概念 java.lang.Object类是Java类层次结构的根类,任何类都是Object类的直接/间接子类. 1.2 常用的方法(重点) Object() - 无参构造 ...
- Java 中的包装类
Java 中的包装类 相信各位小伙伴们对基本数据类型都非常熟悉,例如 int.float.double.boolean.char 等.基本数据类型是不具备对象的特性的,比如基本类型不能调用方法.功能简 ...
- Object类和包装类的一些方法
一.instanceof关键字的使用: a instanceof A:判断对象a是否是类A的实例.如果是,返回true:如果不是,返回false. 使用场景:为了避免在向下转型时出现ClassCast ...
随机推荐
- [No0000178]改善C#程序的建议1:非用ICloneable不可的理由
好吧,我承认,这是一个反标题,实际的情况是:我找不到一个非用ICloneable不可的理由.事实上,接口ICloneable还会带来误解,因为它只有一个Clone方法. 我们都知道,对象的拷贝分为:浅 ...
- 添加字体与字符集locale支持(基于busybox文件系统)
添加字体与字符集(基于busybox文件系统) 2011-10-11 14:07:32 分类: LINUX 1.添加字体 下面以文泉驿为例 $ mkdir -p rootfs/usr/share/ ...
- yum下载rpm包
方法一:downloadonly插件 1.安装插件 yum -y install yum-download 2.下载httpd软件包到当前文件夹内 yum -y install httpd -dow ...
- ionic使用cordova插件中的Screenshot截图分享功能
需要实现操作,考试完成后需要将成绩生成一张图片,分享出去, import { Screenshot } from '@ionic-native/screenshot'; constructor(pri ...
- mac下安装debug坑
mac默认情况下的php版本是很低的,当你直接用phpize的时候默认是使用mac默认安装的phpize版本,这个时候查看Phpinfo的时候是看不到xdebug的,这时候查看错误日志会收到这样的报错 ...
- mysql缓存分析
- js如何判断哪个按钮被点击了?
用事件委托,然后判断target,代码如下: $(docuement).on('click',function(event){ event.target... }) 例如:点击.c1之外任意地方的时候 ...
- tensorflow入门笔记(五) name_scope和variable_scope
一.上下文管理器(context manager) 上下文管理器是实现了上下文协议的对象,主要用于资源的获取与释放.上下文协议包括__enter__.__exit__,简单说就是,具备__enter_ ...
- 【JMeter】【接口测试】csv参数化,数据驱动,自动化测试
csv参数化,数据驱动 首先我们要有一个接口测试用例存放的地方,我们这里用EXCEL模板管理,里面包含用例编号.入参.优先级.请求方式.url等等. 1:新建一个txt文件,命名为sjqd,后缀名 ...
- sql server系统存储过程大全
关键词:sql server系统存储过程,mssql系统存储过程 xp_cmdshell --*执行DOS各种命令,结果以文本行返回. xp_fixeddrives --*查询各磁盘/分区可用空间 x ...