飞艇安全吗_Java匹马行天下之JavaSE核心技术——面向对象
- 时间:
- 浏览:0
- 来源:泽宇博客 - 专注共享知识共享网资源
注:看此篇时强烈建议有一定的面向对象思想基础,有一定的基础后先翻到下面看第九条:9.面向对象: 从未封装→封装→继承→多态→抽象类→接口的代码演变,按你同类 逻辑去看,哪有不理解的再回头看知识点,这是掌握理解最好最快的方式,切记切记
万物皆对象
描述有另另六个物质都后能 通过两方面说明:数据模型(属性)、行为模型(行为)。在Java编程中,亲戚亲戚朋友使用成员变量表示数据模型,用成员方式表示行为模型。使用类表示其他具有相同属性和行为的事物。
1、函数
构造函数:
语法:
[访问修饰符] 类名(){ }
作用:
构造函数,一般是用于为成员属性赋初始化值;
注意:
- 当类中越来越显式的构造方式,实例化该类的对象时,应用进程会自动创建有另另六个公开的无参构造方式;
- 机会类涵盖显示的构造方式,应用进程就不让创建无参构造;
静态函数:
- static关键字用来声明独立于对象的静态方式。静态方式只有使用类的非静态变量。静态方式从参数列表得到数据,而且计算那此数据。
- 对类变量和方式的访问后能 直接使用 classname.variablename 和 classname.methodname 的方式访问。
如下例所示,static修饰符用来创建类方式和类变量:
public class InstanceCounter {
private static int numInstances = 0;
protected static int getCount() {
return numInstances;
} private static void addInstance() {
numInstances++;
} InstanceCounter() {
InstanceCounter.addInstance();
} public static void main(String[] arguments) {
System.out.println("Starting with " +
InstanceCounter.getCount() + " instances");
for (int i = 0; i < 30; ++i){
new InstanceCounter();
}
System.out.println("Created " +
InstanceCounter.getCount() + " instances");
}
}
运行结果:
Starting with 0 instances
Created 30 instances
成员函数(实例函数)
2、变量
成员变量(实例变量)
- 声明在所有方式体和代码块之外,而且越来越使用static修饰的变量,叫做实例变量;
- 后能 使用访问修饰符和final修饰;
- 使用final修饰时,一定要赋值;
- 实例变量是在对象被创建时创建,对象被销毁时销毁;
- 作用域范围在整个类中;
局部变量
- 声明在构造方式、静态方式、实例方式、代码块中的变量,不是局部变量;
- 只有使用static和访问修饰符修饰;
- 后能 使用final修饰,即为常量,不须在声明说说中赋值;
- 当执行局部变量所在的方式或代码块时,才有机会被创建,在方式或代码块执行过后过后刚开始英文后被自动销毁;
- 局部变量在内存的栈区分配;
- 局部变量在使用过后需要要先赋值;
静态变量(类的变量)
- 声明在所有方式体和代码块之外,而且使用static修饰的变量;
- 后能 使用访问修饰符修饰;
- 一般配合final使用,即public static fianl,标识符使用大写;
- 类变量被分配在静态存储区,是被所有该类的对象共享数据;
- 类变量是在应用进程过后过后刚开始英文时被创建,应用进程过后过后刚开始英文时销毁;
3、修饰符
访问修饰符
Java中后能 使用访问控制符来保护对类、变量、方式和构造方式的访问。Java 支持 4 种不同的访问权限。
- default (即缺省,那此过后写): 在同一包内可见,不使用任何修饰符。使用对象:类、接口、变量、方式。
- private : 在同一类内可见。使用对象:变量、方式。 注意:只有修饰类(内外部类)
- public : 对所有类可见。使用对象:类、接口、变量、方式
- protected : 对同一包内的类和所有子类可见。使用对象:变量、方式。 注意:只有修饰类(内外部类)
亲戚亲戚朋友后能 通过以下表来说明访问权限:
非访问修饰符
为了实现其他其他的功能,Java 也提供了其他非访问修饰符。
- static 修饰符,用来修饰类方式和类变量。
- final 修饰符,用来修饰类、方式和变量,final 修饰的类只有够被继承,修饰的方式只有被继承类重新定义,修饰的变量为常量,是不可修改的。
final修饰变量:
- final 表示"最后的、最终的"含义,变量一旦赋值后,只有被重新赋值。被 final 修饰的实例变量需要显式指定初始值。
- final 修饰符通常和 static 修饰符一并使用来创建类常量。
final修饰方式:
- 类中的 final 方式后能 被子类继承,而且只有被子类修改。
- 声明 final 方式的主要目的是出理 该方式的内容被修改。
如下所示,使用 final 修饰符声明方式:
public class Test{
public final void changeName(){
final修饰类:
- final 类只有被继承,越来越类后能 继承 final 类的任何形态学 。
注意:
- 当final修饰类时,当前类只有被继承;
- 当final修饰方式时,该方式只有被重写;
- 当final修饰变量时,变量的值只有被修改,即为常量;
abstract修饰符,用来创建抽象类和抽象方式。
抽象类:
- 抽象类只有用来实例化对象,声明抽象类的唯一目的是为了将来对该类进行扩充。
- 有另另六个类只有一并被 abstract 和 final 修饰。机会有另另六个类涵盖抽象方式,越来越该类一定要声明为抽象类,而且将突然老出编译错误。
- 抽象类后能 涵盖抽象方式和非抽象方式。
规则:
- 涵盖抽象方式的类,一定是抽象类;
- 抽象类中后能 声明成员变量、常量、成员方式、抽象方式,抽象类中不一定要有抽象方式;
- 抽象类只有被实例化;
- 抽象类后能 被继承;
- 后能 通过并不是方式获得抽象类对象:父类引用指向子类对象、匿名内内外部类;
- 子类需要重写抽象父类的所有抽象方式,机会是把子类也定义为抽象类;
- 机会有另另六个类继承的抽象父类还有上级抽象父类,越来越子类中需要要重写所有抽象父类的所有抽象方式;
- 抽象类也后能 继承非抽象类,一并继承了父类的所有非私有的属性和方式;
实例:
abstract class Caravan{
private double price;
private String model;
private String year;
public abstract void goFast();
抽象方式
- 抽象方式是并不是越来越任何实现的方式,该方式的的具体实现由子类提供。
- 抽象方式只有被声明成 final 和 static。
- 任何继承抽象类的子类需要实现父类的所有抽象方式,除非该子类也是抽象类。
- 机会有另另六个类涵盖若干个抽象方式,越来越该类需要声明为抽象类。抽象类后能 不涵盖抽象方式。
*抽象方式的声明以分号结尾,同类 :public abstract sample();
实例:
public abstract class SuperClass{
abstract void m();
synchronized 和 volatile 修饰符,主要用于应用进程的编程。
synchronized 修饰符
synchronized 关键字声明的方式同一时间只有被有另另六个应用进程访问。synchronized 修饰符后能 应用于六个访问修饰符。
实例
public synchronized void showDetails(){
.......
}
transient 修饰符
- 序列化的对象涵盖被 transient 修饰的实例变量时,java 虚拟机(JVM)跳过该特定的变量。
- 该修饰符涵盖在定义变量的说说中,用来预出理 类和变量的数据类型。
实例
public transient int limit = 55;
**volatile **修饰符
- volatile 修饰的成员变量在每次被应用进程访问时,都强制从共享内存中重新读取该成员变量的值。而且,当成员变量居于变化时,会强制应用进程将变化值回写到共享内存。另有另另六个在任多会儿刻,有另另六个不同的应用进程突然看了某个成员变量的同有另另六个值。
- 有另另六个 volatile 对象引用机会是 null。
实例
public class MyRunnable implements Runnable
{
private volatile boolean active;
public void run()
{
active = true;
while (active)
通常情况表下,在有另另六个应用进程调用 run() 方式(在 Runnable 开启的应用进程),在另有另另六个应用进程调用 stop() 方式。 机会 第一行 中缓冲区的 active 值被使用,越来越在 第二行 的 active 值为 false 时循环不让停止。而且以上代码中亲戚亲戚朋友使用了 volatile 修饰 active,之过后循环会停止。
4、关键字
this指当前对象,用法:
- 当局部变量名和实例变量名同名时,使用this.变量名来表示实例变量;
- this()表示当前类的构造方式,只有在构造方式中使用该写法,而且是写在构造方式内的第一行。
面向对象三大形态学 :封装、继承、多态
5、封装
私有的属性,公开的方式。
封装的步骤:
- 声明私有(private)的属性;
- 声明公开(public)的geter和seter方式;
6、继承
Java中的继承是单继承,后能 实现多层继承,继承的关键字extends
语法:
public class Son extends Father{}
规则:
- 子类继承父类非私有的所有属性和方式,只有继承父类的构造方式;
- 实例化子类对象的步骤:先执行父类的构造方式,再执行子类的构造方式;
重写定义:
- 子类重新声明从父类继承来的方式,称为方式重写;
- 方式重写时,方式的声明次要要和父类保持一致(返回值类型,方式名,参数);
- 重写方式的访问权限要大于等于父类中方式的访问权限;
- 子类重写父类方式,子类对象调用的是子类中重写后的方式;
- 使用static修饰的方式只有被重写,而且后能 被子类重写声明;
- 不同包的子类后能 重写父类中protected修饰的方式,而且只有以继承的形式,用子类对象直接调用父类的该方式;
7、多态
实现的必要条件:
- 继承
- 重写
- 父类引用指向子类对象
instanceof关键字:
语法:
if (对象名 instanceof 类名) {
类型转换代码;
}
实例:
Animal cat = new Cat();
if (cat instanceof Cat) {
8、接口
语法:
public interface ITest {}
规则:
- 接口使用interface关键字修饰;
- 接口是有另另六个完正抽象的抽象类;
- 接口中越来越构造方式;
- 接口只有被实例化对象;
- 接口中后能 声明静态常量、抽象方式、静态方式;
- 接口中只有声明实例方式,声明抽象方式时,只有使用static关键字修饰;
- 声明接口说说中,默认涵盖abstract关键字,抽象方式中也默认涵盖abstract关键字;
- 接口后能 被实现,使用implements关键字,有另另六个类实现有另另六个接口,需要重写该接口中所有的抽象方式;
- 有另另六个类后能 实现多个接口,每个接口名用英文的逗号隔开,该类中需要重写所有已实现接口中的抽象方式;
- 接口后能 继承接口,接口与接口间是多继承关系,接口只有继承类;
9.面向对象: 从未封装→封装→继承→多态→抽象类→接口的代码演变:
未封装:
public class Person {
int age;
封装:
public class Person {
private int age;
继承
public class Office {
public void print(){
System.out.println("打印");
}
}class Word extends Office {
@Override
public void print() {
System.out.println("Word打印");
}
}class Test{
public static void main(String[] args) {
Word word = new Word();
word.print();
}
}运行结果:
Word打印
有另另六个Java源文件中后能 声明多个class类,但只有有有另另六个public修饰的类。
多态
public class Office {
public void print(){
System.out.println("打印");
}
}class Word extends Office {
@Override
public void print() {
System.out.println("Word打印");
}
}class Excle extends Office{
@Override
public void print() {
System.out.println("Excel打印");
}
}class Ppt extends Office{
public void daYin() {
为出理 你同类 方式名称多样的情况表,用并不是约束叫抽象类
public abstract class Office {
public abstract void print();
}class Word extends Office {
@Override
public void print() {
System.out.println("Word打印");
}
}class Excle extends Office{
@Override
public void print() {
System.out.println("Excel打印");
}
}class Ppt extends Office{
@Override
public void print() {
System.out.println("PPT打印");
}
}class Test{
public static void main(String[] args) {
Office o = new Ppt();
接口是完正抽象的抽象类,而且后能 多实现
接口默认为:
public class abstract interface Office {
public abstract void print();
}
---------------------------------------------------------
public interface Office {
void print();
}class Word implements Office {
@Override
public void print() {
System.out.println("Word打印");
}
}class Excle implements Office{
@Override
public void print() {
System.out.println("Excel打印");
}
}class Ppt implements Office{
@Override
public void print() {
System.out.println("PPT打印");
}
}class Test{
public static void main(String[] args) {
Office o = new Ppt();
o.print();
}
}运行结果为:
PPT打印
10、内内外部类
成员内内外部类
成员内内外部类声明在类中,方式体、代码块之外。和成员变量、成员方式在同一级别。
语法:
public class Out {
静态内内外部类
声明的位置参考成员内内外部类。
语法:
public class Out {
局部内内外部类
声明在方式体或代码块内,作用域范围在方式体或代码块内。
语法:
public class Out {
public void method(){
匿名内内外部类
- 声明位置同局部内内外部类一样,前提条件:需要继承有另另六个类或实现有另另六个接口,匿名内内外部类的声明和实例化对象是一并进行的;
- 一般使用于获得抽象类或接口对象;
语法:
父类名/接口名 对象名 = new 父类名/接口名(){
此篇完
你同类 篇对新手是不友好的,不过对其他一知半解的机会想复习的亲戚亲戚朋友机会帮助更大。
推荐阅读
- 《婴儿的出生为你解惑构造函数和构造代码块》
- 《彻底填平Static坑》
- 《抽象类和接口到底是那此垃圾》
- 《抽象类能实例化吗》