如何在Java中从构造函数反序列化对象?

如何在Java中从构造函数反序列化对象?,java,object,deserialization,Java,Object,Deserialization,我正在尝试做一些我以前从未做过的时髦的事情 所以我想做的是: 我通过执行以下操作创建一个对象 Player playerVar = new Player(1234); Players构造函数随后将查找名为1234的播放器,如果它存在,它将反序列化并将加载的对象存储在'playerVar'下,如果不存在,它将只执行并给出一个'blank'播放器对象 我不确定是否有可能使当前对象成为同一对象的另一个实例,所以我在这里发布 这基本上就是我要做的 this = deserielizedObject

我正在尝试做一些我以前从未做过的时髦的事情

所以我想做的是: 我通过执行以下操作创建一个对象

Player playerVar = new Player(1234);
Players构造函数随后将查找名为1234的播放器
,如果它存在,它将反序列化并将加载的对象存储在
'playerVar
'
下,如果不存在,它将只执行并给出一个
'blank'播放器对象

我不确定是否有可能使当前对象成为同一对象的另一个实例,所以我在这里发布

这基本上就是我要做的

this = deserielizedObject
我知道这一切都可以通过加载对象,然后手动设置所有必要的变量来完成,但这并不理想。如何从对象内部用另一个对象实例“替换”对象

这是我目前拥有的代码

player.java

    public class Player implements java.io.Serializable
    {
        Player(String GUID) // when loading a new player
        {
            Player player = loadPlayer(GUID);
            //i want to set this to player
            // something like     this = player     If you know what i mean....
        }
        Player()//when creating a new player
        {

        }

        private Player loadPlayer(String GUID)
        {
            File f = new File("data/players/"+GUID+".ser");
            if(!f.exists())
            {
                Player player = new Player();
                return player;
            }
                Player player = null;
            try
            {
                FileInputStream fileIn = new FileInputStream("data/players/"+GUID+".ser");
                ObjectInputStream in = new ObjectInputStream(fileIn);
                player = (Player) in.readObject();
                in.close();
                fileIn.close();
            }
            catch(IOException i)
            {
                i.printStackTrace();
                return null;
            }
            catch(ClassNotFoundException c)
            {
                System.out.println("Cant find Player Class!");
                c.printStackTrace();
                return null;
            }
            return player;
        }

        private int guid;
        private String name;
        private int bankMoney;
        .......
        ...
        .


    }

您可以使用工厂类/方法。在您的情况下,最简单的方法可能是将
loadPlayer
作为公共静态方法

    public static Player loadPlayer(String GUID)
    {
        ...
        return player;
    }
然后:


你所描述的是不可能的。但是,您可以创建一个(静态)工厂方法,而不是构造函数,后者可以反序列化或创建一个新实例。

您不能为该
赋值,这是不可能的。为什么不直接调用
loadPlayer
方法:

Player player = Player.loadPlayer(GUID); //having loadPlayer as public static

在java中,您不能为
这个
赋值…哦,真的。。。。这么简单。。。。抱歉问这么简单的问题浪费了时间!:)
Player player = Player.loadPlayer(GUID); //having loadPlayer as public static