JavaSE static final及abstract修饰符实例解析
作者:阿福聊编程 发布时间:2021-07-01 10:54:54
static :静态常量,静态方法,静态代码块
静态变量: 静态变量属于类的,使用类名来访问,非静态变量是属于对象的,"必须"使用对象来访问.
注意:静态变量对于类而言在内存中只有一个,能被类中所有的实例共享。 实例变量对于类的每一个实例都有一份,
它们之间互不影在加载类的过程中为静态变量分配内存,实例变量在创建对象时分配内存
所以静态变量可以使用类名来直接访问,而不需要使用对象来访问.
package com.len.collection;public class PersonTest111 { private static String username="战士高高"; private String password; public static String getUsername() { return username; } public static void setUsername(String username) { PersonTest111.username = username; } public String getPasswoord() { return passwoord; } public void setPasswoord(String passwoord) { this.passwoord = passwoord; } public static void main(String[] args) { /** * 第一点: 静态变量属于类的,可以使用名来访问,非静态变量是属于对象的,必须使用对象来访问。 */ System.out.println(PersonTest111.username); PersonTest111 personTest111 = new PersonTest111(); personTest111.setPasswoord("2131231"); System.out.println(personTest111.getPasswoord()); }}
静态方法:静态方法数属于类的,"可以"使用类名来调用,非静态方法是属于对象的,"必须"使用对象来调用.
静态方法"不可以"直接访问类中的非静态变量和非静态方法,但是"可以"直接访问类中的静态变量和静态方法
注意:this和super在类中属于非静态的变量.(静态方法中不能使用),代码同上
静态代码块:在类加载的时候被调用,给静态成员变量赋值
<em>package com.len.collection;
public class PersonTest extends PersonTest111{
private static String username="张珊";
private String password="123456";
public PersonTest(){
System.out.println("构造方法");
}
static {
System.out.println("静态代码块");
}
public static void main(String[] args) {
PersonTest personTest=new PersonTest();
}
}
</em>
final 修饰符
用final修饰的类不能被继承,没有子类
用final修饰的方法可以被继承,但是不能被子类的重写 如java 中每个类都是Object类的子类,继承了Object中的众多方法,在子类中可以重写toString方法、equals方法等,
但是不能重写getClass方法 wait方法等,因为这些方法都是使用fi修饰的
用final修饰的变量表示常量,只能被赋一次值.其实使用final修饰的变量也就成了常量了,因为值不会再变了。
2)修饰成员变量:
非静态成员变量:
public class PersonTest{
private final int a;
}
只有一次机会,可以给此变量a赋值的位置:
声明的同时赋
构造器中赋值(类中出现的所有构造器都要写)
静态成员变量:
public class Person{
private static final int a;
}
只有一次机会,可以给此变量a赋值的位置:
声明的同时赋值
静态代码块中赋值
abstract修饰符
可以用来修饰方法也可以修饰类,如果修饰方法,那么该方法就是抽象方法;如果修饰类,那么该类就是抽象类。
抽象类,不能使用new关键在来创建对象,它是用来让子类继承的,
抽象方法,只有方法的声明,没有方法的实现,它是用来让子类实现的
注:子类继承抽象类后,需要实现抽象类中没有实现的抽象方法,否则这个子类也要声明为抽象类。
类的创建和初始化过程
* 1.类加载,同时初始化类中的静态属性
* 2.执行静态代码块
* 3.分配内存空间,同时初始化非静态的属性
* 4.调用 PersonTest父类构造器
* 5.对PersonTest中的属性进行显示赋值
* 6.执行匿名代码块
* 7.执行构造器
* 8.返回内存地址
package com.len.collection;
public class PersonTest extends PersonTest111{
private static String username="张珊";
private String password="123456";
public PersonTest(){
System.out.println("构造方法");
}
//匿名代码块是创建对象的时候自动执行,并且是在构造方法之前执行给方法
//作用:给对象的成员变量初始化赋值
{
System.out.println("匿名代码块");
}
//静态方法在类被加载的时候调用
//作用:给静态成员变量初始化赋值
static {
System.out.println("静态代码块");
}
public static void main(String[] args) {
/**
* 1.类加载,同时初始化类中的静态属性
* 2.执行静态代码块
* 3.分配内存空间,同时初始化非静态的属性
* 4.调用 PersonTest父类构造器
* 5.对PersonTest中的属性进行显示赋值
* 6.执行匿名代码块
* 7.执行构造器
* 8.返回内存地址
*/
PersonTest personTest=new PersonTest();
}
}
来源:https://www.cnblogs.com/xiaofuzi123456/p/10962394.html


猜你喜欢
- 一、前言关于EasyExcel,它对poi做了进一步的封装,使得整个编写流程更加的面向对象。好处嘛,我认为流程上更加清晰即易懂、可读性更好,
- 本文实例讲述了Android编程入门之HelloWorld项目目录结构。分享给大家供大家参考,具体如下:我们介绍了如何搭建Android开发
- 一、在spring的应用中我们存在两种过滤的用法,一种是 * 、另外一种当然是过滤器。我们这里介绍过滤器在springboot的用法,在sp
- 程序性能的主要表现点:执行速度:程序的反映是否迅速,响应时间是否足够短内存分配:内存分配是否合理,是否过多地消耗内存或者存在内存泄漏启动时间
- 前言大家都知道网络操作的响应时间是不定的,所有的网络操作都应该放在一个异步操作中处理,而且为了模块解耦,我们希望网络操作由专门的类来处理。所
- 目录一、System.out.println(最简单)二、java.util.logging(相对简单)三、log4j(最强大)四、comm
- 虽然jvm可以通过GC自动回收无用的内存,但是代码不好的话仍然存在内存溢出的风险。 一、为什么要了解内存泄露和内存溢出?1、内存泄
- 目录Web服务器技术讲解PHP:JSP/ServletWeb服务器IISTomcatJAVA jdk中的内容TomcatTomcat根目录下
- 前言spring 对bean的创建过程做了很完整的封装。但是提供了非常多的扩展接口,供我们使用。这一节主要是实现spring提供的获取 be
- AppWidgetProvider 用来在HOME页面显示插件实现步骤:1、为AppWidget提供一个元布局文件AppWigdetProv
- 介绍技术之前有用eureka 现在用nacos工作流和gateway接口数据流向数据表新建项目新建cloud-删除src-新建modleEu
- List 是在开发中比较常用的集合,今天总结一下 Java 中初始化 List 的几种方式。1、常规方式List<String>
- TabHost组件可以在界面中存放多个选项卡, 很多软件都使用了改组件进行设计。一、基础知识TabWidget : 该组件就是TabHost
- 目录开始准备开始动画画圆弧项目使用背景图完整代码今天介绍一个很简单的倒计时动画,仿酷狗音乐的启动页倒计时效果,也是大多数APP在用的一个动画
- Mybatis无法获取带有下划线前缀的字段的值今天下面,把几张表里的字段都加了前缀,如 article_id,article_title,a
- 本文实例为大家分享了spring mvc实现文件上传与下载功能的具体代码,供大家参考,具体内容如下文件上传在pom.xml中引入spring
- (注意:本文基于JDK1.8)前言增删改查,修改元素,Vector提供了3个方法,包括迭代器中的一个,不过本文只分析Vector自身的两个修
- 一、 WillPopScope用法WillPopScope本质是一个widget用于拦截物理按键返回事件(Android的物理返回键和iOS
- java编码中经常用到代理,代理分为静态代理和 * 。其中 * 可以实现spring中的aop。一、静态代理:程序运行之前,程序员就要编
- 程序中的错误分为编译时的错误和运行时的错误。编译时的错误主要是语法错误,比如:句尾没有加分号,括号不匹配,关键字错误等,这类错误比较容易修改