彻底填平Static坑(细节决定成败)

static

学习的过程就是填坑的过程,可不要偷懒想着跳过去,你现在跳过去,就相当于给自己挖了一个坑,你迟早会掉进去的,为了避免不掉坑,所以,努力填坑吧!

一.如果没有static会怎样?

需求:  

1:定义Student类

1:姓名、国籍,说话行为

2:多个构造,重载形式体现

2:学生的国籍都是确定的

1:国籍可以进行显示初始化

public class Student {
    String name;//姓名
    String country;//国籍

    public Student(String name, String country) {
        this.name = name;
        this.country = country;
    }

    public void speak(){
        System.out.println("姓名:"+this.name+" "+"国籍:"+this.country);
    }
}

class Test{
    public static void main(String[] args) {
        Student student = new Student("何道昌","中国");
        Student student1 = new Student("孙双双","中国");

        student.speak();
        student1.speak();
    }
}

  

运行结果:

姓名:何道昌 国籍:中国
姓名:孙双双 国籍:中国

  

目前存在的问题:

        现在我们已知学生都是中国人,现在我们每创建一个学生对象,就要给所有学生的国籍属性赋相同的值,这样造成堆内存空间资源浪费

目前方案:

        把“中国”这个数据移动到数据共享区中,共享这个数据给所有的Student对象使用即可

        疑问:如何才能把这个数据移动到数据共享区中共享呢?

解决方案:

        只需要用static修饰该数据即可

        静态的成员变量只会在数据共享区中维护一份,而非静态成员变量的数据会在每个对象中都维护一份

 

public class Student {
    String name;//姓名
    //使用了static修饰country,那么这时候country就是一个共享的数据
    static String country = "中国";//国籍
    //构造函数
    public Student(String name) {
        this.name = name;
    }
     //说话行为
    public void speak(){
        System.out.println("姓名:"+this.name+" "+"国籍:"+country);
    }
}

class Test{
    public static void main(String[] args) {
        Student student = new Student("何道昌");
        Student student1 = new Student("孙双双");

        student.speak();
        student1.speak();
    }
}

  

运行结果:

姓名:何道昌 国籍:中国
姓名:孙双双 国籍:中国

  

下面我来详细解说static

static(静态修饰符)

1.static修饰静态变量

        如果有数据需要被共享给所有对象使用时,那么就可以使用static修饰

        静态成员变量的访问方式:

               方式一: 可以使用对象进行访问

                             格式:对象.变量名

               方式二:可以使用类名进行访问

                             格式:类名.变量名

               注意:

                         1.非静态的成员变量只能使用对象进行访问,不能使用类命进行访问

public class Student {
    String name;//姓名     非静态成员变量
    //使用了static修饰country,那么这时候country就是一个共享的数据
    static String country = "中国";//国籍    静态成员变量
    //构造函数
    public Student(String name) {
        this.name = name;
    }
     //说话行为
    public void speak(){
        System.out.println("姓名:"+this.name+" "+"国籍:"+country);
    }
}

class Test{
    public static void main(String[] args) {
        Student student = new Student("何道昌");

        System.out.println(student.name);//用对象访问非静态变量        Systen.out.println(student.country);//用对象访问静态变量
        System.out.println(Student.country);//用类命访问静态变量
    }
}

  

运行结果:

何道昌中国
中国

  

2.千万不要为了方便访问数据而使用static修饰成员变量,只有成员变量的数据真正需要被共享的时候,才使用static修饰

            static修饰成员变量的应用场景:如果一个数据需要被所有对象共享使用的时候,用static修饰

2.static修饰成员函数(静态的成员方法)

            

 静态成员函数的访问方式:

               方式一: 可以使用对象进行访问

                             格式:对象.静态的函数名

               方式二:可以使用类名进行访问

                             格式:类名.静态的函数名

推荐使用类名直接访问静态的成员

         原因:

                   1.方便      

                   2.节省内存

静态函数要注意的事项:

        1.静态函数是可以调用类名或者对象进行调用的,而非静态函数只能使用对象进行调用

        2.静态的函数可以访问静态的成员,但是不能直接访问非静态的成员

        3.非静态的函数是可以直接访问静态与非静态的成员

        4.静态函数不能出现this或者super关键字

public class Student {
    String name;//姓名     非静态成员变量
    //使用了static修饰country,那么这时候country就是一个共享的数据
    static String country = "中国";//国籍    静态成员变量
    //构造函数
    public Student(String name) {
        this.name = name;
    }
     //说话行为
    //静态成员方法
    public static void speak(){
        System.out.println("国籍:"+country);
    }
    //学习行为
    //非静态成员方法
    public  void study(){
        System.out.println(name+"好好学习");
    }
}

class Test{
    public static void main(String[] args) {
        Student student = new Student("何道昌");

        System.out.println(student.name);//用对象访问非静态变量
        System.out.println(student.country);//用对象访问静态变量
        System.out.println(Student.country);//用类命访问静态变量

        student.study();//用对象访问非静态方法
        student.speak();//用对象访问静态方法
        Student.speak();//用类名访问静态方法
    }
}

  

运行结果:

何道昌
中国
中国
何道昌好好学习
国籍:中国
国籍:中国

  

最后,继续用这个例子穿插一下静态代码块的知识

           静态代码块是在Student.class文件加载到内存的时候就马上执行的

public class Student {
    String name;//姓名     非静态成员变量
    //使用了static修饰country,那么这时候country就是一个共享的数据
    static String country = "中国";//国籍    静态成员变量
    //静态代码块
    static{
        System.out.println("静态代码块执行了!!");
    }
    //构造函数
    public Student(String name) {
        this.name = name;
    }
     //说话行为
    //静态成员方法
    public static void speak(){
        System.out.println("国籍:"+country);
    }
    //学习行为
    //非静态成员方法
    public  void study(){
        System.out.println(name+"好好学习");
    }
}

class Test{
    public static void main(String[] args) {
        Student.speak();
    }
}

  

运行结果:

静态代码块执行了!!
国籍:中国

  

理解到这,你再看看下面的分析图,应该还会有所收获

最后再跟大家分享一句话:

          一个人若想改变自己的命运,最重要的是要改变自己,改变心态,改变环境,这样命运也会随之改变

          读完此篇,如若对你有用,记得推荐,如若有误,欢迎指正!

          此篇为本人原创,转载请说明出处

原文地址:https://www.cnblogs.com/zyx110/p/10661545.html

时间: 2024-08-30 09:43:18

彻底填平Static坑(细节决定成败)的相关文章

atitit.细节决定成败的适合情形与缺点

1. 在理论界有两种观点:一种是“细节决定成败”,另一种是“战略决定成败”.1 1.1. 格局决定成败,方向决定成败 战略决定成败”1 1.2.   战略用的是望远镜,细节用的是显微镜.1 2. 只有战略正确,细节才会有意义.2 2.1. 只见树木,不见森林2 2.2. 对于一艘驶错了方向的航船来说,任何来风都是逆风,2 2.3. 南辕北辙的故事2 2.4. 大失误是战略,小失误是细节,战略错了回天无力,细节错了还有改进的余地. 2 2.5.      细节主义会像鸦片一样麻痹整个企业上上下下的

细节决定成败-mysql中的时间存储(datetime,timestamp,int)

在mysql中存储时间,我们可以用datetime 格式,timestamp格式,也可以用int格式.那么我们设计的时候该如何考虑呢? 首先,我觉得应该明白这几个格式究竟是如何的,然后看看他们的区别,这样我们才能思考何时使用正确的格式. DATETIME格式,默认是"YYYY-MM-DD HH:MM:SS",这19个字符表示的,从1000-01-01 00:00:00-9999-12-31 23:59:59 . TIMESTAMP格式也是'YYYY-MM-DD HH:MM:SS'这样的

记一次AngularJs 路由 $stateChangeStart不起作用(细节决定成败)

var app= angular .module('app', [ 'ngAnimate', 'ngCookies', 'ngResource', 'ngSanitize', 'ngTouch', 'ui.router', 'ui.bootstrap', 'datatablesDirectives', 'ngTable', 'ncy-angular-breadcrumb', 'ngFileUpload', 'MessageCenterModule', 'angular-loading-bar',

细节决定成败--记初学Power Query之分组汇总问题解决

在今天用手头资料联系PQ时,出现含税金额项完全是数字格式的,分组汇总求和提示有错误值,错误提示:DataFormat.Error.无法转换为Number.详细信息q.各种百度居然搜不到类似PQ的解决方法.碰巧加入曾老师的"Excel Power Query交流群"受到启发,居然是添加条件列之前的那一列的格式没统一导致汇总依据列的连贯错误.还好最后测试解决.强烈建议以后的各位PQ处理数据前先确认各列数据的属性,再进行相关的运算汇总. 原文地址:https://blog.51cto.com

注册、起名、选头像,也许起步就错了——自媒体有坑,得绕①

世上本来就有坑,掉进去的人多了,也就发现了坑.前方有坑,大家绕行.这里是第1期<自媒体有坑,得绕>,咱们先来个起手式,从注册用户开始讲起. 或许你会说了,注册自媒体,这种事还要教吗?没注册过,也有微信.邮箱,那样不是3分钟搞定.实在是注册的不太满意了,咱随后就改还不得了. 咱们先举个例子.比如我要去注册一个微信公众号或者微博号,又或者今日头条号,为了辨识度更高,肯定我所有的自媒体平台账号会选择同一个名字,选什么呢? 对,注意听讲的小伙伴可能记住了我的真名,张书乐.所以一般来说,就会严格按照有关

初涉node.js做微信测试公众号一路填坑顺便发现个有趣的其他漏洞

[微信测试公众号] 半年前耍着玩搭起来的“微信简历”,是LAMP版的,很皮毛. 微信的官方文档在这 http://mp.weixin.qq.com/wiki/index.php 1.获取access token 2.自定义菜单创建,直接在调试工具上做了 http://mp.weixin.qq.com/debug 3.接入指南(接入自己的网站) 4.接收微信消息,判断消息类型,判断消息关键字(比如来自哪个按钮),响应消息 这里有个小坑,不同类型的消息数据结构略有不同,判空最好做细致点. [V2.0

入门训练 A+B问题

------------------------------------------------------------------------------------------------------------------------- 本题主要是讲蓝桥杯的注意事项的,细节决定成败 ---------------------------------------------------------------------------------------------------------

Android性能优化典例(一)

在Android开发过程中,很多时候往往因为代码的不规范.api使用不恰当.控件的使用场景考虑不全面和用户不恰当的操作等都能引发一系列性能问题的,下面就是我目前整理的一些Android开发过程中需要注意的细节,正所谓一颗老鼠屎可以坏了一锅粥,细节决定成败 下面就是一些性能优化的方案: 1.Android中别使用enum,使用static final 代替枚举enum,因为使用enum比使用static需要消耗更多的内存空间 2.Toast中使用getApplicationContext()来代替

ssm+freemark集成shiro

1.导入的jar包 <!-- shiro start --> <!-- freemarker + shiro(标签) begin --> <dependency> <groupId>net.mingsoft</groupId> <artifactId>shiro-freemarker-tags</artifactId> <version>0.1</version> </dependency&g