【Java开发指南 | 第九篇】访问实例变量和方法、继承、接口

简介: 【Java开发指南 | 第九篇】访问实例变量和方法、继承、接口

访问实例变量和方法

通过已创建的对象来访问成员变量和成员方法,如下所示:


/* 实例化对象 */
Object referenceVariable = new Constructor();
/* 访问类中的变量 */
referenceVariable.variableName;
/* 访问类中的方法 */
referenceVariable.methodName();


举例:


public class ice{
    public ice(String name)
    {
        System.out.println("名字是:"+name);
    }
    int myAge;
    public void setAge(int age)
    {
        myAge=age;
    }
    public int getAge()
    {
        System.out.println("年龄是:"+myAge);
        return myAge;
    }
    public static void main(String[] args)
    {
        ice I = new ice("张三");//创建对象
        I.setAge(1);//调用方法,设定年龄
        I.getAge();//调用方法,输出年龄
    }
}


继承

在 Java 中,一个类可以由其他类派生。如果我们需要创建一个类,而且已经存在一个类具有我们所需要的属性或方法,那么我们可以将新创建的类继承该类。


利用继承的方法,可以重用已存在类的方法和属性,而不用重写这些代码。被继承的类称为超类(super class),派生类称为子类(sub class)。


这里给出简单的继承模板:


// 父类
class Parent {
    // 父类的属性
    private String name;
    // 父类的构造方法
    public Parent(String name) {
        this.name = name;
    }
    // 父类的方法
    public void printName() {
        System.out.println("Name: " + name);
    }
}
// 子类继承父类
class Child extends Parent {
    // 子类的构造方法
    public Child(String name) {
        // 调用父类的构造方法
        super(name);
    }
    // 子类可以重写父类的方法
    @Override
    public void printName() {
        System.out.println("Child's name: " + name);
    }
    // 子类可以添加新的方法
    public void sayHello() {
        System.out.println("Hello from Child!");
    }
}
public class Main {
    public static void main(String[] args) {
        // 创建子类的实例
        Child child = new Child("ICE");
        // 调用继承自父类的方法
        child.printName();
        // 调用子类的方法
        child.sayHello();
    }
}


实例演示


假设有一个Animal类,它具有name和age两个属性,以及eat()和sleep()两个方法:


public class Animal {
    protected String name;
    protected int age;
    public Animal(String name, int age) {
        this.name = name;
        this.age = age;
    }
    public void eat() {
        System.out.println(name + " is eating.");
    }
    public void sleep() {
        System.out.println(name + " is sleeping.");
    }
}

现在,如果我们想创建一个Dog类,它是一种动物,具有和Animal类相同的属性和方法,我们可以使用继承来实现:


public class Dog extends Animal {
    public Dog(String name, int age) {
        super(name, age);
    }
    public void bark() {
        System.out.println(name + " is barking.");
    }
}

在这个例子中,Dog类继承了Animal类。Dog类拥有了name和age属性,以及eat()和sleep()方法,同时还添加了一个bark()方法。通过继承,Dog类可以重用Animal类的代码,并且可以添加自己特有的行为。


下面创建了一个Dog类的实例,并实现相应的继承:


public class Ice {
    public static void main(String[] args) {
        Dog myDog = new Dog("dog", 3); //继承
        myDog.bark();  //自己特有的行为
    }
}
class Animal {
    protected String name;
    protected int age;
    public Animal(String name, int age) {
        this.name = name;
        this.age = age;
    }
    public void eat() {
        System.out.println(name + " is eating.");
    }
    public void sleep() {
        System.out.println(name + " is sleeping.");
    }
}
class Dog extends Animal {
    public Dog(String name, int age) {
        super(name, age);
    }
    public void bark() {
        System.out.println(name + " is barking.");
    }
}



注意:


1、父类中声明为 public 的方法在子类中也必须为 public。


2、父类中声明为 protected 的方法在子类中要么声明为 protected,要么声明为 public,不能声明为 private。


3、父类中声明为 private 的方法,不能够被子类继承。


接口

在 Java 中,接口可理解为对象间相互通信的协议。接口在继承中扮演着很重要的角色。


接口只定义派生要用到的方法,但是方法的具体实现完全取决于派生类。


举个例子:

// 定义一个接口,只定义派生要用到的方法
interface Animal {
    void eat();
    void sleep();
}
//Dog类实现了Animal接口,并提供了这两个方法的具体实现。
class Dog implements Animal {
    public void eat() {
        System.out.println("Dog is eating.");
    }
    public void sleep() {
        System.out.println("Dog is sleeping.");
    }
}
class Main {
    public static void main(String[] args) {
        Dog myDog = new Dog();
        myDog.eat();
        myDog.sleep();
    }
}

目录
相关文章
|
1天前
|
Java Spring
面对Spring 不支持java8的改变方法
面对Spring 不支持java8的改变方法
|
2天前
|
设计模式 Java 测试技术
Java一分钟之-PowerMock:静态方法与私有方法测试
【6月更文挑战第4天】PowerMock是扩展Mockito的框架,用于模拟静态方法、构造函数和私有方法,以增强Java单元测试的隔离性和覆盖率。核心应用场景包括静态方法模拟、私有方法测试和Final类模拟。常见问题包括配置复杂、过度使用和忽略模拟的真实行为。解决方案包括遵循官方文档、谨慎使用PowerMock、精确控制模拟逻辑和遵循最佳实践。示例展示了如何模拟静态方法,通过添加PowerMock依赖和使用`PowerMockRunner`、`PrepareForTest`注解,以及`PowerMockito.mockStatic`和`verifyStatic`方法进行测试。
22 0
Java一分钟之-PowerMock:静态方法与私有方法测试
|
3天前
|
Java 编译器 数据安全/隐私保护
20. 【Java教程】继承
20. 【Java教程】继承
3 0
|
3天前
|
Java 编译器
17. 【Java教程】Java 方法
17. 【Java教程】Java 方法
13 0
|
3天前
|
存储 自然语言处理 Java
09. 【Java教程】Java 变量
09. 【Java教程】Java 变量
6 1
|
6天前
|
存储 Java
JAVA中的变量:深入解析与实例
JAVA中的变量:深入解析与实例
30 3
|
6天前
|
存储 Java
深入探索Java语言中的方法
深入探索Java语言中的方法
|
6天前
|
Java
Java语言中的继承:深入解析与应用
Java语言中的继承:深入解析与应用
|
2天前
|
算法 安全 Java
Java性能优化(四)-多线程调优-Synchronized优化
JVM在JDK1.6中引入了分级锁机制来优化Synchronized,当一个线程获取锁时,首先对象锁将成为一个偏向锁,这样做是为了优化同一线程重复获取导致的用户态与内核态的切换问题;其次如果有多个线程竞争锁资源,锁将会升级为轻量级锁,它适用于在短时间内持有锁,且分锁有交替切换的场景;轻量级锁还使用了自旋锁来避免线程用户态与内核态的频繁切换,大大地提高了系统性能;但如果锁竞争太激烈了,那么同步锁将会升级为重量级锁。减少锁竞争,是优化Synchronized同步锁的关键。
18 2
|
1天前
|
监控 算法 Java
Java性能优化(九)-多线程调优-垃圾回收机制优化
Java性能优化(九)-多线程调优-垃圾回收机制优化
10 0