java中的clone

TestCloneBean b = ne TestCloneBean();
        b.setIntegers(Lists.newArrayList(1));
        String s = JsonUtils.getObjectMapperInstance().writeValueAsString(b);
        TestCloneBean a = JsonUtils.getObjectMapperInstance().readValue(s, TestCloneBean.class);

1.先说一句

不去覆盖clone方法,不去调用clone方法,除非真的有必要。

2.java中clone两个概念

浅克隆 copy的是引用

深克隆 copy的是实例,开辟新的堆空间

java中的clone方法实现的是浅克隆,一个类可被浅克隆需实现Cloneable(此接口只是说明此类允许clone,它改变的是超类中受保护的clone方法的行为),如effective java中的第11条所说这是接口的一种极端非典型的用法,不值得效仿。

3.浅克隆

浅克隆看上去只要实现了Cloneable接口 且@Override clone方法为public后就可以了,但是实际应用了,确定你要的是浅clone么?

若是一个对象没有实现Cloneable接口,也可以很简单的使用反射实现对象的浅复制:

非严谨的code如下:

public static <T> T simpleClone(T obj) throws IllegalAccessException, InstantiationException {
        Class<T> c = (Class<T>) obj.getClass();
        T cloneC = c.newInstance();
        Field[] fields = c.getDeclaredFields(); if (fields != null && fields.length > 0) { for (Field field : field敏感词ield.setAccessible(true);
                Object value = field.get(obj);
                field.set(cloneC, value);
            }
        } return cloneC;
    }

当然有很多工具类了:比如,springBeanUtils.copyProperties, apacheBeanUtils.copyProperties,cglib或者spring-cglibBeanCopier

4.深克隆

既然实际应用中更希望使用的是深克隆,那么如何实现呢

1> bean 自己实现Cloneable接口,靠谱的实现clone方法

非严谨code如下:

public class TestCloneBean implements Cloneable { private List<Integer> integers; public List<Integer> getIntegers() { return integers;
    } public void setIntegers(List<Integer> integers) { this.integers = integers;
    }
 
    @Override public TestCloneBean clone() { try {
            TestCloneBean t = (TestCloneBean) super.clone();
            t.setIntegers(Lists.<Integer> newArrayList()); if (CollectionUtils.isNotEmpty(integer敏感词or (Integer i : integers) {
                    t.getIntegers().add(i);
                }
            } return t;
 
        } catch (CloneNotSupportedException e) { throw new RuntimeException(e);
        }
    }
 
    @Override public String toString() { return ToStringBuilder.reflectionToString(this);
    }
}

2>第一种方法你会这么做么?不会。那么只能另外一种方式:序列化啊!

非严谨code如下:

public class JsonUtils { private static ObjectMapper objectMapper = new ObjectMapper(); static {
        objectMapper.configure(JsonParser.Feature.ALLOW_COMMENTS, true);
        objectMapper.configure(JsonParser.Feature.ALLOW_UNQUOTED_FIELD_NAMES, true);
        objectMapper.configure(JsonParser.Feature.ALLOW_SINGLE_QUOTES, true);
        objectMapper.configure(JsonParser.Feature.ALLOW_UNQUOTED_CONTROL_CHARS, true);
        objectMapper.configure(JsonParser.Feature.INTERN_FIELD_NAMES, true);
全部评论

相关推荐

刚刷到字节跳动官方发的消息,确实被这波阵仗吓了一跳。在大家还在纠结今年行情是不是又“寒冬”的时候,字节直接甩出了史上规模最大的转正实习计划——ByteIntern。咱们直接看几个最硬的数,别被花里胡哨的宣传词绕晕了。首先是“量大”。全球招7000多人是什么概念?这几乎是把很多中型互联网公司的总人数都给招进来了。最关键的是,这次的资源分配非常精准:研发岗给了4800多个Offer,占比直接超过六成。说白了,字节今年还是要死磕技术,尤其是产品和AI领域,这对于咱们写代码的同学来说,绝对是今年最厚的一块肥肉。其次是大家最关心的“转正率”。官方直接白纸黑字写了:整体转正率超过50%。这意味着只要你进去了,不划水、正常干,每两个人里就有一个能直接拿校招Offer。对于2027届(2026年9月到2027年8月毕业)的同学来说,这不仅是实习,这简直就是通往大厂的快捷通道。不过,我也得泼盆冷水。坑位多,不代表门槛低。字节的实习面试出了名的爱考算法和工程实操,尤其是今年重点倾斜AI方向,如果你简历里有和AI相关的项目,优势还是有的。而且,转正率50%也意味着剩下那50%的人是陪跑的,进去之后的考核压力肯定不小。一句话总结:&nbsp;27届的兄弟们,别犹豫了。今年字节这是铁了心要抢提前批的人才,现在投递就是占坑。与其等到明年秋招去千军万马挤独木桥,不如现在进去先占个工位,把转正名额攥在手里。
喵_coding:别逗了 50%转正率 仔细想想 就是转正与不转正
字节7000实习来了,你...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务