Java执行流程 – 重写方法首先比构造函数执行

前端之家收集整理的这篇文章主要介绍了Java执行流程 – 重写方法首先比构造函数执行前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有同样的 java文件中的以下代码.
import javax.swing.SwingUtilities;
import java.io.File;

public class MainClass2{
   public static void main(String[] args){
       SwingUtilities.invokeLater(new Runnable(){
             public void run() {
                 javax.swing.JFileChooser jfc = new MyFileChooser();
                     File file = jfc.getSelectedFile();
             }

      });
   }
}

class MyFileChooser extends javax.swing.JFileChooser{
    public MyFileChooser(){
        System.out.println("constructor call");
    }
    @Override
    public java.io.File getSelectedFile(){
        System.out.println("call to getSelectedFile");
        return null;
    }
}

当我运行它,输出给我

调用getSelectedFile

构造函数调用

调用getSelectedFile

不应该输出

构造函数调用

调用getSelectedFile

我使用的是Java 5.

解决方法

MyFileChooser的构造函数相当于:
public MyFileChooser() {
    super(); // ***
    System.out.println("constructor call");
}

getSelectedFile()的第一个调用是由MyFileChooser的基类构造函数创建的,该构造函数在System.out.println(“构造函数调用”)之前被标记为***的位置隐式调用.

这是堆栈跟踪:

MyFileChooser.getSelectedFile() line: 16    
AquaFileChooserUI.installComponents(JFileChooser) line: 1436    
AquaFileChooserUI.installUI(JComponent) line: 122   
MyFileChooser(JComponent).setUI(ComponentUI) line: 670  
MyFileChooser(JFileChooser).updateUI() line: 1798   
MyFileChooser(JFileChooser).setup(FileSystemView) line: 360 
MyFileChooser(JFileChooser).<init>(File,FileSystemView) line: 333  
MyFileChooser(JFileChooser).<init>() line: 286  
MyFileChooser.<init>() line: 11
原文链接:https://www.f2er.com/java/125166.html

猜你在找的Java相关文章