这是我的代码:
class StaticBlock {
{
println("initializer block : " + message);
}
public StaticBlock(String message) {
this.message = message;
}
private String message;
}
现在的问题是,在初始化程序块中
{
println("initializer block : " + message);
}
如果我在this
之前添加关键字message
,则可以,但是缺少this
关键字时会出现错误。
编译器说:
StaticBlockDemo.java:34: illegal forward reference
println("initializer block : " + message);
^
1 error
他们为什么不一样?
我不了解设计原理,但可能有助于阅读Java语言规范的相关部分。
实例初始化器允许通过关键字
this
(§15.8.3)引用当前对象,使用关键字super
(§15.11.2,§15.12),并使用范围内的任何类型变量。有时会限制使用声明后在文本中出现的实例变量,即使这些实例变量在范围内。有关控制对实例变量的前向引用的精确规则,请参见第8.3.2.3节。
仅当成员声明是
static
类或接口的实例字段(分别)C
且满足以下所有条件时,成员声明才需要以文本形式出现:
用法发生在的实例(分别为
static
)变量初始化器中C
或的实例(分别为静态)初始化器中C
。用法不在作业的左侧。
用法是通过一个简单的名称。
C
是包含用法的最里面的类或接口。
以下是该规范中该部分的示例,它被精简以说明您要询问的特定点:
class UseBeforeDeclaration {
{
j = 200;
// ok - assignment
j = j + 1;
// error - right hand side reads before declaration
int k = j = j + 1;
// error - illegal forward reference to j
int n = j = 300;
// ok - j at left hand side of assignment
int h = j++;
// error - read before declaration
int l = this.j * 3;
// ok - not accessed via simple name
}
int j;
}
不过,我还应该指出,即使是代码的编译版本也无法实现您想要的功能。如果运行它:
new StaticBlock("abc");
它将打印
initializer block : null
这是因为初始化程序是在构造函数主体(大部分)之前执行的。以下是规格的要点:
[...]使用以下过程处理指示的构造函数以初始化新对象:
[...]
4.执行此类的实例初始化器和实例变量初始化器[...]
5.执行此构造函数的其余部分。[...]
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句