当前位置: 代码迷 >> J2SE >> 静态内部类的有关问题
  详细解决方案

静态内部类的有关问题

热度:32   发布时间:2016-04-24 00:38:02.0
静态内部类的问题
静态内部类可以被实例化么?是不是和其他普通静态类不同?(按道理说,静态类是不能够被实力化的)
静态内部类如果可以被实例化,他是怎么被实例化的?可以多次创建静态内部类的实力么?
在代码中,TreeInfo 被创建了若干次,如何解释?TreeInfo result = new TreeInfo()
Java code
//: net/mindview/util/Directory.java// Produce a sequence of File objects that match a// regular expression in either a local directory,// or by walking a directory tree.package net.mindview.util;import java.util.regex.*;import java.io.*;import java.util.*;public final class Directory {  public static File[]  local(File dir, final String regex) {    return dir.listFiles(new FilenameFilter() {      private Pattern pattern = Pattern.compile(regex);      public boolean accept(File dir, String name) {        return pattern.matcher(          new File(name).getName()).matches();      }    });  }  public static File[]  local(String path, final String regex) { // Overloaded    return local(new File(path), regex);  }  // A two-tuple for returning a pair of objects:  public static class TreeInfo implements Iterable<File> {    public List<File> files = new ArrayList<File>();    public List<File> dirs = new ArrayList<File>();    // The default iterable element is the file list:    public Iterator<File> iterator() {      return files.iterator();    }    void addAll(TreeInfo other) {      files.addAll(other.files);      dirs.addAll(other.dirs);    }    public String toString() {      return "dirs: " + PPrint.pformat(dirs) +        "\n\nfiles: " + PPrint.pformat(files);    }  }  public static TreeInfo  walk(String start, String regex) { // Begin recursion    return recurseDirs(new File(start), regex);  }  public static TreeInfo  walk(File start, String regex) { // Overloaded    return recurseDirs(start, regex);  }  public static TreeInfo walk(File start) { // Everything    return recurseDirs(start, ".*");  }  public static TreeInfo walk(String start) {    return recurseDirs(new File(start), ".*");  }  static TreeInfo recurseDirs(File startDir, String regex){    TreeInfo result = new TreeInfo();    for(File item : startDir.listFiles()) {      if(item.isDirectory()) {        result.dirs.add(item);        result.addAll(recurseDirs(item, regex));      } else // Regular file        if(item.getName().matches(regex))          result.files.add(item);    }    return result;  }  // Simple validation test:  public static void main(String[] args) {    if(args.length == 0)      System.out.println(walk("."));    else      for(String arg : args)       System.out.println(walk(arg));  }} ///:~


------解决方案--------------------
兄弟,你见过静态类吗?如果见过,那么你所说的静态类是何时加载初始化的?
------解决方案--------------------
能不能实例化你试一下不就知道了么,想那么深其实一点根基都没有,一边试验,一边猜测才最有逻辑的。

Java code
public class Test {    public static void main(String[] args) {        new Inner();    }    static class Inner {        Inner() {            System.out.println("你猜我是谁");        }    }}
  相关解决方案