Java 中的静态块
Java 在对象初始化之前使用静态块来执行代码。当我们用 static
关键字声明一个块时,我们称它为静态块。
它在 Java 中也称为静态初始化块或静态初始化块。当类加载到内存中时,静态块体内的代码会执行一次。
语法:
static {
// body of the staic block
}
在 Java 中,静态块总是在 main
方法之前执行,因为它在类加载和对象创建之前存储在内存中。
Java 中的静态块示例
让我们通过这个例子来看看。在这里,我们创建了一个静态块来检查执行顺序。
静态块首先执行,甚至在 main()
方法之前。
// Java Static Block Example
public class SimpleTesting {
// creating static block
static {
System.out.println("This is static block");
}
public static void main(String[] args) {
System.out.println("This is main method");
}
}
输出:
This is static block
This is main method
这里,JVM
首先执行静态块,在静态块完全执行之后,它执行 main()
方法。
这里可能会出现一个问题:我们可以在不创建 main()
方法的情况下使用静态块吗?答案是肯定的。
我们可以做 JDK version 1.6
或以前的版本;否则,它将在运行时显示错误。
Java 6 中的静态块
在这里,我们创建了一个静态块,并且该类不包含 main()
方法。此代码执行良好并显示所需的结果。
public class SimpleTesting {
static {
System.out.println("This is static block");
}
}
输出:
This is static block
Java 7 或更高版本中的静态块
如果我们在没有 main()
方法的类中声明静态块,则代码不会编译并向控制台抛出错误。
public class SimpleTesting {
static {
System.out.println("This is static block");
}
}
输出:
Error: Main method not found in class Example_1, please define the main method as:
public static void main(String[] args)
or a JavaFX application class must extend javafx.application.Application
让我们再看一个静态块的例子。
在这里,我们在另一个类中创建了一个静态块,并且在另一个类中声明了 main()
方法。
使用类名访问其变量时,代码执行得很好。请参见下面的示例。
class Sample {
static int a;
int b;
// creating the static block
static {
a = 20;
System.out.println("Static block");
}
}
public class SimpleTesting {
public static void main(String[] args) {
// accessing a without creating an object
System.out.println(Sample.a);
}
}
输出:
Static block
20
Java 中的静态块和构造函数
请注意,静态块在构造函数之前执行。请参见下面的示例。
class Sample {
static int a;
int b;
// creating the static block
static {
a = 20;
System.out.println("I am static block");
}
// creating the constructor
Sample() {
System.out.println("I am constructor");
}
}
public class SimpleTesting {
public static void main(String[] args) {
// creating the objects
Sample obj1 = new Sample();
Sample obj2 = new Sample();
}
}
输出:
I am static block
I am constructor
I am constructor
如果我们创建 5 个对象,那么实例块会执行 10 次,但静态块的执行并不依赖于对象的创建。
它的执行取决于类的加载,我们知道,类只加载一次,因此静态块只会执行一次。
public class SimpleTesting {
// Declaring two instance blocks.
{ System.out.println("This is instance block-1"); }
{ System.out.println("This instance block-2"); }
// Declaring two static blocks.
static {
System.out.println("Static block-1");
}
static {
System.out.println("Static block-2");
}
// Declaring zero parameter constructor.
SimpleTesting() {
System.out.println("0 argument constructor");
}
// Declaring one parameter constructor with int parameter named a.
SimpleTesting(int a) {
System.out.println("1 argument constructor");
}
public static void main(String[] args) {
// Creating an object of class.
new SimpleTesting(); // Nameless object.
// Creating another object of class and passing an integer argument value.
new SimpleTesting(20); // Nameless object.
}
}
输出:
Static block-1
Static block-2
This is instance block-1
This instance block-2
0 argument constructor
This is instance block-1
This instance block-2
1 argument constructor
Java 中的多个静态块
Java 允许在一个类中创建任意数量的静态块。我们在一个类中创建了两个静态块,代码执行得很好。
public class SimpleTesting {
static {
System.out.println("I am static block - 1");
}
static {
System.out.println("I am static block - 2");
}
public static void main(String[] args) {
System.out.println("I am main method");
}
}
输出:
I am static block - 1
I am static block - 2
I am main method
在下面的例子中,我们在一个类中定义了一个 method
、constructor
、instant block
、static block
。
查看执行顺序以了解 JVM 执行优先级
。
public class SimpleTesting {
int x = 10;
static int y = 20;
void fun1(int a) {
System.out.println("This is instance method");
}
static void fun2(String str) {
System.out.println("This is static method");
}
SimpleTesting() {
System.out.println("0 argument constructor");
}
SimpleTesting(int a) {
System.out.println("1 argument constructor");
}
{ System.out.println("This is instance block"); }
static {
System.out.println("This is static block");
}
public static void main(String[] args) {
SimpleTesting at = new SimpleTesting();
SimpleTesting at2 = new SimpleTesting(10);
at.fun1(50);
SimpleTesting.fun2("Name");
}
}
输出:
This is static block
This is instance block
0 argument constructor
This is instance block
1 argument constructor
This is instance method
This is static method
相关文章
Java 中的实例化是什么意思
发布时间:2023/11/14 浏览次数:100 分类:Java
-
本文讲授 Java 中的实例化主题。本文介绍了 Java 中的实例化概念。我们在 Java 中使用对象是因为它是一种面向对象的编程语言。
Java 中的可变参数
发布时间:2023/11/14 浏览次数:125 分类:Java
-
本文介绍了 Java 中的可变参数。变量参数 varargs 是 Java 中的一个概念。我们可以为方法提供可变数量的参数零或多个参数。
Java 中的箭头运算符 ->
发布时间:2023/11/14 浏览次数:99 分类:Java
-
这篇文章就是要了解 Java 中的箭头运算符。本文介绍了箭头运算符 (->) 在 Java 中的作用,并列出了一些示例代码来理解该主题。
Java 中的 volatile 关键字
发布时间:2023/11/13 浏览次数:174 分类:Java
-
本文讨论了 Java 中的 volatile 关键字及其优缺点,并举例说明了如何使用。Java 是一种非常流行的编程语言,通过了解 Java,我们可以很容易地理解它为什么会在编程社区中获得这样的地位。
Java 中的 StringUtils
发布时间:2023/11/13 浏览次数:81 分类:Java
-
本文介绍 Java 中的 StringUtils 类是什么。本文介绍什么是 StringUtils 以及如何在 Java 中使用它来处理字符串。StringUtils 是一个用于处理 String 的类,它提供了比 Java String 类更多的实用方法。
Java 中的 flatMap
发布时间:2023/11/13 浏览次数:132 分类:Java
-
本文介绍 flatMap 以及如何在 Java 中使用它。本文介绍 flatMap 以及如何在 Java 中使用它。flatMap 是 Java 流中的一个操作/函数,用于在执行某些功能性任务后获取新流。在这里,我们将讨论 flatMap
在 Java 中将 Stream 元素转换为映射
发布时间:2023/11/13 浏览次数:77 分类:Java
-
我们将使用 Java 将流元素转换为映射。我们将向你展示如何使用 Collectors.toMap() 从 Java 字符串中提取映射。我们将讨论 Java Streams 的实际用途以及如何将流元素转换为映射元素。
Java 中的 findFirst 流方法
发布时间:2023/11/13 浏览次数:171 分类:Java
-
本教程介绍 Java 中的 findFirst 流方法。java.util.stream API 是在 Java 8 中引入的;它用于处理对象的集合。不同的源(例如数组或集合)可以创建流。
Java 中的 Stream 的 reduce 操作
发布时间:2023/11/13 浏览次数:147 分类:Java
-
本文介绍 Java 中 stream 的 reduce 操作。本文将讨论 reduce() 操作细节并讨论它的一些示例。在讨论 reduce() 操作之前。让我们首先讨论减少。