Object类 

 java.lang.Object类是java语言中的根类,即所有类的父类.它中描述的所有方法都可以使用.在对象实例化的时候,最终找的父类就是Object.

  如果一个类没有特别指定父类,那么默认则继承自Object类.例如:

自己随便定义的一个类:

public void Demo{

//.........
}

根据JDK源码和Object类的API文档,Object类当中包含的方法有11个,然后,我只挑选了两个来做重点介绍:

public String toString():返回该对象的字符串表示.
public boolean equals(Object obj):指示其他某个对象是否与此对象"相等".

toString方法:

public String toString():返回该对象的字符串表示.

  toString方法返回该对象的字符串表示,其实该字符串内容就是对象的类型+@+内存地址值.

  由于toStrng方法返回的结果是内存地址,而在开发中,经常需要按照对象的属性得到相应的字符串表现形式,因此也需要重写它.

覆盖重写

  如果不希望使用toString方法的默认行为,则可以对它进行覆盖重写.例如自定义的Person类:

public class Person { 
    private String name;
    private int age;
    @Override
    public String toString() {
        return "Person{" + "name='" + name + '\'' + ", age=" + age + '}';
    }
    // 省略构造器与Getter Setter
}

在InteliJ IDEA,可以点击Code菜单中的Generate....也可以使用快捷键alt+insert,点击toString()选项,选择需要包含的成员变量并确定,

在我们直接使用输出语句输出对象名的时候,其实通过该独享调用了其toString()方法.

equals方法

方法摘要:

public boolean equals(Object object):指示其他某个对象是否与此对象"相等".

调用成员方法equals并指定参数为另一个对象那个,则可以判断这两个对象是否是相同的.这里的"相同"有默认和自定义两种方式.

默认地址比较:

如果没有覆盖重写equals方法,那么Object类中默认进行==运算符的对象地址比较,只要不是同一个对象,结果必然为false.

对象内容比较

如果希望进行对象内容比较,即所有或指定的部分成员变量相同就判定两个对象相同,则可以覆盖重写equals方法,例如:

 import java.util.Objects;
public class Person {  
private String name;    
private int age;    
   
    @Override
    public boolean equals(Object o) {
        // 如果对象地址一样,则认为相同
        if (this == o)
            return true;
        // 如果参数为空,或者类型信息不一样,则认为不同
        if (o == null || getClass() != o.getClass())
            return false;
        // 转换为当前类型
        Person person = (Person) o;
        // 要求基本类型相等,并且将引用类型交给java.util.Objects类的equals静态方法取用结果
        return age == person.age && Objects.equals(name, person.name);
    }
}

这里考虑到了对象为空.类型一致等问题.但方法内容并不唯一,大多数IDEA都可以自动生成equals方法的代码内容.在IntelliJ IDEA中,可以使用Code菜单中的Generate选项,也可以使用alt+insert,并选择equals()and hashCode()进行自动代码生成.如些土所示:

Objects类:

在刚才IDEA自动重写equals代码中,使用到了java.util.Objects类,那么这个类是什么呢?

在JDK7添加了一个Object工具类,它提供了一些方法来操作对象,它由一些静态的实用方法组成,这些方法是null-save(空指针安全的)或null-tolerant(容忍空指针的),用于计算对象那个的hashcode,返回对象那个的字符串表示形式,比较两个对象.

在比较两个对象的时候,Object的equals方法容易抛出空指针异常,而Object类中的equals方法就优化了这个问题.方法如下:

public static boolean equals(Object a, Object b) :判断两个对象是否相等.

我们可以查看一下源码,学习一下:

public static boolean equals(Object a, Object b) { 
    return (a == b) || (a != null && a.equals(b)); 
}

Date类

概述:

java.util.Date类表示特定的瞬间,精确到毫秒.

继续查阅Date类的描述,发现Date拥有多个构造函数,只是部分已经过时,但是其中有未过时的构造函数可以把毫秒值转成日期对象.

public Date():分配Date对象那并初始化此对象,以表示分配它的时间(精确到毫秒).

public Date(long date):分配Date对象并初始化此对象,以表示自从标准基准时间(称为"历元(epoch)",即1970年1月1日00:00:00 GMT)以来的指定毫秒数.

注意:由于中国处于东8区(GMT+08:00)是比世界协调时间/格林尼治时间(GMT)快8小时的时区,当格林尼治标准时间为0:00时,东八区的标准时间为08:00.

简单来说:使用无参构造,可以自动设置当前系统时间的毫秒时刻;

      指定long类型的构造参数,可以自定义毫秒时刻,例如:

import java.util.Date;
public class Demo01Date {
    public static void main(String[] args) {
        // 创建日期对象,把当前的时间
        System.out.println(new Date()); // Tue Jan 16 14:37:35 CST 2020
        // 创建日期对象,把当前的毫秒值转成日期对象
        System.out.println(new Date(0L)); // Thu Jan 01 08:00:00 CST 1970
    }
}

在使用println方法时,会自动调用Date类中的toString方法,Date类对Object类中的toString方法进行了覆盖重写,所以结果为指定格式的字符串.

Date类中的多数方法已经过时,常用的方法有:

public long getTime():把日期对象转换成对象的时间毫秒值.

DateFormat类

java.text.DateFormat是日期/时间格式化自类的抽象类,我们通过这个类可以帮我们完成日期和文本之间的转换,也就是可以在Date对象与String对象之间进行来回转换.

  格式化:按照指定的格式,从Date对象转换为String对象.

  解析:按照指定的格式,从String对象转换为Date对象.

构造方法:

  由于DateFormat为抽象类,不能直接使用,所以需要常用的自类java.text.SimpleDateFormat.这个类需要一个模式(格式)来指定格式化或解析的标准,构造方法为:

public SimpleDateFormat(String pattern):用给定的模式和默认语言环境的日期格式符号构造参数pattern是一个字符串,代表日期时间的自定义格式.

格式规则:

常用的格式规则为:

  

更详细的格式规则,可以参考SimpleDateFormat类的API文档.

常用方法:

  DateFormat类的常用方法有:

  public String format(Date date):将date对象格式化为字符串,

  public Date parse(String source):将字符串解析为Date对象.

   DateFormat df = new SimpleDateFormat("yyyy‐MM‐dd")
   //将当前日期转换为字符串
   String s = df.format(new Date());
   System.out.println("‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐");
   //将字符串转换为日期对象
   DateFormat df = new SimpleDateFormat("yyyy/MM/dd")
   Date d = df.parse("1949/10/01")

Calendar类

概念:日历我们都见过:

java.util.Calendar是日历类,在Date后出现,替换掉了许多Date的方法,该类将所有可能用到的时间信息封装为静态成员变量,方便获取,日历类就是方便获取各个时间属性的.

获取方法:

Calendar为抽象类,不能直接创建对象,而是通过静态方法创建,返回自类对象.如下:

Calendar静态方法:

public static Calendar genInstance():使用默认时区和语言环境获得一个日历

例如:

Calendar cal = Calendar.getInstance();

常用方法:

根据Calendar类的API文档,常用方法有:

public int get(int field):返回戈丁日历字段的值

public void set(int field,int value):将给定的日历字段设置为给定值.

public abstract void add(int field,int amount):根据日历的规则,为给定的日历字段添加或者减去指定的时间量.

public Date getTime():返回一个表示此Ccalendar时间值(从历元到现在的毫秒偏移量)的Date对象.

Calendar类中提供很多成员常量,代表给定的日历字段:

代码使用简单演示:

import java.util.Calendar;
public class CalendarUtil {
    public static void main(String[] args) {
        // 创建Calendar对象
        Calendar cal = Calendar.getInstance();
        // 获取年
        int year = cal.get(Calendar.YEAR);
       //设置年份为2020年  
       cal.set(Calendar.YEAR, 2020);  
       //将年份修改为2000年  
        cal.add(Calendar.YEAR,‐20)    
        //将日历对象转换为日期对象
        Date d = cal.getTime();
    }   
}

西方兴起的开始为周日,中国为周一.

在Calendar类中,月份的表示0-11代表1-12月

日期是有大小关系的,时间靠后,时间越大.

System类

java.lang.System类中提供了大量的静态方法,可获取与系统相关的信息或者系统级操作,在System类的API文档中,常用的方法有:

  public static long currentTimeMillis():返回以毫秒为单位的当前时间

  public static void arraycopy(Object src,int srcPos,Object dest,int destPos,int length):将数组中指定的数据拷贝到另一个数组中.

currentTimeMillis方法

实际上,currentTimeMillis方法就是获取当前系统时间与1970年01月01日00:00点之间的毫秒差值.

import java.util.Date;
public class SystemDemo {
    public static void main(String[] args) {
       //获取当前时间毫秒值
       System.out.println(System.currentTimeMillis()); // 1516090531144
      //计算程序运行时间
       long start = System.currentTimeMillis();
        for (int i = 0; i < 10000; i++) {
            System.out.println(i);
        }
        long end = System.currentTimeMillis();
        System.out.println("共耗时毫秒:" + (end ‐ start));
    }
 
}

arraycopy方法

public static void arraycopy(Object src,int srcPos,Object dest,int destPos,int length):将数组中指定的数据拷贝到另一个数组中.

数组的拷贝动作是系统级的,性能很高,System.arraycopy方法具有5个参数,含义分别是:

将src数组中前3个元素,复制到dest数组的前3个位置上.

复制元素前:src数组元素[1,2,3,4,5],dest数组元素[6,7,8,9,10]

复制元素后:src数组元素[1,2,3,4,5],dest数组元素[1,2,3,9,10]

import java.util.Arrays;
public class Demo11SystemArrayCopy {
    public static void main(String[] args) {
        int[] src = new int[]{1,2,3,4,5};
        int[] dest = new int[]{6,7,8,9,10};
        System.arraycopy( src, 0, dest, 0, 3);
        /*代码运行后:两个数组中的元素发生了变化
         src数组元素[1,2,3,4,5]
         dest数组元素[1,2,3,9,10]
        */
    }
}

StringBuilder类

字符串拼接问题

由于String类的对象内容不可变,所以每当进行字符串拼接时,总是会在内存中创建一个新的对象,例如:

public class StringDemo {
    public static void main(String[] args) {
        String s = "Hello";
        s += "World";
        System.out.println(s);
    }
}

在API中对String类有这样的描述:字符串是常量,他们的值在创建后,就不能被更改.

根据这句话分析我们的代码,其实总共产生了三个字符串,即"hello","world",和"hello world".引用变量s首先指向hello对象,最终指向拼接出来的新字符串对象,即helloWorld

由此可知,如果对字符串进行拼接操作,每次拼接,都会构建一个新的String对象,既耗时,又浪费空间,为了解决这个问题,可以使用java.lang.StringBuilder类.

StringBuilder概述

  查看java.lang.StringBuilder的API,StringBbuilder又称为可变字符序列,它是一个类似于String的字符串缓冲区,通过某些方法调用可以改变该序列的长度和内容.

  原来StringBuilder是个字符串的缓冲区,即它是一个容器,容器中可以装很多字符串.并且能够对其中的字符串进行各种操作.

  它的内部拥有一个数组用来存放字符串内容,进行字符串拼接时,直接在数组中加入新的内容.StringBuilder会自动维护数组的扩容.原理如下图所示:(默认16字符空间,超过自动扩容.)

构造放法

根据StringBuilder的API文档,常用构造放法有2个:

public StringBuilder():构造一个空的StringBuilder容器.

public StringBuilder(String str):构造一个StringBuilder容器,并将字符串添加进去.

常用方法:

public StringBuilder append(,,,,):添加任意类型数据的字符串形式,并返回当前对象自身.

public String toString():将当前StringBuilder对象转换为String对象.

代码简单演示:

public class Demo02StringBuilder {
public static void main(String[] args) {    
//创建对象        
StringBuilder builder = new StringBuilder();        
    // 可以添加 任何类型    
builder.append("hello");        
builder.append(true);        
builder.append(100);        
        //将StringBuilder转换为String类型
        String s = builder.toString();
       System.out.println(s)  
// 在我们开发中,会遇到调用一个方法后,返回一个对象的情况。然后使用返回的对象继续调用方法。        
        // 这种时候,我们就可以把代码现在一起,如append方法一样,代码如下
//链式编程        
String s2 = builder.append("hello").append(true).append(100).toString();        
System.out.println(s2);        
}    
}

备注:StringBuilder已经覆盖重写了Object当中的toString方法.

包装类

概述:java提供了两个类型系统,基本类型引用类型,使用基本类型在于效率,然而很多情况,会创建对象使用,因为对象可以做更多的功能,如果想要我们的基本类型像对象一样操作,就可以使用基本类型对应的包装类,如下:

拆箱与装箱

基本类型与对应的包装类对象之间,来回转换的过程称为"装箱"与"拆箱".

装箱:从基本类型转换为对应的包装类对象

拆箱:从包装类对象转换为对应的基本类型.

用Integer与int为例:

基本数值------->包装对象

Integer i = new Integer(4);//使用构造函数函数
Integer iii = Integer.valueOf(4);//使用包装类中的valueOf方法

包装对象------>基本数值

int num=i.intvalue();

自动装箱与自动拆箱

由于我们经常要做基本类型与包装类之间的转换,从java5(JDK5)开始,基本类型与包装类的装箱.拆箱动作可以自动完成.例如:

Integer i = 4;//自动装箱。相当于Integer i = Integer.valueOf(4);
i = i + 5;//等号右边:将i对象转成基本数值(自动拆箱) i.intValue() + 5;
//加法运算完成后,再次装箱,把基本数值转成对象。

基本类型与字符串之间的转换

基本类型转换为String

基本类型转换String有三种方式,这里只讲最简单的一种方式:

基本类型直接与""相连接即可;如:34+""

String转换成基本类型

除了Character类之外,其他所有包装类都具有parseXXX静态方法可以将字符串参数转换为对应的基本类型:

public static byte parseByte(String s) :将字符串参数转换为对应的byte基本类型。
public static short parseShort(String s) :将字符串参数转换为对应的short基本类型。
public static int parseInt(String s) :将字符串参数转换为对应的int基本类型。
public static long parseLong(String s) :将字符串参数转换为对应的long基本类型。
public static float parseFloat(String s) :将字符串参数转换为对应的float基本类型。
public static double parseDouble(String s) :将字符串参数转换为对应的double基本类型。
public static boolean parseBoolean(String s) :将字符串参数转换为对应的boolean基本类型。

代码使用(仅以Integer类的静态方法parseXXX为例)如:

public class Demo18WrapperParse {
    public static void main(String[] args) {
        int num = Integer.parseInt("100");
    }
}

如果在转换字符串参数的内容时,可能会抛出java.lang.NumberFormatExceptioin异常

原因:字符串参数的内容无法正确转换为对应的基本类型.

Object类.时间日期类.System类.Stringbuilder类.包装类的更多相关文章

  1. 深入理解Java常用类-----时间日期

    除了String这个类在日常的项目中比较常用之外,有关时间和日期的操作也是经常遇到的,本篇就讲详细介绍下Java API中对时间和日期的支持.其实在Java 8之前时间日期的API并不是很好用,以至于 ...

  2. 【学习笔记】String进阶:StringBuffer类(线程安全)和StringBuilder类

    一.除了使用String类存储字符串之外,还可以使用StringBuffer类存储字符串.而且它是比String类更高效的存储字符串的一种引用数据类型. 优点: 对字符串进行连接操作时,使用Strin ...

  3. C# 8 函数 调用 常用类 时间 日期型

    函数:能够独立完成某个功能的模块. 好处:1.结构更清析(编写.维护方便 ).2.代码重用.3.分工开发. 四要素:名称,输入(参数),输出(返回的类型),加工(函数体) 语法: 返回类型 函数名(参 ...

  4. Java8新特性(三)——Optional类、接口方法与新时间日期API

    一.Optional容器类 这是一个可以为null的容器对象.如果值存在则isPresent()方法会返回true,调用get()方法会返回该对象. 查看结构图可以看到有如下常用方法: of(T)—— ...

  5. 在 .NET Framework 中使用 StringBuilder 类

    在 .NET Framework 中使用 StringBuilder 类 String 对象是不可变的.每次使用 System.String 类中的一个方法时,都要在内存中创建一个新的字符串对象,这就 ...

  6. 字符串处理总结之二(C#StringBuilder类)

    动态串StringBuilder 与String类相比,System.Text.StringBuilder类可以实现动态字符串.此外,动态的含义是指在修改字符串时,系统不需要创建新的对象,不会重复开辟 ...

  7. C#中 StringBuilder类 与 String类的区别---(转)

      在找工作的时候,去了些公司,避免不了要面试和笔试.不过一般最起初的是笔试.我印象中有这样有一道题目:StringBuilder类与 String类的区别?那时候我不太清楚这两个类的区别,今天在看代 ...

  8. 动态字符串 Stringbuilder类

    StringBuilder动态字符串 string 类型的修改会浪费资源,如果要修改字符串而不创建新的对象,则可以使用 System.Text.StringBuilder 类, stringbuild ...

  9. StringBuilder类的作用,以及与String类的相互转换

    # 转载请留言联系 先看一段String类的字符串拼接的代码. String s = "hello" 会在常量池开辟一个内存空间来存储”hello". s += &quo ...

随机推荐

  1. 可能是全网最好的MySQL重要知识点 | 面试必备

    可能是全网最好的MySQL重要知识点 | 面试必备  mp.weixin.qq.com 点击蓝色“程序猿DD”关注我 回复“资源”获取独家整理的学习资料! 标题有点标题党的意思,但希望你在看了文章之后 ...

  2. laravel门面与服务提供者区别

    laravel门面模式与服务提供者区别 以 Laravel 自带的文件系统为例,在 config/app.php 的配置文件的 providers 数组中,注册了一个服务提供者: Illuminate ...

  3. MATBLAB学习笔记----基础绘图

    整理自台大生机系郭彦甫.MATLAB系列教程,吐血推荐看这个视频,非计算机专业也能看懂,全程干货 MATLAB图形来自于“数据”,MATLAB不能理解函数. MATLAB绘图原理: 1.在特定范围生成 ...

  4. python3使用smtplib发送邮件,带xlsx附件

    一.概述 最近在做一个统计报表,需要发送邮件,并带附件的. 在之前的文章中 https://www.cnblogs.com/xiao987334176/p/10022026.html 已经实现了发送邮 ...

  5. SQL系列(四)—— 唯一值(distinct)

    有时需要查询某列上的不重复的数据,如: SELECT name FROM student; 结果: name lxy lxy lxy lxy 这样的结果显然不符合我们的需求.如何对列数据进行去重,查询 ...

  6. (原创)对比组态软件,使用C#开发的服务器和客户端软件的优势

    在当前经济形势和市场环境下,中小企业面对萧条的消费市场,恶化的外部贸易环境,刚性支出高成本人工和生产要素,通货膨胀,隐性的腐化支出等各种因素的作用导致企业生存艰难,企业需要在各方面削减支出,拓展市场寻 ...

  7. WPF Dispatcher使用

    微软在WPF引入了Dispatcher,那么这个Dispatcher的主要作用是什么呢?Dispatcher的作用是用于管理线程工作项队列.主线程负责接收输入.处理事件.绘制屏幕等工作,这样一来,UI ...

  8. 异常详细信息: System.Security.SecurityException: 未找到源,不过,未能搜索部分或所有事件日志。 若要创建源,您需要用于读取所有事件日志的权限以确保新的源名称是唯一的。 不可访问的日志: Security。

    “/”应用程序中的服务器错误. 安全性异常 说明: 应用程序尝试执行安全策略不允许的操作.要授予此应用程序所需的权限,请与系统管理员联系,或在配置文件中更改该应用程序的信任级别. 异常详细信息: Sy ...

  9. 【SQL】各取所需 | SQL JOIN连接查询各种用法总结

    前面 在实际应用中,大多的查询都是需要多表连接查询的,但很多初学SQL的小伙伴总对各种JOIN有些迷糊.回想一下,初期很长一段时间,我常用的似乎也就是等值连接 WHERE 后面加等号,对各种JOIN也 ...

  10. 一步一步学Spring Boot 2 微服务项目实战 - 黄文毅-2018年8月第一次印刷

    properties 配置文件的优先级高于.yml .在properties文件中配置了server.port=8080 同时在.yml中配置了server.port=8090  Spring Boo ...