”static”关键字是什么意思?Java中是否可以覆盖(override)一个private或者是static的方法?

static关键字

在《java编程思想》中有这样一段话形容static关键字:

通常,我们创建类时会指出那个类的对象的外观与行为。除非用new 创建那个类的一个对象,否则实际上并
未得到任何东西。只有执行了new 后,才会正式生成数据存储空间,并可使用相应的方法。
但在两种特殊的情形下,上述方法并不堪用。一种情形是只想用一个存储区域来保存一个特定的数据——无
论要创建多少个对象,甚至根本不创建对象。另一种情形是我们需要一个特殊的方法,它没有与这个类的任
何对象关联。也就是说,即使没有创建对象,也需要一个能调用的方法。为满足这两方面的要求,可使用
static(静态)关键字。一旦将什么东西设为static,数据或方法就不会同那个类的任何对象实例联系到一
起。所以尽管从未创建那个类的一个对象,仍能调用一个 static方法,或访问一些 static数据。而在这之
53
前,对于非 static数据和方法,我们必须创建一个对象,并用那个对象访问数据或方法。这是由于非
static数据和方法必须知道它们操作的具体对象。当然,在正式使用前,由于static方法不需要创建任何
对象,所以它们不可简单地调用其他那些成员,同时不引用一个已命名的对象,从而直接访问非 static成员
或方法(因为非static成员和方法必须同一个特定的对象关联到一起)。
有些面向对象的语言使用了“类数据”和“类方法”这两个术语。它们意味着数据和方法只是为作为一个整
体的类而存在的,并不是为那个类的任何特定对象。有时,您会在其他一些Java 书刊里发现这样的称呼。

这说明了static所修饰的方法/变量可以直接通过类名访问,而不是先创建对象再对里面的静态方法/变量进行访问,当然这样也可以。

static所修饰的变量/代码块/方法在该类被加载时加载/运行(这里特指静态代码块,并且只执行一次)。同时,被static修饰的变量在堆只有一个副本,所有对象对该变量的操作都是在操作同一个变量,如果是实例变量的话,每个对象都有各自的副本,每个对象操作的都是各自的副本。

易混淆:在学习了static关键字之后,我们会觉得,被static修饰过的成员似乎与访问控制权限有关系,既然被static关键字修饰了,那么应该在哪里都可以访问它,其实并非这样。

public class StaticFundational {

    public static String s1 = "1";

    private static String s2 = "2";
}

public class StaticFundationalTest {

    public static void main(String[] args) {
        StaticFundational.s2;
    }
}

上面的测试类在编译时期报错了:
这里写图片描述


java中是否可以覆盖一个private方法?

在学习继承的过程中,我们知道,如果在父类中修饰了一个private的方法,子类继承之后,对子类也是不可见的。那么如果子类声明了一个跟父类中定义为private一样的方法,那么编译器只当作是你子类自己新增的方法,并不能算是继承过来的。

public class OverridePrivateMethod1 {
    private void print() {
        System.out.println("o1");
    }
}

public class OverridePrivateMethod2 extends OverridePrivateMethod1 {
    public void print() {
        System.out.println("o2");
    }
}

public class OverridePrivateMethodTest {

    public static void main(String[] args) {
        OverridePrivateMethod1 method = new OverridePrivateMethod2();
         method.print();
    }

}

结果在编译时期就检测到错误:这里写图片描述

java中是否可以覆盖一个static方法?

public class StaticOverride1 {

    public static void print() {
        System.out.println("o1");
    }
}


public class StaticOverride2 extends StaticOverride1 {

    public static void print() {
        System.out.println("o2");
        System.out.println("o2");
    }

}


public class StaticOverrideTest {

    /**
     * test wether the static method can be override by creating the subclass's
     * instance and invoking the same static method.
     * 
     */
    public static void main(String[] args) {
        StaticOverride1 override2 = new StaticOverride2();
        override2.print();
    }
}

运行结果:这里写图片描述

参考资料:
《java编程思想第四版》 2.6.3 static 关键字 PDF53页

Java中的static关键字解析

  • 7
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java,可以使用 `synchronized` 关键字让对象在任何时刻只能由一个线程访问。`synchronized` 关键字可以用于方法或代码块,用于实现线程的同步。 当一个方法或代码块被 `synchronized` 关键字修饰时,它被称为同步方法或同步代码块。在同步方法或同步代码块,只有一个线程可以访问该方法或代码块,其他线程必须等待该线程执行完毕后才能访问。 例如,下面的代码演示了如何使用 `synchronized` 关键字实现线程的同步: ```java class Counter { private int count = 0; public synchronized void increment() { count++; } public synchronized int getCount() { return count; } } class MyThread extends Thread { private Counter counter; public MyThread(Counter counter) { this.counter = counter; } @Override public void run() { for (int i = 0; i < 1000; i++) { counter.increment(); } } } public class Main { public static void main(String[] args) throws InterruptedException { Counter counter = new Counter(); MyThread thread1 = new MyThread(counter); MyThread thread2 = new MyThread(counter); thread1.start(); thread2.start(); thread1.join(); thread2.join(); System.out.println(counter.getCount()); // 输出 2000 } } ``` 在这个例子,首先定义了一个 `Counter` 类,包含了一个计数器 `count`,以及一个使用 `synchronized` 关键字修饰的 `increment()` 方法一个使用 `synchronized` 关键字修饰的 `getCount()` 方法。`increment()` 方法用于将计数器加 1,`getCount()` 方法用于获取计数器的值。 然后定义了一个 `MyThread` 类,继承自 `Thread` 类,用于执行计数器的增加操作。在 `Main` 类,创建了两个 `MyThread` 对象,传入同一个 `Counter` 对象,启动这两个线程并等待它们执行完毕后打印计数器的值。 运行这个程序可以看到,无论有多少个线程同时访问计数器,都能够保证计数器的值是正确的,这是因为 `increment()` 和 `getCount()` 方法都被 `synchronized` 关键字修饰,保证了同一时刻只有一个线程可以访问这些方法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值