zoukankan      html  css  js  c++  java
  • 静态成员方法与静态成员变量【Java版】

    一、类的定义

    package com.StaticKeyword;

    public class Staff {
    private static String country="China";
    private int id;
    private String name;

    static void setCountryAndPrint(String _country)
    {
    country=_country;// 由于country不是专属某个特定的类,因此不能以this.country=country;的形式访问
    System.out.println("The new country is : "+country);
    }

    Staff(int id,String name)
    {
    this.id=id;
    this.name=name;
    }

    void printCountry()
    {
    System.out.println("My country is : "+country);
    }
    }



    二、静态成员函数

    a)只可访问静态成员变量

        public static void main(String[] args) {
    /*虽然也可以用staff_A.setCountryAndPrint("Japan")的形式访问,但是为了
    * 体现静态方法的运行与任何具体对象都无关,故提倡用“类名.静态方法”的形式访问
    */
    Staff.setCountryAndPrint("Japan");
    }

    运行结果:

    b)无法访问非静态成员变量

    如果修改静态成员函数,使其访问非静态成员变量

       static void  setCountryAndPrint(String _country)
    {
    name="testName";// 实际上并不能访问非静态成员变量
    country=_country;// 由于country不是专属某个特定的类,因此不能以this.country=country;的形式访问
    System.out.println("The new country is : "+country);
    }

    运行结果:

    说明:1)由于在调用静态成员方法时,并不会将对象的引用传递过去,因此不能访问对象的非静态成员变量

    静态成员方法访问方式:“类名.静态方法”

             2)而且由于静态成员方法通常以“类名.静态方法”的形式访问,如果可以访问“非静态成员变量”,那么

    编译器也就无法确定:访问的“非静态成员变量”是属于哪个对象,在内存中的位置,甚至根本就还没有对象

    为避免这种情况的出现,编译器一定不会允许“静态成员方法”访问“非静态成员变量”
                                                                                                                                                                                      

    三、静态成员变量

    静态成员变量:   位于“数据区”,无论多少个对象该变量在内存中都只有一份

    非静态成员变量:位于“堆空间”,每new一个对象创建一份,因此有多少个对象该变量在内存就有多少份

    a)静态成员方法访问

       显然可以访问,同【二(a)】,略

    b)非静态成员函数访问

        public static void main(String[] args) {
    // TODO Auto-generated method stub
    Staff staff_A=new Staff(1,"Evens");
    staff_A.printCountry();

    }

    运行结果:



  • 相关阅读:
    Flink 电商实时数仓(二十三):ClickHouse基础(二)使用基础(2)ClickHouse 的安装(centos)
    Flink 电商实时数仓(二十二):ClickHouse基础(一)使用基础(1)ClickHouse 入门
    Flink 源码(二十六):Flink 内存管理(二)内存数据结构 、管理器
    Flink 源码(二十五):Flink 内存管理(一)内存模型与内存数据结构
    Flink 源码(二十四):Flink 任务调度机制(五)调度
    460. LFU Cache (solution 1)
    785. Is Graph Bipartite? (是否二分图)
    1318. Minimum Flips to Make a OR b Equal to c
    211. Add and Search Word
    188. Best Time to Buy and Sell Stock IV
  • 原文地址:https://www.cnblogs.com/edisonfeng/p/2219599.html
Copyright © 2011-2022 走看看