• 成员变量和局部变量的区别


    成员变量与局部变量的区别

    1、在类中的位置不同

    成员变量:在类中方法外面

    局部变量:在方法或者代码块中,或者方法的声明上(即在参数列表中)

    2、在内存中的位置不同,可以看看Java程序内存的简单分析

    成员变量:在堆中(方法区中的静态区)

    局部变量:在栈中

    3、生命周期不同

    成员变量:随着对象的创建而存在,随着对象的消失而消失

    局部变量:随着方法的调用或者代码块的执行而存在,随着方法的调用完毕或者代码块的执行完毕而消失

    4、初始值

    成员变量:有默认初始值

    局部变量:没有默认初始值,使用之前需要赋值,否则编译器会报错(The local variable xxx may not have been initialized)

    复制代码
     1 package demo;
     2 
     3 public class VariableDemo {
     4     String name = "成员变量";
     5 
     6     public static void main(String[] args) {
     7         new VariableDemo().show();
     8     }
     9 
    10     public void show() {
    11         String name = "局部变量";
    12         System.out.println(name);
    13     }
    14 }
    复制代码

    输出结果:局部变量
    我们看到输出的是show方法中定义的name变量,在使用变量时遵循的原则是就近原则,那么如何访问到成员变量name呢,Java中提供了this(表示调用对象本身)这个关键字用于访问成员变量。

    复制代码
     1 package demo;
     2 
     3 public class VariableDemo {
     4     String name = "成员变量";
     5 
     6     public static void main(String[] args) {
     7         new VariableDemo().show();
     8     }
     9 
    10     public void show() {
    11         String name = "局部变量";
    12         System.out.println(this.name);
    13     }
    14 }
    复制代码

    输出结果:成员变量

    转自:https://www.cnblogs.com/huangminwen/p/5935130.html

  • 相关阅读:
    Spark概述及集群部署
    Scala编程实战
    Scala的高级特性
    Scala基础
    MapReduce优化参数
    HDFS安全模式
    HDFS元数据管理机制
    Hadoop Federation联邦
    Hadoop HA集群的搭建
    Hadoop High Availability高可用
  • 原文地址:https://www.cnblogs.com/forever29/p/12844125.html
Copyright © 2020-2023  润新知