这是我的代码:
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语言规范的相关部分。
8.6。
实例初始化器
实例初始化器可以通过关键字
this
(§15.8.3)引用当前对象,使用关键字super
(§15.11.2,§15.12),并使用范围内的任何类型变量。有时会限制使用声明之后以文本形式出现的实例变量,即使这些实例变量在范围内。有关控制对实例变量的前向引用的精确规则,请参见第8.3.2.3节。
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
这是因为初始化程序是在构造函数主体(大部分)之前执行的。以下是规范的要点:
12.5。
创建新的类实例
[…] 使用以下过程处理指示的构造函数以初始化新对象:
[…]
4.执行此类的实例初始化器和实例变量初始化器 […]
5.执行此构造函数的其余部分。 […]
问题内容: 从sys.c第123行: 是数组的通用指针,我可以看到。但是,表示法是什么: 什么是? 编辑: 我在这里学到了另一个C技巧:将被 预处理 并替换为其内容并分配给。 问题答案: 使用 指定的初始化 程序进行 初始化 。 基于范围的初始化是gnu gcc扩展。 要将一系列元素初始化为相同的值,请写入。这是一个GNU扩展。例如, 它不是便携式的。编译与告诉您。 它在这里如何运作? 预处理器在
问题内容: 我们可以将代码放入构造函数或方法或初始化块中。初始化块有什么用?每个Java程序都必须有它吗? 问题答案: 首先,有两种类型的初始化块: 实例初始化块,以及 静态初始化块。 此代码应说明它们的用法以及执行顺序: 印刷品: 如果要运行某些代码而不管使用哪个构造函数,或者想要对匿名类进行一些实例初始化,则实例迭代块很有用。
问题内容: 似乎几乎没有人意识到这一点,但是Java中的“ thisreference”是最终的。在正常的编程天中,我认为可以通过在自己的类中重新定义此引用来重新定义整个实例: 为什么此引用在Java中是最终的? 问题答案: 问题不在于它是参考,而是它本身根本不是参考。是一个 关键字 ,“表示一个值,该值是对为其调用实例方法或默认方法的对象的引用”(JLS§15.8.3)。 此外,从可以重新分配变
问题内容: 我看见某个地方 问题答案: Google是您的朋友- 抢手货 -您还可以先看看什么是序列化。 它将成员变量持久化为字节流时标记为不序列化。通过网络传输对象时,需要对该对象进行“序列化”。序列化将对象状态转换为串行字节。这些字节通过网络发送,并且从这些字节中重新创建对象。由java暂态关键字标记的成员变量不会被传输,它们是有意丢失的。 此处的示例,稍作修改(感谢@pgras):
问题内容: 在此MySQL表定义中: 什么是关键字是什么意思?它不是主键,也不是外键,所以它仅仅是索引吗?如果是这样,用这种方法创建的这种索引有何特别之处? 问题答案: 从http://dev.mysql.com/doc/refman/5.1/en/create- table.html 引用 所以是一个;)
N4527 8.5.3[dcl初始参考] 5对“cv1 T1”类型的引用由“cv2 T2”类型的表达式初始化,如下所示: (5.1)-[...] (5.1.1)-[...] (5.1.2)-[...] (5.2)-否则,引用应该是对非易失性const类型的左值引用(即cv1应该是const),或者引用应该是右值引用。 (5.2.1)-如果初始化表达式 (5.2.1.1)-是一个xvalue(但不是