zoukankan      html  css  js  c++  java
  • [转]java中的Static class

    转自:http://www.cnblogs.com/kissazi2/p/3971065.html

    Java中的类可以是static吗?答案是可以。在java中我们可以有静态实例变量、静态方法、静态块。类也可以是静态的。

         java允许我们在一个类里面定义静态类。比如内部类(nested class)。把nested class封闭起来的类叫外部类。在java中,我们不能用static修饰顶级类(top level class)。只有内部类可以为static。

         静态内部类和非静态内部类之间到底有什么不同呢?下面是两者间主要的不同。

        (1)内部静态类不需要有指向外部类的引用。但非静态内部类需要持有对外部类的引用。

        (2)非静态内部类能够访问外部类的静态和非静态成员。静态类不能访问外部类的非静态成员。他只能访问外部类的静态成员。

        (3)一个非静态内部类不能脱离外部类实体被创建,一个非静态内部类可以访问外部类的数据和方法,因为他就在外部类里面。

    基于上面的讨论,我们可以通过这些特性让编程更简单、有效。

    /* 下面程序演示如何在java中创建静态内部类和非静态内部类 */
    class OuterClass{
       private static String msg = "GeeksForGeeks";
    
       // 静态内部类
       public static class NestedStaticClass{
    
           // 静态内部类只能访问外部类的静态成员
           public void printMessage() {
    
             // 试着将msg改成非静态的,这将导致编译错误 
             System.out.println("Message from nested static class: " + msg); 
           }
        }
    
        // 非静态内部类
        public class InnerClass{
    
           // 不管是静态方法还是非静态方法都可以在非静态内部类中访问
           public void display(){
              System.out.println("Message from non-static nested class: "+ msg);
           }
        }
    } 
    
    class Main
    {
        // 怎么创建静态内部类和非静态内部类的实例
        public static void main(String args[]){
    
           // 创建静态内部类的实例
           OuterClass.NestedStaticClass printer = new OuterClass.NestedStaticClass();
    
           // 创建静态内部类的非静态方法
           printer.printMessage();   
    
           // 为了创建非静态内部类,我们需要外部类的实例
           OuterClass outer = new OuterClass();        
           OuterClass.InnerClass inner  = outer.new InnerClass();
    
           // 调用非静态内部类的非静态方法
           inner.display();
    
           // 我们也可以结合以上步骤,一步创建的内部类实例
           OuterClass.InnerClass innerObject = new OuterClass().new InnerClass();
    
           // 同样我们现在可以调用内部类方法
           innerObject.display();
        }
    }
  • 相关阅读:
    HDU 1102 Constructing Roads
    HDU 1285 确定比赛名次。
    最小生成树 HDU 各种畅通工程的题,prim和kru的模板题
    HDU Jungle Roads 1301 最小生成树、
    并查集小结(转)
    HDU hdu 2094 产生冠军 拓扑排序 判定环
    模运算(转)
    拓扑排序(主要是确定环和加法) HDU 2647 Reward
    HDU 1372 Knight Moves 简单BFS
    用计算机模型浅析人与人之间沟通方式 (一)如何谈话
  • 原文地址:https://www.cnblogs.com/tanlon/p/4125973.html
Copyright © 2011-2022 走看看