1、关键字this

含义:this 是一个引用类型,代表当前对象,引用类型里面必然保存内存地址,在堆中的每个对象中存储,保存内存地址指向自身。

用法:

1)this可以用在成员方法中,里面保存内存地址,指向当前变量

2)this可以用在构造方法中,其他地方是不能用的;

int empno;

//员工姓名
 String ename;

//Constructor
 Employee(){

  this(12,zhangsan);//this(实参);表示通过一个构造方法去调用另外一个构造方法,且必须出现在构造方法的第一行。

}

Employee(int _empno, String _ename){
  empno= _empno;
  this.ename=_ename;//this用在构造方法中
 }

public void work(){
  System.out.println(ename+"在工作");
  System.out.println(this.ename+"在工作");//这两种效果是一样的。
 //成员方法
 public void m1(){
  this.m2();//this用在成员方法中
  m2();
 }
 
 //成员方法
 public void m2(){
  System.out.println("THSWEOD");
 }

3)this 不能用在静态方法中

静态方法的执行根本不需要java对象的存在,直接使用类名.方法名的方式访问。而this代表的是当前对象,所以静态方法中根本没有this,如果使用this.则编译无法通过

2、static关键字

1)static修饰的变量叫做“静态变量”--->类名.变量名
 2)static修饰的方法叫做“静态方法”--->类名.方法名 或 引用.方法名 或 方法名;静态方法中不能使用非静态数据:成员变量和成员方法;静态方法中不能使用this
 3)static还可以定义静态语句块 static定义的静态语句块在类加载阶段执行,并且只执行一次。并且是自上往下的顺序执行。
开发的过程中:一般工具类的方法都是静态方法

备注:

  静态变量意味着所有的java对象都共用这一块东西。静态变量存放在方法区。放在方法区中,表示java中的每一个类型对象都共享一份。所以静态变量属于类级别的。

  什么时候变量声明成静态变量?
 如果这个属性所有对象都有,并且这个属性的值是相同的,则该属性声明成静态变量。这样让其在方法区中存储一份,可以节省空间。

成员变量:在创建java对象的时候初始化
 静态变量:在类加载的时候赋值,并且只赋值一次。

//静态语句块

static {
  System.out.println("1");
 }

//实例语句块:每一次调用构造方法之前会执行一次,即每次创建对象之前会执行一次。调用n次就会执行n次
 {
  System.out.println("1");
 }

备注:为什么main方法定义成public static void main(String[] args){}    ?

为了方便java虚拟机的调用。换句话说java虚拟机在调用main方法的时候,不需要创建对象。直接使用类名.main方法 公开的静态的、方法结束之后不需要有返回值。

//空的引用去访问成员的时候会出现空指针异常
 //m2方法不是“成员”而是静态的,所以即使引用是空的,也不会报空指针异常

3、类中可以包含:

类{

   //可以通过“类名.”,也可以通过“引用.”,即使使用“引用.”底层也是“类名.”
   1)静态变量
   2)静态方法-->如果方法中不需要当前对象的一些东西,而是整个类的东西,那么该方法就声明成静态的方法

  //必须对象存在才可以访问,采用“引用.”
   3)成员变量
   4)成员方法-->如果方法中用到了,当前对象的一些方法,则需要将该方法声明为成员方法

  //创建对象给成员变量赋值
   5)构造方法

  //类加载时只执行一次
   6)静态语句块

   //构造方法没有调用之前执行一次
   7)实例语句开

   //用在成员变量和构造方法中
   8)this
    空引用访问成员时会出现空指针异常。(成员包括:成员变量和成员方法)
   访问静态不会出现空引用异常。
}

4、super关键字

1)super代表的是当前子类对象中的父类型特征,不是引用类型,存储的不是内存地址,指的不是父类对象;例如子类和父类中都有某个属性,如果要在子类中访问父类中的name属性,需要使用super.name;

2)super可以用在成员方法、构造方法中,不能用在静态方法中;this和super相同,都不能用在静态上下文当中

  super在构造方法中的作用是通过子类的构造方法去调动父类的构造方法(但是并没有创建java对象),从而给当前子类对象中的父类型特征赋值

  super在成员方法中是通过当前子类对象去访问父类型特征

注意:构造方法的执行不一定创建对象。因为super()也算构造方法执行了,但是并没有创建对象。
通过子类的构造方法去调用父类的构造方法,一定会执行父类的构造方法,但是这个构造方法的执行并不一定会创建对象。它只是为了当前子类对象的父类型特征赋值。

public class Account {
   private int actno;
   private double balance;
 
   public Account(){
      System.out.println("父类的构造方法执行");
   }
   public Account(int actno, double balance) {
      super();
      this.actno = actno;
      this.balance = balance;
      System.out.println("账户号是:"+actno+","+"账户余额是:"+balance);
   }
}

public class debitAccount extends Account {
   private double debit;
   public  debitAccount() {
      super();
      /*有super();的效果和没有super();的效果是一样的
       * 无参数的构造方法第一行什么都没写,则系统默认调用父类里面的构造方法,若是父类里面的构造方法私有化了,则编译无法通过
       * 因此:单例模式的类型没有子类型,无法被继承。因为单例模式最大的特点就是构造方法私有化。而构造方法私有化之后则无法被
       * 继承。
       * */
   }
   debitAccount(int actno,double balance,double debit){
     super(actno,balance);
      this.debit=debit;
      System.out.println("信用额度为"+debit);
   }
}

public class Test02 {
   public static void main(String[] args) {
   debitAccount da1=new debitAccount();
    debitAccount da2=new debitAccount(12,30,400);
   }
}

4、抽象类

1)抽象类:由abstract修饰的类

  抽象类无法实例化(即无法创建对象),但是抽象类也有构造方法,该构造方法是给子类型创建对象;也说明了调用构造方法无法创建对象。抽象类中不一定有抽象方法,但是抽象方法一定出现在抽象类中。

  一个非抽象类继承抽象类,必须将抽象类中的抽象方法覆盖,实现,重写;

2)抽象方法:由abstract修饰,并且方法没有方法体{},以;结束

public abstract class Abs_a {
   //抽象类中也有构造方法,是给子类创建对象用的 
   int a;
   double b;
   Abs_a(){
      System.out.println("父抽象类的无参数构造方法执行");
   }
   //抽象类虽然可以有有参数的构造方法,但是无在子类中对该抽象父类进行实例化
   public Abs_a(int a,double b){
      System.out.println("父抽象类的有参构造方法执行");
   }
   public abstract void m1();
}

public class Abs_b extends Abs_a {
   public static void main(String[] args){
    Abs_b ab1=new Abs_b(); //此时父类的无参数构方法会执行
    ab1.m1();
  
    /*Abs_a ab2=new Abs_a(12,30);
     * 抽象类虽然可以有有参数的构造方法,但是无在子类中对该抽象父类进行实例化,否则编译无法通过
     */
   Abs_b ab2=new Abs_b(10,30);
   } 
   @Override
   public void m1() {
    // 一个非抽象类继承抽象类,必须将抽象类中的抽象方法覆盖,实现,重写;
    System.out.println("实现/重写抽象类Abs_a中的抽象方法");

  }
 
   public Abs_b(){
      super();//父类的无参数构方法也会执行
   }
 
   public Abs_b(int a,double b){
      this.a=a;
      this.b=b;
    System.out.println("a的值为"+a+"b的值为"+b);
   }
}

5、final关键字

1) final修饰的类无法被继承
2) final修饰的方法无法别覆盖
3) final修饰的局部变量,一旦赋值,不能在改变
4) final修饰的成员变量必须“显示的”初始化,即必须手动的赋值。final修饰的成员变量在构造方法调用结束之前,只要能附上值就行。例如 final int k=100;或者通过构造方法 A(){ k=100;}进行赋值
5) final修饰的成员变量一般和static联用,用来定义常量 public static final double PI = 3.13;常量是值不可在改变的变量,“类名.常量名”访问
6) final修饰的引用类型,该引用不可以再重新指向其他的java对象,但是final修饰的引用,该引用指向的对象的属性是可以修改的。final Customer c=new Customer("jack",45);    c=new Customer("LUCY",20);//Error

备注:抽象类不能被final修饰,抽象方法不能被final修饰。即final不能和abstract共存;

finalize:是object里面的一个方法的名字,压根就不是关键字,垃圾回收器在回收java对象之前,会先自动调用java对象的finalize方法,

finally:   是异常处理机制中的finally语句块,所以这三者没有任何联系,不能把这三者混为一谈。

五、java基础-关键字this_static_super_abstract_final,finalize()方法finally语句块的更多相关文章

  1. JAVA基础篇 之 finalize()方法的作用

    ​ 我们知道java有垃圾回收器负责回收无用对象占据的内存资源,但也有特殊情况:假设你的对象(并非使用new)获得了一块特殊的内存区域,由于垃圾回收器只知道回收那些经由new分配的内存,所以它不知道如 ...

  2. [java]final关键字、finally关键字与finalize()方法

    final关键字: final关键字通常指的是“无法改变的”,使用“无法改变”这样修饰可能出于两个原因:设计或者效率. final可以修饰变量.方法和类. 一.final变量 一个既是static又是 ...

  3. JAVA基础语法:函数(方法)、类和对象(转载)

    4.JAVA基础语法:函数(方法).类和对象 函数 在java中函数也称为方法,是一段具备某种功能的可重用代码块. 一个函数包括这几部分: 函数头 函数头包括函数访问修饰符,函数返回值类型, 函数名, ...

  4. Java基础 之 System.getProperty()方法

    Java基础 之 System.getProperty()方法大全 public static void main(String[] args) { System.out.println(" ...

  5. synchronized(1)用法简介:修饰方法,修饰语句块

    注意: 同一个对象或方法在不同线程中才出现同步问题,不同对象在不同线程互相不干扰. synchronized方法有2种用法:修饰方法,修饰语句块 1.synchronized方法 是某个对象实例内,s ...

  6. Java 中 try、catch、finally 语句块的执行顺序

    假设代码顺序书写如下:try → catch → finally → 其他代码 则: 1.正常执行顺序:try → catch → finally → 其他代码 2.try,catch和finally ...

  7. java基础 五 java注释 关键字 标识符

    一:java有三大注释: 1:当行注释: 使用://开始进行注释. 2:多行注释: /**/  在/*和*/之间的内容 会被编译器忽略. 3:文档注释: /***/  /**注释信息*/和多行注释是一 ...

  8. JAVA基础关键字小结一

    基础部分总是看起来简单,若要明白原理和使用场景,需要慢慢的体会. 本文对常用的关键字如final,transient,volatile,static以及foreach循环的原理重新梳理了一遍. 一.f ...

  9. JAVA中GC时finalize()方法是不是一定会被执行?

    在回答上面问题之前,我们一定要了解JVM在进行垃圾回收时的机制,首先: 一.可达性算法  要知道对象什么时候死亡,我们需要先知道JVM的GC是如何判断对象是可以回收的.JAVA是通过可达性算法来来判断 ...

随机推荐

  1. 如何在应用程序中使用ML.NET?

    https://www.cnblogs.com/shanyou/p/9190701.html ML.NET以NuGet包的形式提供,可以轻松安装到新的或现有的.NET应用程序中. 该框架采用了用于其他 ...

  2. mongodb副本集仲裁节点搭建

    服务器准备: 主节点192.168.100.106 从节点192.168.100.107 仲裁节点192.168.100.108 三台服务器: 关闭防火墙 service iptables stop ...

  3. CSS的精灵技术

  4. "%Error opening tftp://255.255.255.255/network config"

    问题:服务配置错误消息(Service Configuration Error Messages) 有时,在通过Cisco IOS软件启动Cisco设备期间,会显示与这些类似的错误消息: %Error ...

  5. 802.1X基本配置

    基本的802.1X部署工作包括以下4步:    1. 为Cisco Catalyst交换机配置802.1X认证方    2. 为交换机配置访客VLAN或者受限VLAN,并调整802.1X定时器(可选) ...

  6. Servlet里面request处理外部POST请求的输入流的工具类

    package etcom.servlet; import java.io.BufferedReader; import java.io.IOException; import java.io.Inp ...

  7. jquery中 $(xxx).each() 和 $.each()的区别,以及enter键一键登录

    1.$().each 在dom处理上面用的较多.如果页面有多个input标签类型为text,对于这时用$().each来处理多个text,例如: $("input[type=’text’]& ...

  8. how to analyze jmeter results

    https://octoperf.com/blog/2017/10/19/how-to-analyze-jmeter-results/

  9. leetCode练题——21. Merge Two Sorted Lists(照搬大神做法)

    1.题目 21. Merge Two Sorted Lists Merge two sorted linked lists and return it as a new list. The new l ...

  10. redis实现哨兵机制

    将cd /usr/local/redis/sentinel.conf复制到/usr/local/redis/etc/下 cd /usr/local/redis/ cp sentinel.conf /u ...