面试小结

腾讯校招面试小结


JAVA部分

Q: ArrayList是怎么实现的?
A: ArrayList实际是实现List接口,底层用数组来保存元素。其基本操作是对数组的操作。基本添加删除操作与数组没有区别,只是在添加到大于临时保存元素的数组时,要对保存元素的数组进行扩容。此外,对于插入操作,将index位置后的所有元素均往后移一位,而后将数据存入。
Q: JAVA的泛型与CPP的模板有什么区别?
A: 泛型是JDK1.5引入的新特性,其与CPP的区别如下:
首先,JAVA中的泛型不能接受基本类型作为类型参数,即List<int>是错误的写法,应该写成List<Integer>。
其次在 C++ 模板中,编译器使用提供的类型参数来扩充模板,因此,为 List<A> 生成的 C++ 代码不同于为 Lis<B> 生成的代码,List<A> 和 List<B> 实际上是两个不同的类。而 Java 中的泛型则以不同的方式实现,编译器仅仅对这些类型参数进行擦除和替换。类型 ArrayList<Integer> 和 ArrayList<String>的对象共享相同的类,并且只存在一个 ArrayList类。
此外,在编写代码时,CPP中可以直接调用模板类一个具体的方法,只要实例化类中存在此方法则不会报错,而JAVA中不能直接调用泛型的具体方法。
Q: 泛型的实现原理?
A: 泛型的实现原理是类型擦除(type erasure)。JAVA是伪

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值