问题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. Lecture3

    Smiling & Weeping ---- 蝴蝶在双翼里藏匿夏的脉络 妄图在绿意中品鉴隆冬 第三章 Git分支管理 3.1 分支的简介 Git最重要的运用场景是多人协同开发,但是如何能保证每 ...

  2. 记一次cdh6.3.2版本spark写入phoniex的错误:Incompatible jars detected between client and server. Ensure that phoenix-[version]-server.jar is put on the classpath of HBase in every region server:

    Caused by: java.lang.reflect.InvocationTargetException at sun.reflect.NativeConstructorAccessorImpl. ...

  3. HBase 中的 JVM 与 GC

    HBase中JVM基本配置 在JVM中,默认情况下会设置minimum heap size 为 1/64 可用物理内存,并为maximum heap size设置 1/4 的物理可用内存(不过在Jav ...

  4. vim中ctags 的使用

    --- title: vim中ctags 的使用 EntryName: vim-config-with-ctags date: 2020-08-19 11:17:38 categories: tags ...

  5. Ubuntu 下 python 安装pip

    背景 python的强大在于它的第三方库. 安装 python2 sudo apt-get install python-pip python3 curl https://bootstrap.pypa ...

  6. [python] Python日志记录库loguru使用指北

    Loguru是一个功能强大且易于使用的开源Python日志记录库.它建立在Python标准库中的logging模块之上,并提供了更加简洁直观.功能丰富的接口.Logging模块的使用见:Python日 ...

  7. C# pythonnet(2)_FFT傅里叶变换

    Python代码如下 import pandas as pd import numpy as np import matplotlib.pyplot as plt # 读取数据 data = pd.r ...

  8. 七牛云 + PicGo

    下载PicGo https://github.com/Molunerfinn/PicGo/releases/tag/v2.3.1 七牛云配置 1.AccessKey和SecretKey:可以在七牛云控 ...

  9. [翻译] PySide6.QtCore.Qt.ConnectionType

    翻译 (自用,不保证对) PySide6.QtCore.Qt.ConnectionType 这个 enum 描述了 signals 和 slots 连接(connection) 的类型. 在一些特殊情 ...

  10. SpringBoot 2.5.5整合SpringSecurity+JWT

    目录结构 添加依赖 <!-- SpringSecurity --> <dependency> <groupId>org.springframework.boot&l ...