• JAVA面向对象基础



    面向对象
    封装的原则
       要求使对象之外的部分不能随意存取对象的内部数据,从而有效避免了错误对它的“交叉感染”,使软件错误能局部化,降低排错难度

    继承

      所有的类都继承自java.lang.Object,一些常用的方法:

        equals():比较两个对象引用时否相同。

        getClass():返回对象运行时所对应的类的表示,从而得到相应的信息

        toString():返回对象字符串表示

        finalize():用于在垃圾收集前清除对象

        notify(), notifyall(), wait(): 用于多线程处理中的同步

      子类(subclass)对父类(superclass,超类)的继承

      子类不能继承父类中访问权限为private的成员变量和方法。

      子类可以重写父类的方法,及命名与父类同名的成员变量。

      Java不支持多重继承

      创建子类

        class SubClass extends SuperClass {

          ...

        }

      成员的隐藏和方法的重写

        子类通过隐藏父类的成员变量和重写父类的方法,可以把父类的状态和行为变为自身的状态和行为。

        

    多态性
      子类继承父类后,同一个方法有不同的表现

      体现在两个方面:方法重载实现的静态多态性(编译时多态),方法重写实现的动态多态性(运行时多态)

        重写方法的调用原则:子类重写父类的方法,调用子类方法;反之,调用父类的方法

      一个对象可以引用子类的实例来调用子类的方法

      eg: B继承A,A的对象a引用B的实例,调用B的方法callme()

     1 import java.io.*;
    2 class A {
    3 void callme() {
    4 System.out.println("Inside A's callme()) method");
    5 }
    6 }
    7
    8 class B extends A {
    9 void callme() {
    10 System.out.println("Inside B's callme() method");
    11 }
    12 }
    13
    14 public class Dispatch {
    15 public static void main(String args[]) {
    16 A a = new B(); // 引用子类的实例
    17 a.callme();
    18 }
    19 }




    类的实现
      类声明
        [public][abstract|final] class className [extends superclassName] [implements interfaceNameList] {}
          修饰符public, abstract, final说明类的属性
          className为类的属性
          superclassName为父类的名字
          interfaceNameList为类所实现的接口列表

      类体
        class className
        {
          [public | protected | private] [static] [final] [transient] [volatile] type variableName; // 成员变量
          [public | protected | private] [static] [final | abstract] [native] [synchronized] returnType methodName(
            [paramList]) [throws exceptionList] {statements}; //成员方法
        }


      成员变量
        [public | protected | private] [static] [final] [transient] [volatile] type variableName; // 成员变量
          static: 静态变量(类变量)
          final: 常量
          transient:暂时性变量,用于对象存档
          volatile:共享变量,用于并发线程的共享

      成员方法
        [public | protected | private] [static] [final | abstract] [native] [synchronized] returnType methodName(
        [paramList]) [throws exceptionList] {statements}; //成员方法
          static: 类方法,可通过类名直接调用
          abstract: 抽象方法,没有方法体
          final:方法不能被重写
          native:集成其他语言的代码
          synchronized:控制多个并发线程的访问

      

      Java类中的限定词:

        private:类中限定为private的成员,只能被这个类本身访问。如果构造方法为private,则其他类不能实例化该类。

        default:不加任何访问权限,可以被这个类本身和同一个包中的类访问。

        protected:类中限定为protected的成员,可以被这个类本身、它的子类和同一个包中的其他类访问。

        public:类中被限定为public的成员,可以被所有类访问。

        

      final关键字可以修饰类、类的成员变量和成员方法,但作用不同

        修饰成员变量:称为常量,须给出初始值

        修饰成员方法:该方法不能被子类重写

        修饰类:类不能被继承

      

        super: 访问父类的成员 

          访问父类被隐藏的成员变量,如super.variable;

          调用父类中被重写的方法,如super.Method([paramlist]);

          调用父类的构造函数,如super([paramlist]);

    eg:

     1 import java.io.*;
    2 class SuperClass {
    3 int x;
    4
    5 SuperClass() {
    6 x = 3;
    7 System.out.println("in SuperClass: x = " + x);
    8 }
    9
    10 void doSomething() {
    11 System.out.println("in SuperClass.doSomething()");
    12 }
    13 }
    14
    15 class SubClass extends SuperClass {
    16 int x;
    17
    18 SubClass() {
    19 super();
    20 x = 5;
    21 System.out.println("in SubClass: x = " + x);
    22 }
    23
    24 void doSomething() {
    25 super.doSomething();
    26 System.out.println("in SubClass.doSomething()");
    27 System.out.println("Super.x = " + super.x + "sub.x = " + x);
    28 }
    29 }
    30
    31 public class Inhereritance {
    32
    33 public static void main(String chars[]) {
    34 SubClass sc = new SubClass();
    35 sc.doSomething();
    36 }
    37 }


         

        

      简单数据:值类型
      复合数据:引用类型

     1 import java.io.*;
    2 public class PassTest {
    3 float ptValue;
    4
    5 public static void main(String args[]) {
    6 int val;
    7 PassTest pt = new PassTest();
    8 val = 11;
    9 System.out.println("Original int Value is:"+val);
    10 pt.changeInt(val);
    11 System.out.println("Int Value after Change is:"+val);
    12 pt.ptValue = 101f;
    13 System.out.println("Original ptValue is:"+pt.ptValue);
    14 pt.changeObjectValue(pt); // 引用类型的参数
    15 System.out.println("ptValue after change is:"+pt.ptValue);
    16
    17 }
    18
    19 public void changeInt(int value) {
    20 value = 55;
    21 }
    22
    23 public void changeObjectValue(PassTest ref) {
    24 ref.ptValue = 99f;
    25 }
    26 }

    简单数据类型作为参数传递时,为值传递;复合数据类型作为参数传递时,为地址传递


      方法体
        方法的实现。方法体中局部变量若与成员变量同名,局部变量将屏蔽成员变量。

     1 import java.io.*;
    2 class Variable {
    3 int x = 0, y = 0, z = 0; // 类的成员变量
    4
    5 void init(int x, int y) {
    6 this.x = x;
    7 this.y = y;
    8 int z = 5; // 局部变量
    9 System.out.println("** in init**");
    10 System.out.println("x = " + x + "y = " + y + "z = " + z);
    11 }
    12 }
    13
    14 public class VariableTest {
    15 public static void main(String args[]) {
    16 Variable v = new Variable();
    17 System.out.println("** before init **");
    18 System.out.println("x = " + v.x + "y = " + v.y + "z = " + v.z);
    19 v.init(20, 30);
    20 System.out.println("** after init **");
    21 System.out.println("x = " + v.x + "y = " + v.y + "z = " + v.z);
    22 }
    23 }

      方法重载

        指多个方法享有相同的名字。这些方法的参数必须不同。且参数类型区分度要足够:如不能使同一简单类型的数据:int与long

     1 import java.io.*;
    2
    3 class MethodOverloading {
    4 void receive(int i) {
    5 System.out.println("Receive in data");
    6 System.out.println("i = " + i);
    7 }
    8
    9 void receive(int x, int y) {
    10 System.out.println("Receive two in datas");
    11 System.out.println("x = " + x + "y = " + y);
    12 }
    13 }
    14
    15 public class MethodOverloadingTest {
    16 public static void main(String args[]) {
    17 MethodOverloading mo = new MethodOverloading();
    18 mo.receive(1);
    19 mo.receive(2, 3);
    20 }
    21 }


      构造方法

        一个特殊的方法。每个类都有构造方法,用来初始化该类的一个对象。

        构造方法具有和类名相同的名称,不返回任何数据类型。

        重载经常用于构造方法。

        构造方法只能由new运算符调用

      抽象类和抽象方法:

        用abstract关键字修饰类:抽象类

        用abstract关键字修饰方法:抽象方法

        抽象类必须被继承,抽象方法必须被重写

        抽象方法只需声明,无需实现

        抽象类不能被实例化,抽象类不一定要包含抽象方法

        若类中包含抽象方法,给类必须被定义为抽象类

      接口

        接口是抽象类的一种,只包含常量和方法的定义,没有变量和方法的实现,且其方法都是抽象方法。

        用处体现在:

          通过接口,实现不相关类的相同行为

          通过接口,指明多个类需要实现的方法

          通过接口,了解对象的交互界面,无需了解对象所对应的类

        接口的定义:

          接口声明:

            [public] interface interfaceName[extends listOfSuperInterface] {...}

          方法体定义:

            returnType methodName([paramlist]);

        接口的实现:

          在类的声明中用implements子句来表示一个类使用某个接口

          类体中可以使用接口中定义的常量,必须实现接口中定义的所有方法

          一个类可以实现多个接口,在implements中用逗号隔开

        接口类型的使用:

          接口作为一种引用类型来使用

          任何实现该接口的类的实例,都可以存储在该接口类型的变量中,通过这些实例,访问该类接口中的方法。

  • 相关阅读:
    .NET 4.5 异步IO
    使用MANIFEST.MF文件来track War包做持续部署
    .NET 4.5 压缩
    自定义实现URL重写 04.18
    对.Net Framework的认识
    那点所谓的分布式——memcache
    不能选择FreeTextBox下拉列表框
    实战架构设计
    LoadRunner压力测试心得总结
    JavaScript的模块化:封装(闭包),继承(原型)
  • 原文地址:https://www.cnblogs.com/forstudy/p/2431957.html
Copyright © 2020-2023  润新知