zoukankan      html  css  js  c++  java
  • JAVA获取对象的四种方式

    1.使用new创建对象

    2.通过反射的方式

    3.通过clone的方式

    4.通过反序列化的方式

    一.使用new创建对象

      使用new会增加耦合度,所以要尽量减少使用new的频率。并且new是使用强引用方式来创建对象的。

    Hello hello = new Hello();

    二.使用反射的方式创建对象

          1.使用Class类的newInstance方法来创建对象

    Class class = Class.forname("com.heyjia.test.Hello");
    Hello hello = (Hello)class.newInstance();

          2.使用Constructor类的newInstance方法来创建兑现

        Class class = Class.forName("com.heyjia.test.Hello");
        Constructor constructor = class.getConstructor();
        Hello hello = (Hello)constructor.newInstance();

    三.使用clone的方式创建对象

       前提:需要有一个对象,使用该对象父类的clone方法可以创建一个内存大小跟它一样大的对象

    Hello hello1 = new Hello();
    Hello hello2 = (Hello)hello1.clone();

    四.使用反序列化的方式创建对象

       在通过实现序列化serializable接口将对象存到硬盘中,通过反序列化可以获取改对象

    public class Serialize
    {
        public static void main(String[] args)
        {
            Hello h = new Hello();
    
            //准备一个文件用于存储该对象的信息
            File f = new File("hello.obj");
    
            try(FileOutputStream fos = new FileOutputStream(f);
                ObjectOutputStream oos = new ObjectOutputStream(fos);
                FileInputStream fis = new FileInputStream(f);
                ObjectInputStream ois = new ObjectInputStream(fis)
                )
            {
                //序列化对象,写入到磁盘中
                oos.writeObject(h);
                //反序列化对象
                Hello newHello = (Hello)ois.readObject();
    
                //测试方法
                newHello.sayWorld();
            }
            catch (FileNotFoundException e)
            {
                e.printStackTrace();
            }
            catch (IOException e)
            {
                e.printStackTrace();
            }
            catch (ClassNotFoundException e)
            {
                e.printStackTrace();
            }
        }
    }
  • 相关阅读:
    针对图片性能优化的总结
    activityGroup源码分析
    针对BaseAdapter的扩展
    ADB命令介绍
    一个对内存分析的文章。 非常棒。
    hdu 1285 确定比赛名次(很典型的拓扑排序)
    经典排序之归并排序
    hdu 1166 敌兵布阵 (树状数组)
    hdu 3518 Boring counting (后缀数组)
    hdu 3584 Cube(树状数组)
  • 原文地址:https://www.cnblogs.com/heyjia/p/11319942.html
Copyright © 2011-2022 走看看