问题1:

public class Demo01_StaticTest {

    private static Demo01_StaticTest st = new Demo01_StaticTest();

    public static int count1;

    public static int count2 = 0;

    private Demo01_StaticTest(){
count1++;
count2++;
} public static Demo01_StaticTest getInstance(){
return st;
} public static void main(String[] args) {
Demo01_StaticTest st = Demo01_StaticTest.getInstance(); System.out.println("count1: " + st.count1);
System.out.println("count2: " + st.count2);
} }

  

    2.分析

    • main方法中的顺序开始分析

      Demo01_StaticTest st = Demo01_StaticTest.getInstance();
      
      这是一个静态方法,返回值是当前类中新定义的实例对象,
      private static Demo01_StaticTest st = new Demo01_StaticTest(); 执行顺序先执行无参构造方法 private Demo——StaticTest()
      {
      count1++;
      count2++;
      } 构造函数执行 count1/2初始值都是0 ,自增后都+1 此时count1 = 1,count2= 1; 构造函数外,除count1 无引用之外,count2重新引用指向0.
      也就是方法参数的几个条件:
      1 一个方法不能改变一个基本数据类型的参数
      2 一个方法可以改变一个对象的参数状态
      3 一个方法不能让对象参数引用一个新对象

       Demo01_StaticTest st = Demo01_StaticTest.getInstance();
      执行到这 返回的count1 count2 为1 , 0;
      
      
      • 3.问题变化

        public class Demo02_StaticTest {
        
            public static int count1;
        
            public static int count2 = 0;
        
            private static Demo02_StaticTest st = new Demo02_StaticTest();
        
            private Demo02_StaticTest(){
        count1++;
        count2++;
        } public static Demo02_StaticTest getInstance(){
        return st;
        } public static void main(String[] args) {
        Demo02_StaticTest st = Demo02_StaticTest.getInstance(); System.out.println("count1: " + st.count1);
        System.out.println("count2: " + st.count2);
        }
        }

        4.分析

        • 完全一样的分析方法
        • 最后的值为1,1


          二、例2:父类子类中均有静态代码块

          public class Demo03_StaticTest {
          public static void main(String[] args) {
          new Child();//请问会输出些什么,以及顺序
          }
          } class Parent{
          static String name = "hello";
          static { System.out.println("parent static block");
          } public Parent(){
          System.out.println("parent constructor");
          } } class Child extends Parent{ static String childNam = "word";
          static { System.out.println("child static block");
          } public Child(){
          System.out.println("child constructor");
          }
          }

          2.分析

          • 在创建子类`new Child()的时候,会按下述的顺序执行
          • 首先去父类中看是否用静态相关的东西,有就先执行
          • 然后再看子类中是否用静态相关的东西,有就执行(以上两步可以总结为静态先行)
          • 然后再去执行父类的构造函数
          • 最后再执行子类的构造函数
          • 所以最后的输出是:

            3另一个重要的问题

            • 当子类定义构造方法的时候,它首先会去找父类中不带参数的构造方法

            • 所以父类中不带参数的构造方法永远先执行

          如果父类没有不带参数的构造方法,必须显示的调用,指定调用父类的哪一个构造方法

          • 这里有个问题,为什么必须要先执行父类的构造方法呢?

              可以简单的理解,没有父类哪来的子类呢!
问题5:

public class A {
static {
System.out.println("a");
} public static String H = "hello"; public A() {
}
} public class B extends A { static {
System.out.println("B");
}
}

  

public class MainDemo {
public static void main(String[] args) throws ClassNotFoundException {
String s = B.H; }
}

  分析:

    这里很容容易思维定式:认为B.H;是新建了B对象   从而就父类静态代码块 子类静态代码块 父类构造方法 子类构造方法 
    

这里并没有涉及到B类的实例化,因为静态变量在类之间是共享的,前提是需要在静态方法中调用  非静态可以使用静态,静态不能使用非静态

Java静态相关问题的更多相关文章

  1. java 静态相关内容

    一般情况下,如果有些代码必须在项目启动的时候就执行的时候,需要使用静态代码块,这种代码是主动执行的;需要在项目启动的时候就初始化,在不创建对象的情况下,其他程序来调用的时候,需要使用静态方法,这种代码 ...

  2. 常用 Java 静态代码分析工具的分析与比较

    常用 Java 静态代码分析工具的分析与比较 简介: 本文首先介绍了静态代码分析的基 本概念及主要技术,随后分别介绍了现有 4 种主流 Java 静态代码分析工具 (Checkstyle,FindBu ...

  3. [转载] 常用 Java 静态代码分析工具的分析与比较

    转载自http://www.oschina.net/question/129540_23043 简介: 本文首先介绍了静态代码分析的基本概念及主要技术,随后分别介绍了现有 4 种主流 Java 静态代 ...

  4. Java线程相关的热门面试题

    ---恢复内容开始--- 下面是Java线程相关的热门面试题,你可以用它来好好准备面试. 1) 什么是线程? 线程是操作系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位.程序 ...

  5. 【转载】常用 Java 静态代码分析工具的分析与比较

    摘自:http://www.oschina.net/question/129540_23043常用 Java 静态代码分析工具的分析与比较 简介: 本文首先介绍了静态代码分析的基本概念及主要技术,随后 ...

  6. Java web相关内容

    我们即将学习Java web 这是通过查阅资料找到的和Java web 相关的内容. 一:Java web的含义 JavaWeb,是用Java技术来解决相关web互联网领域的技术总和.web包括:we ...

  7. Java 静态工厂模式的使用

    多相关文章请参考:http://www.enjoytoday.cn/categorys/java 静态工厂模式给人的第一印象就是:static+abstract.这两个词汇已经说明了一切,一个是周期长 ...

  8. Java面向对象——相关基本定义

    Java面向对象——相关基本定义 摘要:本文简单介绍了面向对象的编程方式,以及与之有关的一些基本定义. 面向对象 什么是面向对象 面向对象编程是一种对现实世界建立计算机模型的一种编程方法.简称OOP( ...

  9. 常用Java静态代码分析工具的分析与比较

    给国产静态代码检测工具Pinpoint打Call! 简介 本文首先介绍了静态代码分析的基本概念及主要技术,随后分别介绍了4种现有的主流Java静态代码分析工具 (Checkstyle,FindBugs ...

  10. Phoenix简介概述,Phoenix的Java API 相关操作优秀案例

    Phoenix简介概述,Phoenix的Java API 相关操作优秀案例 一.Phoenix概述简介 二.Phoenix实例一:Java API操作 2.1 phoenix.properties 2 ...

随机推荐

  1. 笔记:Sublime Text3配置

    Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解` 笔记:Sublime Text3配置 日期:2017-12 ...

  2. NumPy 差分、最小公倍数、最大公约数、三角函数详解

    NumPy 差分 离散差分意味着相邻元素之间的减法. 例如,对于 [1, 2, 3, 4],离散差分将是 [2-1, 3-2, 4-3] = [1, 1, 1] 要找到离散差分,使用 diff() 函 ...

  3. app备案

    最近app要求备案,使用阿里云备案 安卓可以上传apk获取信息,那么ios怎么弄呢 https://zhuanlan.zhihu.com/p/660738854?utm_id=0 查看的时候需要使用m ...

  4. Java基础:throw和throws的详解

    总结来说,throw是用来抛出一个具体的异常实例,而throws是用来声明方法可能会抛出哪些类型的异常,是对调用者的一种通知和要求. 1. throw 作用: throw关键字用于在方法体内实际抛出一 ...

  5. 基于人类反馈的强化学习,Reinforcement Learning from Human Feedback (RLHF)

    基于人类反馈的强化学习, RLHF,转载参考链接 RLHF 是一项涉及多个模型和不同训练阶段的复杂概念,可以按三个步骤分解: 预训练一个语言模型 (LM) : 聚合问答数据并训练一个奖励模型 (Rew ...

  6. Django-缓存、信号与序列化

    缓存 1.缓存的简介 在动态网站中,用户所有的请求,服务器都会去数据库中进行相应的增,删,查,改,渲染模板,执行业务逻辑,最后生成用户看到的页面. 当一个网站的用户访问量很大的时候,每一次的的后台操作 ...

  7. gerrit权限控制

    gerrit权限控制 背景 在公司中使用到了Gerrit作为技术管理,在配置的时候发现一些问题:转载了这篇文章作为学习. 正文开始 原文链接:https://blog.csdn.net/chenjh2 ...

  8. 三层交换机vlan间路由

    sw1: [Huawei]vlan batch 10 20 [Huawei]int e0/0/1 [Huawei-Ethernet0/0/1]port link-type access [Huawei ...

  9. C#皮肤美化

    关于Winform窗体美化,目前大致了解是有两种方式:第一种方式是重写Winform本身的控件,不过这需要非常熟悉控件的各个属性和事件并且要求具有很高的GDI绘图技术.第二种方式是借助第三方Winfo ...

  10. c++17 auto非类型模板参数

    //用auto非类型模板参数 #include <iostream> using namespace std; template<auto c> auto foot() { c ...