java之static详细总结

static也叫静态,可以修饰成员变量、成员方法。

成员变量

按照有无static分为两种:

  • 类变量:static修饰,属于类,与类一起加载一次,在内存中只有一份,会被类的全部对象共享
  • 实例变量(对象变量):无static修饰,属于每个对象的。

代码举例:

//先创建一个学生类
public class Student {
    //类变量
    static String name;
    //实例变量(对象变量)
    int age;

}


//测试
public class Test {
     public static void main(String[] args) {
        //1、类变量的使用
        //类名.类变量
        Student.name="袁华";
        //对象.类变量(不推荐)
        Student s1=new Student();
        s1.name="马冬梅";

        Student s2=new Student();
        s1.name="秋雅";

        System.out.println(s1.name); //输出秋雅
        System.out.println(Student.name);  //输出秋雅

        //2、实例变量的使用:属于每个对象的变量
        //对象、实例变量(不能通过类名.变量名访问)
        s1.age=23;
        s2.age=18;
        System.out.println(s1.age);  //输出23
        System.out.println(s2.age);  //输出18


    }
}

 一开始先将Test.class加载到方法区,然后main方法入栈,运行到Student.name="张三"会将Student.class加载到方法区,并检查是否有类变量,如果有也会将类变量立即加载到堆内存中,初始值为null,然后赋值成 袁华

 然后在堆内存中创建学生对象,学生变量s1指向这个对象,然后执行 s1.name=“马冬梅”  会在s1指向的对象中去寻找这个变量,如果没有这个变量,则通过类的地址去寻找Student.class,然后通过这个寻找到name并赋值成 “马冬梅”

 同理s2的创建和修改和上面一样

 最后s1和s2的name都指向同一个,所以最后输出的名字都是“秋雅”。

下面再看实例变量age的变化:

s1.age=23会通过s1找到第一个学生对象,将其变量age的值改为23;同理s2也是如此

类变量的应用场景 

        在开发中,如果某个数据只需要一份,且希望能够被共享(访问、修改),则该数据可以定义成类变量来记住。例如,一个类可以记住自己创建了多少个对象,如下图

成员方法

按照有无static分为两种:

  • 类方法:static修饰,属于类
  • 实例方法:无static修饰,属于每个对象的。

代码举例:

public class Student {
    double score;
    //类方法
    public static void printHelloWorld(){
        System.out.println("Hello World");
    }

    //实例方法
    public void printPass(){
        System.out.println("成绩"+(score>=60?"及格了":"没及格"));
    }
}


//测试
public class StaticTest {
    public static void main(String[] args) {
        //1、类方法的使用
        //类名.类方法
        Student.printHelloWorld();
        //对象.类方法(不推荐)
        Student s1=new Student();
        s1.printHelloWorld();


        //2、实例方法的使用:属于每个对象的方法
        //对象.实例方法(不能通过类名.方法名访问)
        s1.printPass();

    }
}

一开始先将Test.class加载到方法区,然后main方法入栈,运行到Student.printHelloWorld()会将Student.class加载到方法区,然后通过学生类找到printHelloWorld()方法,进行打印

  然后在堆内存中创建学生对象,学生变量s1指向这个对象,然后执行 s1.printHelloWorld() 时,会通过s1找到它指向的学生对象,然后通过学会对象找到Student这个类,通过这个类找到这个printHelloWorld()方法 。如图

 实例方法也是如此,但它会访问这个对象的一些变量,所以不能通过类名调用(通过类名调用就不知道访问哪个对象的变量了)。

补充:main方法也是类方法,也是通过类名.main进行调用的

应用场景

类方法最常见的应用场景是做工具类:提高了代码复用;调用方便,提高了开发效率

注意事项

1. 类方法中可以直接访问类成员,不可以直接访问实例成员

public class Student {
    static String schoolname;//类变量
    double score;//实例变量
    //类方法
    public static void printHelloWorld(){
        //同一个类中,访问类成员,可以省略类名
        schoolname="张三";
        printHelloWorld2();
//        score=12.0;//报错
//        printPass();//报错

    }
    //类方法
    public static void printHelloWorld2(){
        System.out.println("Hello World");
    }
    //实例方法
    public void printPass(){
        System.out.println("成绩"+(score>=60?"及格了":"没及格"));
    }
}

2. 实例方法中既可以直接访问类成员,也可以直接方法实例成员

public class Student {
    static String schoolname;//类变量
    double score;//实例变量
    //类方法
    public static void printHelloWorld2(){
        System.out.println("Hello World");
    }
    //实例方法
    public void printPass(){
        schoolname="李四";
        printHelloWorld2();
        printPass2();
        System.out.println(score);
    }
    //实例方法
    public void printPass2(){
        
    }
}

3. 实例方法中可以出现this关键字,类方法中不可以出现this关键字

因为实例方法用this时会拿到这个对象,而类方法拿不到对象

应用知识

1. 代码块

代码块是类的5大成分之一(成员变量、构造器、方法、代码块、内部类)。

代码块分为两种:

  • 静态代码块
    • 格式:static{}
    • 特点:类加载时自动执行,由于类只加载一次,所以静态代码块也只会执行一次
    • 作用:完成类的初始化,例如:对类变量的初始化赋值。
      public class Student {
          static int number=80;
          static{
              System.out.println("静态代码块执行了");
          }
      }
      //测试
      public class StaticTest {
          public static void main(String[] args) {
              System.out.println(Student.number);
          }
      }
      
      //输出
      
      静态代码块执行了
      80
  • 实例代码块
    • 格式:{}
    • 特点:每次创建对象时,执行实例代码块,并在构造器前执行
    • 作用:和构造器一样,都是用来完成对象的初始化的。例如对实例变量进行初始化赋值

2. 单例模式

确保一个类只有一个对象

写法

  • 把类的构造器私有
  • 定义一个类变量记住类的一个对象
  • 定义一个类方法,返回对象
    public class A {
        //2.定义一个类变量记住类的一个对象
        private static A a=new A();
    
        //1.私有类的构造器
        private A() {
        }
        //3.定义一个类方法,返回对象
        public static A getObject(){
            return a;
        }
    }

 实现方式

  • 饿汉式单例:拿到对象时,对象早已经创建好了。上面便是。
  • 懒汉式单例:拿到对象时,才开始创建对象。
    public class B {
        //1.类的构造器私有
        private B() {
        }
        //2.定义一个类变量,用户存储这个类的一个对象
        private static B b;
        //3.定义一个类方法,要保证第一次调用时才创建一个对象,后面调用时都会用这同一个对象
        public static B getObject(){
            if(b==null){
                b=new B();
            }
            return b;
        }
    }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/522879.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

docker-compose安装adguard给局域网提供dns加速服务

启动配置 docker-compose.yaml配置文件 version: 3.3 services:adguard:image: adguard/adguardhome:latestcontainer_name: adguardrestart: unless-stoppedvolumes:- ./workdir:/opt/adguardhome/work- ./confdir:/opt/adguardhome/confports:- 53:53/tcp- 53:53/udp- 81:8…

蓝桥-回文日期

目录 题目链接 ​编辑 ​编辑 什么是回文数?​编辑 代码 100%过 90%暴力 优化写的暴力代码 题目链接 2.回文日期 - 蓝桥云课 (lanqiao.cn) 什么是回文数? 代码 100%过 把那个90%的代码的循环限制条件去掉就行了,题目只是限制了N…

每日一题(leetcode1026):节点与其祖先的最大差值--dfs

考虑到只能计算祖先之间的节点差而不能计算兄弟之间的节点差,所以思考使用dfs来解决该题。 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), ri…

axure谷歌插件(直接下载)

axure谷歌插件 在网上找一个谷歌的axure,不是登陆就是收费,离谱。找了好久才找到这个,我下载保存到网盘了,直接下载就ok,永久无提取码。 下载插件文件,打开开发者模式,直接拖进来就ok。 网盘…

YOLOv8改进 | 细节涨点篇 | 利用YOLOv8自带的RayTune进行超参数调优

一、本文介绍 本文给大家带来的改进机制是利用Ray Tune进行超参数调优,在YOLOv8的项目中目前已经自带了该超参数调优的代码,我们无需进行任何的改动,只需要调用该方法输入我们的一些指令即可,当然了,这些超参数的设置还是比较又学问的,本文的内容也是应群友的需求进行发…

mid转MP3怎么转?一分钟搞定~

MIDI(Musical Instrument Digital Interface)文件格式的诞生可以追溯到上世纪80年代,音频技术迅速崛起。为了让不同音乐设备之间能够互相通信,MIDI格式成为了音乐的标准。它不同于常见的音频文件格式,不包含实际的声音…

JavaEE 初阶篇-深入了解线程池(线程池创建、线程池如何处理任务)

🔥博客主页: 【小扳_-CSDN博客】 ❤感谢大家点赞👍收藏⭐评论✍ 文章目录 1.0 线程池概述 1.1 线程池的优点 1.2 不使用线程池的问题 1.3 线程池的工作原理图 1.4 如何创建线程池? 2.0 通过 ThreadPoolExecutor 类自定义创建线程…

关于交叉小波变换

小波变换可以很好的在时频域中分析单个信号的瞬态和突变等时变特性,交叉小波变换是在小波变换的基础上提出的, 主要用来处理两个信号之间的相关程度。传统的互相关分析方法, 是通过傅里叶变换将信号从时域上转换到频域上,然后在频…

neo4j图数据库下载安装配置

neo4j下载地址Index of /doc/neo4j/3.5.8/ 1.说明:jdk 1.8 版本对应的 neo4j 数据库版本 推荐安装3.X版本 2.配置系统环境变量 3.启动 neo4j.bat console 4.访问

ENSP防火墙,解决不兼容及报错等问题,windows命令行修改网卡配置,配置cloud及防火墙连接,web连接防火墙

解决不兼容和报错等问题 原因1:VirtualBox版本太低(5.1.x)或太高(6.x.x)和eNSP不兼容 卸载virtualbox,下载virtualbox 5.2.28,安装稳定版本的virtualbox 删除原有程序:c:\用户\***\.…

烤羊肉串引来的思考--命令模式

1.1 吃羊肉串! 烧烤摊旁边等着拿肉串的人七嘴八舌地叫开了。场面有些混乱,由于人实在太多,烤羊肉串的老板已经分不清谁是谁,造成分发错误,收钱错误,烤肉质量不过关等。 外面打游击烤羊肉串和这种开门店做烤…

FSQ8罗德与施瓦茨FSQ8信号分析仪

181/2461/8938产品概述: R&S FSQ8 信号分析仪将两种仪器合二为一。它提供高达 120 MHz 解调带宽的信号分析以及高端频谱分析仪的动态范围。 频率范围:20 Hz 至 8 GHz高端频谱分析仪的动态范围 TOI 25 dBm,典型值1 dB 压缩 13 dBm&…

【已解决】HalconDotNet.HOperatorException:“HALCON error #1201: Wrong type of control

前言 最近在学习Halcon视觉和C#的联合开发,碰到一个比较有意思的问题记录一下,大致的报错信息是说我用的halcondotnet版本和我在halcon导出的使用的halcondotnet.dll版本不一致,所以才报错的! 解决 首先你得找到你安装halcon的…

安全测试概述和用例设计

一、安全测试概述 定义:安全测试是在软件产品开发基本完成时,验证产品是否符合安全需求定义和产品质量标准的过程。 概念:安全测试是检查系统对非法侵入渗透的防范能力。 准则:理论上来讲,只要有足够的时间和资源&a…

哈希字典Dict

目录 Dict的组成 1.hash表的节点 2.hash表结构 3.字典 4.Dict结构 hash算法 哈希函数 什么情况下使用 rehash rehash主要的函数dictExpand 怎么判断要进行扩容还是收缩 什么时候会用到扩展和收缩 渐进式rehash 渐进式rehash主要的函数dictRehash 字典API 字典的…

shopee虾皮运营技巧,学会这几招能有效提高销量

在电商的运营过程中,新手总会踩上不少的坑,运气好的累计成经验值,应用于日后的店铺运营中,运气不好的,进坑了就再也爬不上来了,特别是跨境电商,本身与国内电商存在很大的信息差,不可…

【EI会议】2024年机械制造、航天工程技术与材料应用国际学术会议 (MMAETMA 2024)

2024 International Academic Conference on Mechanical Manufacturing, Aerospace Engineering Technology and Materials Application (MMAETMA 2024) 会议地点:长沙,中国 截稿时间:2024.4.30 网址:http://www.mmaetma.com/ …

Linux环境下安装redis踩坑zmalloc.h:50:31收录(附解决方法)

老将回归第一篇问题收录(苦笑) 报错收录 解决:zmalloc.h:50:31: 致命错误:jemalloc/jemalloc.h:没有文件或目录 解法一: # 执行如下命令 MALLOC环境变量去建立Redis的libcmake MALLOClibc解决 解法二&a…

FJSP:霸王龙优化算法(Tyrannosaurus optimization,TROA)求解柔性作业车间调度问题(FJSP),提供MATLAB代码

一、柔性作业车间调度问题 柔性作业车间调度问题(Flexible Job Shop Scheduling Problem,FJSP),是一种经典的组合优化问题。在FJSP问题中,有多个作业需要在多个机器上进行加工,每个作业由一系列工序组成&a…

企业IT运维事中故障定位方法及工具

企业IT故障定位指诊断故障直接原因或根因,故障定位有助于故障恢复动作更加有效。故障定位通常是整个故障过程中耗时最长的环节,定位的目标围绕在快速恢复的基础上,而非寻找问题根因,后者由问题管理负责。通常大部分可用性故障&…