java中关于实例成员变量,静态成员变量,静态代码块 的问题。很是迷茫!

haojianfeng11 2012-03-07 09:12:47
如果一个类中有 实例成员变量,静态成员变量,静态代码块 ,他们是如何被加载后被初始化或执行的?
我最初的想法是:类被加载时,只有 静态成员变量被构造和静态代码块被执行,而实例成员变量是不会被构造的;
结果却不是,下面是代码:


package com.wind.jdbc;

public class TestStaticCode {
private static TestStaticCode tsc = new TestStaticCode();
static{
System.out.println("4");
}
private InstanceVariable iv = new InstanceVariable();

private TestStaticCode(){
System.out.println("3");
}

public static void main(String[] args){
}
}


package com.wind.jdbc;

public class InstanceVariable {
static{
System.out.println("1");
}
public InstanceVariable(){
System.out.println("2");
}
}


结果竟然是:
1
2
3
4
很是不解,,求指教!
...全文
380 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
黑暗圣骑士 2014-04-03
  • 打赏
  • 举报
回复
引用 11 楼 u011949650 的回复:
请问为什么在public static void main(String[] args) { // TODO Auto-generated method stub new TestStaticCode();//新添加的语句 } 执行结果是: 1 2 3 4 2 3 求解??
你在main方法有new一个对象,2,3是你new对象的结果。。1,2,3,4你楼上解释的结果, 总而言之就是static代码块》非static代码块》构造函数的顺序来执行!!!
Jemutse_默之 2014-03-21
  • 打赏
  • 举报
回复
请问为什么在public static void main(String[] args) { // TODO Auto-generated method stub new TestStaticCode();//新添加的语句 } 执行结果是: 1 2 3 4 2 3 求解??
coco86775005 2013-11-26
  • 打赏
  • 举报
回复
3#太给力了,其实就是---静态代码块-->非静态代码块-->构造函数-->级别相同情况下按先后顺序执行
wll72300991 2012-09-27
  • 打赏
  • 举报
回复
解惑了啊
五哥 2012-03-08
  • 打赏
  • 举报
回复
楼上很详细啊
qybao 2012-03-08
  • 打赏
  • 举报
回复
private static TestStaticCode tsc = new TestStaticCode(); --1
static{ --2
System.out.println("4");
}
同样的static级别,会按顺序执行,所以先执行 --1 后执行 --2
执行 --1的时候,应为 new TestStaticCode(); 会生成 TestStaticCode实例,所以会先调用 TestStaticCode的初始化块代码,然后再调用构造方法
private InstanceVariable iv = new InstanceVariable();
这条语句相当于2条语句
private InstanceVariable iv;
{iv = new InstanceVariable();} //这个就是初始化块代码,优先于构造方法
其他的就不用说明了,static{}静态块在类加载的时候被调用,{}非静态初始化块在实例对象被初始化构造方法被调用之前被调用
举个例子,LZ理解好这个例子就能理解你的代码了

public class Test {
public Test() {
System.out.println("我是构造方法9"); //构造方法在对象实例化时非静态初始化块执行结束以后被执行
System.out.println("我是构造方法10"); //同级别的安先后顺序执行
}

{System.out.println("我是非静态初始化块5");} //非静态初始化块在对象实例化时构造方法被调用之前被执行
{System.out.println("我是非静态初始化块6");} //同级别的按先后顺序执行
String str2 = "我是静态代码块7";
{
System.out.println(str2);
str2 = "我是静态代码块8"; //这里重新赋值
System.out.println(str2); //可见 String str2=xxx 相当于
//String str; {str=xxx;}//在非静态初始化块赋值
//非静态初始化块同级别按先后顺序执行
}

static {System.out.println("我是静态代码块1");} //静态块在类加载的时候被执行
static {System.out.println("我是静态代码块2");} //同级别的按先后顺序执行
static String str = "我是静态代码块3";
static {
System.out.println(str);
str = "我是静态代码块4"; //这里重新赋值
System.out.println(str); //可见 static String str=xxx 相当于
//static String str; static {str=xxx;}//在静态块赋值
//静态块同级别按先后顺序执行
}

public static void main(String[] args) {
new Test(); //LZ自己理解一下例子的执行顺序
}
}

安特矮油 2012-03-08
  • 打赏
  • 举报
回复
其实很容易理解的,都是这句引发的血案:
private static TestStaticCode tsc = new TestStaticCode();
根据对象初始化顺序,那么肯定要先执行这个了,
他发现需要构造一个TestStaticCode,那么自然会去调用构造函数,但是构造的时候他发现内部有个InstanceVariable还没初始化,所以他必须要先初始化InstanceVariable这个对象,jvm就会先初始化InstanceVariable了。所以打印出1,2。后面的3,4也就好理解了。
funnyone 2012-03-08
  • 打赏
  • 举报
回复
你 new TestStaticCode();之后 ,filed域肯定要初始化的。即 private InstanceVariable iv = new InstanceVariable();
haojianfeng11 2012-03-08
  • 打赏
  • 举报
回复
我错了,太大意了,,丢个板砖,得再好好看看,
haojianfeng11 2012-03-08
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 qybao 的回复:]
public class Test {
public Test() {
System.out.println("我是构造方法9"); //构造方法在对象实例化时非静态初始化块执行结束以后被执行
System.out.println("我是构造方法10"); //同级别的安先后顺序执行
}

{System.out.println("我是非静态初始化块5");} //非静态初始化块在对象实例化时构造方法被调用之前被执行
{System.out.println("我是非静态初始化块6");} //同级别的按先后顺序执行
static String str2 = "我是静态代码块7";
{
System.out.println(str2);
str2 = "我是静态代码块8"; //这里重新赋值
System.out.println(str2); //可见 String str2=xxx 相当于
//String str; {str=xxx;}//在非静态初始化块赋值
//非静态初始化块同级别按先后顺序执行
}

static {System.out.println("我是静态代码块1");} //静态块在类加载的时候被执行
static {System.out.println("我是静态代码块2");} //同级别的按先后顺序执行
static String str = "我是静态代码块3";
static {
System.out.println(str);
str = "我是静态代码块4"; //这里重新赋值
System.out.println(str); //可见 static String str=xxx 相当于
//static String str; static {str=xxx;}//在静态块赋值
//静态块同级别按先后顺序执行
}

public static void main(String[] args) {
new Test(); //LZ自己理解一下例子的执行顺序
}
}
[/Quote]
7 语句前少个static吧,
那执行结果应该是7 8 1 2 3 4 5 6 9 10
haojianfeng11 2012-03-08
  • 打赏
  • 举报
回复
理解了,,谢谢各位,,也别是Mr 阿宝
昨日凡阳 2012-03-08
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 qybao 的回复:]

Java code
private static TestStaticCode tsc = new TestStaticCode(); --1
static{ --2
System.out.println("4");
}
同样的static级别,会按顺序执行,所以先执行 --1 后执行 --2
执行 --1的时候,应为 new TestStaticCode();……
[/Quote]

++

很詳細
源码链接: https://pan.quark.cn/s/8ddf8a1c92f9 **libcurl用于获取大型文件**libcurl作为一个开源的C语言库,提供了一系列的API来处理与URL相关的任务,涵盖了HTTP、FTP、SMTP等多种网络协议的应用。在执行大型文件的下载操作时,libcurl展现出卓越的性能表现和高度的灵活性,能够高效地管理大文件传输过程,有效预防内存溢出及其他潜在问题。**libcurl的基础操作**libcurl的基础应用包括以下几个环节:1. **初始化**:需要借助`curl_global_init()`函数来启动libcurl的工作环境。2. **建立会话句柄**:通过`curl_easy_init()`函数创建一个会话句柄,该句柄将用于后续所有的操作流程。3. **配置选项**:运用`curl_easy_setopt()`函数来设定多种参数,例如目标URL、超时时间、重试次数以及数据写入的回调函数等。4. **执行请求**:调用`curl_easy_perform()`函数来实施下载操作。5. **释放资源**:使用`curl_easy_cleanup()`函数来释放已经占用的资源。**获取大型文件时的重要设置**1. **数据写入回调函数**:在处理大型文件下载时,通常不希望一次性将整个文件载入内存。可以配置`CURLOPT_WRITEFUNCTION`选项,指定一个回调函数来处理接收到的数据片段,这样libcurl在接收到数据时会调用该函数,使得我们可以按需将数据写入文件或缓冲区。2. **缓冲策略**:可以设定缓冲区的大小(比如,通过`CURLOPT_BUFFERSIZE`),来控制每次接收数据的数量,从而优化内存...
内容概要:本文档整合了《鬼谷子·决篇》与《三略·审权变第三》《差德行第四》三大古代智慧典籍,构建了一套“决策+形势+用人”三位一体的领导力提升体系。通过28天三合实战路径、三维诊断工具、9个实用模板及独特的“身体锚点”仪式,系统解决管理者在决策犹豫、形势误判、人岗错配等方面的痛点。全文涵盖理论溯源、方法论拆解(如三步决策法、审权变四步法、差德行四步法)、历史案例对照(范蠡 vs 项羽)以及跨资源联动建议,形成从认知到实践的完整闭环。; 适合人群:基层管理者、创业者、职场进阶者,尤其是面临决策困境、环境适应困难或团队用人问题的人群;具备一定管理经验或自我提升意识的个体亦可受益。; 使用场景及目标:① 提升重大事项的决策质量,避免反复纠结与事后后悔;② 增强对外部环境变化的敏感度与应对能力,实现灵活调整;③ 科学评估人才德才素质,实现人岗精准匹配,减少用人失误;④ 构建个人化的决策-应变-用人标准化流程(SOP)。; 阅读建议:建议按照28天路径逐步实践,结合自测表定位短板,优先突破薄弱模块;配套工具模板需实际填写使用,配合身体锚点仪式强化行为记忆;可与“诸葛亮决策术”“立将威信术”等单品联动,全面提升领导力体系。

51,409

社区成员

发帖
与我相关
我的任务
社区描述
Java相关技术讨论
javaspring bootspring cloud 技术论坛(原bbs)
社区管理员
  • Java相关社区
  • 小虚竹
  • 谙忆
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧