Chapter 4:Initialization & Cleanup

博客介绍了Java类对象的创建过程。当首次创建Dog类对象或访问其static方法、字段时,Java解释器会搜索Dog.class,找到后运行所有static初始化模块。创建对象时,先分配内存并清零,再执行字段定义时的初始化,最后执行构建器。


类的成员变量会在成员函数(甚至构造式)之前完成初始化

在这里有必要总结一下对象的创建过程。请考虑一个名为Dog的类:
(1) 类型为Dog的一个对象首次创建时,或者Dog类的static方法/static字段首次访问时,Java解释器必须找到Dog.class(在事先设好的类路径里搜索)。
(2) 找到Dog.class后(它会创建一个Class对象,这将在后面学到),它的所有static初始化模块都会运行。因此,static初始化仅发生一次——在Class对象首次载入的时候。
(3) 创建一个new Dog()时,Dog对象的构建进程首先会在内存堆(Heap)里为一个Dog对象分配足够多的存储空间。
(4) 这种存储空间会清为零,将Dog中的所有基本类型设为它们的默认值(零用于数字,以及boolean和char的等价设定)。
(5) 进行字段定义时发生的所有初始化都会执行。
(6) 执行构建器。正如第6章将要讲到的那样,这实际可能要求进行相当多的操作,特别是在涉及继承的时候。

测试结果 0/1 6-基于二叉链表的二叉树最长路径的求解.cpp: In function ‘int main()’: 6-基于二叉链表的二叉树最长路径的求解.cpp:6:5: error: redefinition of ‘int main()’ int main() ^~~~ In file included from 6-基于二叉链表的二叉树最长路径的求解.cpp:3:0: 6.h:44:5: note: ‘int main()’ previously defined here int main() { ^~~~ 6-基于二叉链表的二叉树最长路径的求解.cpp:15:23: error: invalid initialization of reference of type ‘std::istringstream& {aka std::__cxx11::basic_istringstream&}’ from expression of type ‘char [100]’ CreateBiTree(T,S,++i); ^ In file included from 6-基于二叉链表的二叉树最长路径的求解.cpp:3:0: 6.h:13:6: note: in passing argument 2 of ‘void CreateBiTree(BiTNode*&, std::istringstream&)’ void CreateBiTree(BiTree &T, std::istringstream &iss) { ^~~~~~~~~~~~ 6-基于二叉链表的二叉树最长路径的求解.cpp:16:26: error: invalid initialization of reference of type ‘std::vector&’ from expression of type ‘BiTNode* [100]’ LongestPath(T,l,longest); ^ In file included from 6-基于二叉链表的二叉树最长路径的求解.cpp:3:0: 6.h:28:6: note: in passing argument 2 of ‘void LongestPath(BiTree, std::vector&, std::vector&)’ void LongestPath(BiTree T, std::vector &path, std::vector &longestPath) { ^~~~~~~~~~~ 测试集1 本关最大执行时间:20秒 本次评测耗时(编
最新发布
12-16
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值