Android面试:offer拿到手软;BAT大厂面试总结

110 阅读2分钟

第一次观看我文章的朋友,可以关注、点赞、转发一下,每天分享各种干货技术和程序猿趣事

前言

随着移动终端的快速发展,Android开发人员也越来越多,Android开发市场也进入了一个饱和的状态,Android开发人员也面临着难找一份好工作的处境。

而找工作的第一关就是面试,一个好的面试往往能很好的提高你的入职几率,下面我总结了一些本人在一些大厂的面试总结,希望的观看的小伙伴有所帮助。

View面试专题

  1. View的滑动方式
  2. View的事件分发机制
  3. View的加载流程
  4. View的measure layout 和 draw流程
  5. 自定义view需要注意的几点
  6. ACTION_DOWN没有拦截,ACTION_MOVE ACTION_UP还会拦截吗

多线程专题

  1. 什么是线程
  2. 线程的状态
  3. 线程的创建
  4. 线程中断
  5. Thread为什么不能用stop方法停止线程
  6. 重入锁与条件对象,同步方法和同步代码块
  7. volatile关键字
  8. java内存模型
  9. 原子性 可见性 有序性
  10. 线程池ThreadPoolExecutor
  11. 线程池的种类
  12. 线程同步机制与原理,举例说明
  13. arrayList与linkedList的读写时间复杂度
  14. 为什么HashMap线程不安全(hash碰撞与扩容导致)
  15. 进程线程的区别
  16. Binder的内存拷贝过程
  17. 传统IPC机制的通信原理(2次内存拷贝)
  18. Java内存模型(记住堆栈是内存分区,不是模型)
  19. 类的加载过程
  20. 什么情况下会触发类的初始化
  21. 双亲委托模式
  22. 双亲委托模式的好处
  23. 死锁的产生条件,如何避免死锁
  24. App启动流程
  25. Android单线程模型
  26. RecyclerView在很多方面能取代ListView,Google为什么没把ListView划上一条过时的横线?
  27. HashMap如何保证元素均匀分布

数据结构面试专题

  1. 常用数据结构简介
  2. 并发集合了解哪些?
  3. 列举java的集合以及集合之间的继承关系
  4. 容器类介绍以及之间的区别
  5. List,Set,Map的区别
  6. HashMap的实现原理
  7. HashMap如何put数据(从HashMap源码角度讲解)?
  8. HashMap如何get数据?
  9. 当两个对象的hashcode相同,即发生碰撞时,HashMap如何处理
  10. 如果两个键的hashcode相同,如何获取值对象?
  11. hashMap如何扩容
  12. ConcurrentHashMap的实现原理
  13. ArrayMap和HashMap的对比
  14. HashTable实现原理
  15. HashMap和HashTable的区别
  16. HashMap与HashSet的区别
  17. HashSet与HashMap怎么判断集合元素重复?
  18. 集合Set实现Hash怎么防止碰撞
  19. ArrayList和LinkedList的区别,以及应用场景