要不要面外包?

可以面试,但我不推荐入职外包

去外包的前提

  • 学历不行(专科及以下,自考本科)

  • 外包 offer 比自研 offer 好很多(极少数情况)

  • 没有Android开发经验但年纪又偏大(转行)

  • 技术、业务能力实在堪忧

个人认为如果没有存在上述四种情况的话,不应该去外包

跳槽必备哪些技能和知识点?

一、计算机网络部分

1.网页中输入url,到渲染整个界面的整个过程,以及中间用了什么协议?

1)过程分析:主要分为三步

DNS解析。用户输入url后,需要通过DNS解析找到域名对应的ip地址,有了ip地址才能找到服务器端。首先会查找浏览器缓存,是否有对应的dns记录。再继续按照操作系统缓存—路由缓存—isp的dns服务器—根服务器的顺序进行DNS解析,直到找到对应的ip地址。

客户端(浏览器)和服务器交互。浏览器根据解析到的ip地址和端口号发起HTTP请求,请求到达传输层,这里也就是TCP层,开始三次握手建立连接。服务器收到请求后,发送相应报文给客户端(浏览器),客户端收到相应报文并进行解析,得到html页面数据,包括html,js,css等。

客户端(浏览器)解析html数据,构建DOM树,再构造呈现树(render树),最终绘制到浏览器页面上。

2)其中涉及到TCP/IP协议簇,包括DNS,TCP,IP,HTTP协议等等。

2.具体介绍下TCP/IP

TCP/IP一般指的是TCP/IP协议簇,主要包括了多个不同网络间实现信息传输涉及到的各种协议

主要包括以下几层:

应用层:主要提供数据和服务。比如HTTP,FTP,DNS等

传输层:负责数据的组装,分块。比如TCP,UDP等

网络层:负责告诉通信的目的地,比如IP等

数据链路层:负责连接网络的硬件部分,比如以太网,WIFI等

TCP的三次握手和四次挥手,为什么不是两次握手?为什么挥手多一次呢?

客户端简称A,服务器端简称B

1)TCP建立连接需要三次握手

A向B表示想跟B进行连接(A发送syn包,A进入SYN_SENT状态)

B收到消息,表示我也准备好和你连接了(B收到syn包,需要确认syn包,并且自己也发送一个syn包,即发送了syn+ack包,B进入SYN_RECV状态)

A收到消息,并告诉B表示我收到你也准备连接的信号了(A收到syn+ack包,向服务器发送确认包ack,AB进入established状态)开始连接。

2)TCP断开连接需要四次挥手

A向B表示想跟B断开连接(A发送fin,进入FIN_WAIT_1状态)

B收到消息,但是B消息没发送完,只能告诉A我收到

《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》

【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享

你的断开连接消息(B收到fin,发送ack,进入CLOSE_WAIT状态)

过一会,B数据发送完毕,告诉A,我可以跟你断开了(B发送fin,进入LAST_ACK状态)

A收到消息,告诉B,可以他断开(A收到fin,发送ack,B进入closed状态)

3)为什么挥手多一次

其实正常的断开和连接都是需要四次:

A发消息给B

B反馈给A表示正确收到消息

B发送消息给A

A反馈给B表示正确收到消息。

但是连接中,第二步和第三步是可以合并的,因为连接之前A和B是无联系的,所以没有其他情况需要处理。而断开的话,因为之前两端是正常连接状态,所以第二步的时候不能保证B之前的消息已经发送完毕,所以不能马上告诉A要断开的消息。这就是连接为什么可以少一步的原因。

4)为什么连接需要三次,而不是两次。

正常来说,我给你发消息,你告诉我能收到,不就代表我们之前通信是正常的吗?

简单回答就是,TCP是双向通信协议,如果两次握手,不能保证B发给A的消息正确到达。

TCP 协议为了实现可靠传输, 通信双方需要判断自己已经发送的数据包是否都被接收方收到, 如果没收到, 就需要重发。

3.TCP是怎么保证可靠传输的?

序列号和确认号。比如连接的一方发送一段80byte数据,会带上一个序列号,比如101。接收方收到数据,回复确认号181(180+1),这样下一次发送消息就会从181开始发送了。

所以握手过程中,比如A发送syn信号给B,初始序列号为120,那么B收到消息,回复ack消息,序列号为120+1。同时B发送syn信号给A,初始序列号为256,如果收不到A的回复消息,就会重发,否则丢失这个序列号,就无法正常完成后面的通信了。

这就是三次握手的原因。

4.TCP和UDP的区别?

TCP提供的是面向连接,可靠的字节流服务。即客户和服务器交换数据前,必须现在双方之间建立一个TCP连接(三次握手),之后才能传输数据。并且提供超时重发,丢弃重复数据,检验数据,流量控制等功能,保证数据能从一端传到另一端。

UDP 是一个简单的面向数据报的运输层协议。它不提供可靠性,只是把应用程序传给IP层的数据报发送出去,但是不能保证它们能到达目的地。由于UDP在传输数据报前不用再客户和服务器之间建立一个连接,且没有超时重发等机制,所以传输速度很快。

所以总结下来就是:

TCP 是面向连接的,UDP 是面向无连接的

TCP数据报头包括序列号,确认号,等等。相比之下UDP程序结构较简单。

TCP 是面向字节流的,UDP 是基于数据报的

TCP 保证数据正确性,UDP 可能丢包

TCP 保证数据顺序,UDP 不保证

可以看到TCP适用于稳定的应用场景,他会保证数据的正确性和顺序,所以一般的浏览网页,接口访问都使用的是TCP传输,所以才会有三次握手保证连接的稳定性。

而UDP是一种结构简单的协议,不会考虑丢包啊,建立连接等。优点在于数据传输很快,所以适用于直播,游戏等场景。

5.HTTP的几种请求方法具体介绍

常见的有四种:

GET 获取资源,没有body,幂等性

POST 增加或者修改资源,有body

PUT 修改资源,有body,幂等性

DELETE 删除资源,幂等性

HTTP请求和响应报文的格式,以及常用状态码

1)请求报文:

//请求行(包括method、path、HTTP版本)

GET /s HTTP/1.1

//Headers

Host: www.baidu.com

Content-Type: text/plain

//Body

搜索****

2)响应报文

//状态行 (包括HTTP版本、状态码,状态信息)

HTTP/1.1 200 OK

//Headers

Content-Type: application/json; charset=utf-8

//Body

[{“info”:“xixi”}]

3)常用状态码

主要分为五种类型:

1开头, 代表临时性消息,比如100(继续发送)

2开头, 代表请求成功,比如200(OK)

3开头, 代表重定向,比如304(内容无改变)

4开头, 代表客户端的一些错误,比如403(禁止访问)

5开头, 代表服务器的一些错误,比如500

6.请回答一个 TCP 连接上面能发多少个 HTTP 请求?

二、 数据结构与算法

1.1.1 常用的数据结构有哪些?

1.1.2 数组

(1).如何在一个1到100的整数数组中找到丢失的数字

相关知识点: [数组](javascript: void(0))[数学](javascript: void(0))[位运算](javascript: void(0))

相关知识点: [数组](javascript: void(0))[数学](javascript: void(0))[位运算](javascript: void(0))?

(2).如何在给定的整数数组中找到重复的数字? (小米)

(3).如何在未排序整数数组中找到最大值和最小值?(字节跳动)

(4).在Java中如何从给定数组中删除多重复制?

(5).大数相加(今日头条)

1.1.3 链表

(1).那查询第一个跟倒数第二个呢?(这就不一样了,第一个直接给了头结点,倒数第二个需要从倒数第一个开始查询,走两步) (腾讯)

(2).arrayList底层原理 (滴滴 字节跳动)

(3).如何在一次遍历中找到单个链表的中值?(中国平安)

(4).如何证明给定的链表是否包含循环?如何找到循环的头节点?(优酷)

(5).两个有交叉的单链表,求交叉点 (华为)

(6).如何得到单链表的长度? 360

(7).如何在不使用递归的情况下逆转单链表?(小米/美团)

(8).怎么判断链表有环? (滴滴)

1.1.4 队列&堆栈

(1).如何使用栈实现队列的功能?(广州荔枝FM)

(2).两个栈实现一个队列(蘑菇街)

(3).两个队列实现一个栈 (腾讯)

(4).对比一下队列和栈,以及它们底部实现 (腾讯)

1.1.5 二叉树

(1).如何在给定的二叉树中执行先序遍历?(百度)

(2).如何实现后序遍历算法?(百度)

(3).如何在给定数组中执行二分法搜索?(苏宁)

(4).已知前序遍历为{1,2,4,7,3,5,6,8},中序遍历为{4,7,2,1,5,3,8,6},它的二叉树是怎么样的?58

(5).输入两棵二叉树 A 和 B,判断 B 是不是 A 的子结构。 (爱奇艺)

(6).请实现两个函数,分别用来序列化二叉树和反序列化二叉树。 (YY)

(7).平衡二叉树和红黑树的区别?(字节跳动)

(8).什么是平衡二叉树,它有什么特征 (美团)

(9).B 树,B+树

1.1.6 HashMap

(1).HashMap的底层原理是什么?线程安全么? (百度 美团)

(2).HashMap中put是如何实现的? (滴滴)

(3).谈一下hashMap中什么时候需要进行扩容,扩容resize()又是如何实现的?

(4).什么是哈希碰撞?怎么解决? (滴滴 美团)

(5).HashMap和HashTable的区别 (小米)

(6).HashMap中什么时候需要进行扩容,扩容resize()是如何实现的? (滴滴)

(7).hashmap concurrenthashmap原理 (美团)

(8).arraylist和hashmap的区别,为什么取数快?(字节跳动)

1.1.7图

(1).旋转输出矩阵

(2).给定一个矩阵 int matrixA[m][n],每行每列都是增序的,实现一个算法去寻找矩阵中的某个元素 element. 搜狗

1.1.8排序算法有哪些?

(1).top-k排序(堆排序,位图法) (美团)

(2).冒泡排序的手写 (华捷艾米)

(3).堆排序算法的手写 (华捷艾米)

(4).椭圆形场地有两个赛道,可以同时提供两匹马比赛,两匹马比赛后,可以获知两匹马中跑的快的那匹马,但是没有计时工具。问题,如何最优的算法(比赛次数最少),获知10匹马中速度最快的三匹马 (阿里)

(5).输入一个整型无序数组,对堆排序的方法使得数组有序 (阿里)

(6).如何使用快速排序算法对整数数组进行排序? (CVTE)

1.1.9 查找算法

(1).有序数组的二分查找算法(百度)

1.1.10 串

(1).给定一个字符串,请你找出其中不含有重复字符的 最长子串的长度。 (字节跳动)

(2).给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。

1.1.11 请写出以下算法的时间复杂度

冒泡排序法 插入排序法 堆排序法 二叉树排序法

1.1.12 其他算法

(1).常用的对称加密算法,有什么同? (字节跳动)

(2).如何在无序(有负数)的数组中查找是否存在和为target的两个数组合,twoSum();(字节)

数据结构与算法题解析在开源项目:https://github.com/Android-Alvin/Android-LearningNotes 中已收录,里面包含不同方向的自学编程路线、面试题集合/面经、及系列技术文章等,资源持续更新中…

三、Java面试题

  1. 容器(HashMap、HashSet、LinkedList、ArrayList、数组等)

需要了解其实现原理,还要灵活运用,如:自己实现 LinkedList、两个栈实现一个队列,数组实现栈,队列实现栈等。

HashMap、HashTable 和 CurrentHashMap 的核心区别(并发),其次内部数据结构的实现、扩容、存取操作,再深一点 哈希碰撞,哈希计算,哈希映射,为什么是头插法,扩容为什么是 2 的幂次等。

参考链接

JAVA容器-自问自答学HashMap

什么是HashMap?

从源码角度认识ArrayList,LinkedList与HashMap

  1. 内存模型

参考链接

理解Java内存模型

你了解Java内存模型么(Java7、8、9内存模型的区别)

  1. 垃圾回收算法(JVM)

JVM 类加载机制、垃圾回收算法对比、Java 虚拟机结构

当你讲到分代回收算法的时候,不免会被追问到新生对象是怎么从年轻代到老年代的,以及可以作为 root 结点的对象有哪些两个问题。

1、谈谈对 JVM 的理解?

2、JVM 内存区域,开线程影响哪块区域内存?

3、对 Dalvik、ART 虚拟机有什么了解?对比?

ART 的机制与 Dalvik 不同。在Dalvik下,应用每次运行的时候,字节码都需要通过即时编译器(just in time ,JIT)转换为机器码,这会拖慢应用的运行效率,而在ART 环境中,应用在第一次安装的时候,字节码就会预先编译成机器码,极大的提高了程序的运行效率,同时减少了手机的耗电量,使其成为真正的本地应用。这个过程叫做预编译(AOT,Ahead-Of-Time)。这样的话,应用的启动(首次)和执行都会变得更加快速。

优点:

  • 系统性能的显著提升。

  • 应用启动更快、运行更快、体验更流畅、触感反馈更及时。

  • 更长的电池续航能力。

  • 支持更低的硬件。

缺点:

  • 机器码占用的存储空间更大,字节码变为机器码之后,可能会增加10%-20%(不过在应用包中,可执行的代码常常只是一部分。比如最新的 Google+ APK 是 28.3 MB,但是代码只有 6.9 MB。)

  • 应用的安装时间会变长。

4、垃圾回收机制和调用 System.gc()的区别?

参考链接

Java虚拟机(JVM)你只要看这一篇就够了!

  1. 类加载过程(需要多看看,重在理解,对于热修复和插件化比较重要)

  2. 反射

  3. 多线程和线程池

线程有哪些状态,哪些锁,各种锁的区别

并发编程:

synchronized 和 volatile 、ReentrantLock 、CAS 的区别

synchronized 修饰实例方法和修饰静态方法有啥不一样。

sleep 、wait、yield 的区别,wait 的线程如何唤醒它

  1. 设计模式(六大基本原则、项目中常用的设计模式、手写单例等)

1、生产者模式和消费者模式的区别?

2、单例模式双重加锁,为什么这样做?

3、知道的设计模式有哪些?

4、项目中常用的设计模式有哪些?

5、手写生产者、消费者模式。

6、手写观察者模式代码。

7、适配器模式、装饰者模式、外观模式的异同?

8、谈谈对 java 状态机的理解。

9、谈谈应用更新(灰度、强制更新、分区更新?)

  1. 断点续传

  2. Java 四大引用

强引用、软引用、弱引用、虚引用的区别以及使用场景。

强引用置为 null,会不会被回收?

稍微问的深一些的面试官会和内存泄漏检测原理以及垃圾回收糅杂在一起。

  1. Java 的泛型,<? super T> 和 <? extends T> 的区别

问到泛型、泛型擦除、通配符相关的东西

  1. final、finally、finalize 的区别

  2. 接口、抽象类的区别

四、Android面试题

1、Activity启动模式

2、Activity的启动过程

3 、进程通讯

4、Android Binder之应用层总结与分析

5.进程保活方法

6.从源码了解handler looper ,messageQueue思路 312

7.handler如何实现延时发消息postdelay() 315

8.Android中为什么主线程不会因为Looper.loop()里的死循环卡死? 320

9.RxJava原理及如何封装使用 334

10.okhttp源码分析

11.retrofit源码分析

12.LeakCanary核心原理源码浅析

13.LruCache 使用及原理

14.ARouter原理

15.注解框架实现原理

16.Android 如何编写基于编译时注解的项目

17.RxJava2+Retrofit2+OkHttp3的基础、封装和项目中的使用

18.Rxjava2.0+Retrofit+Okhttp(封装使用)+MVP框架搭建

19.Android 插件化和热修复知识梳理

20.Android开发中比较常见的内存泄漏问题及解决办法

21.如何检测和定位Android内存泄漏

22.图片占据的内存算法

23.为什么图片需要用软引用,MVP模式中的view接口用弱引用 580

24.基于DataBinding与LiveData的MVVM实践

25.App稳定性优化

Android开发两年,我要跳槽去阿里巴巴了,做个阶段总结,flutterrow高度对齐相关推荐

  1. Android开发两年,我要跳槽去阿里巴巴了,做个阶段总结

    相关知识点: [数组](javascript: void(0))[数学](javascript: void(0))[位运算](javascript: void(0)) 相关知识点: [数组](java ...

  2. 斗鱼直播Android开发二面被刷,跳槽薪资翻倍

    前言 前几年移动互联网创业的风口,如今渐渐消失,移动互联网被巨头公司瓜分,一些创业公司倒闭了,Android 开发需求慢慢趋近于饱和.而当初移动互联网处于风口时,自学.转行以及培训机构出来了大量 An ...

  3. 【手把手教】Android开发两种方式实现图片的上传下载

    Android 图片上传的应用场景 在Android开发中,很多时候我们需要进行图片,文件的上传下载,最直接的一个应用场景就是用户头像的保存与切换,以及像即时通讯中的图片发送等任何在App中设计图片的 ...

  4. Android开发两年,跳槽面试小公司面试官说我可以试试大厂

    不过还是打算跳槽了,薪资和无法推动项目是个大问题,总不能鱼渔都不得吧.我是抱着找不到好的,就北上的心态找的. 做股票期货的,经验类似,面试太过顺利- Activity的启动模式 Activity和Fr ...

  5. Android开发两年,跳槽面试小公司面试官说我可以试试大厂---,Android小程序开发实例

    开源库用过哪些 自己平时写项目学习,基本都用过,原理也了解:重构项目的资讯模块用了Retrofit & RxJava,自己思考优化了代码框架,比如线程切换.页面查找等,其实弄清楚原理,要改哪里 ...

  6. 掌握这些Android开发热门前沿知识,跳槽薪资翻倍

    前言 这是一篇软文.但是绝对不是鸡汤:为啥不是呢?因为我文笔太差-偶尔矫情发发牢骚(勿喷) 说说程序猿行业 现在社会上给IT行业贴上了几个标签:高薪.高危.高大上.秃顶(哈哈).这些标签我相比大家都比 ...

  7. Android开发 ---- 两分钟写一个录音演示软件

    Android自带的SoundRecoder软件写得很简单,就3个Java文件,最有特色的还算哪个指针了.这里并不是要介绍那个个指针的实现过程,其实也简单,就是一个算法,通过录音过程中获取的振幅来实现 ...

  8. Flutter _ 状态管理指南篇,Android开发两年

    ),); 然后我们开始测试,点击收藏按钮,查看 rebuild 情况. Performing hot reload- Syncing files to device iPhone Xs Max- - ...

  9. android开发百度地图定位到大西洋去了!!

    我采用的是TabHost+activity的方式实现界面的跳转,我将调用地图和监听定位的代码写到另外的类里,类结构如下: Map.java实现调用显示地图,MyOrientationListener. ...

最新文章

  1. Node.js(nodejs)对本地JSON文件进行增、删、改、查操作(轻车熟路)
  2. 描述符应用 -- 让python变成一个强类型的语言
  3. Java Stringbuilder简单介绍
  4. 一阶电路暂态响应的结果分析。_反激式DCDC变换器的分析、计算与仿真精讲
  5. udp 使用connect优点_nodejs源码分析第十九章 -- udp模块
  6. linux数据库mysql的安装
  7. C语言const关键字—也许该被替换为readolny
  8. Controller接口控制器(4)
  9. mysql havequerycache_如何开启MySQL的中的Query Cache缓存
  10. 有关AntDesign的简单学习
  11. z-index ios失效
  12. ios降级鸿蒙,ios14怎么降级13.6 苹果iOS14降级超详细教程
  13. csv文档转为tsv文档-csv to tsv
  14. 中专计算机学数学,科学计算器在中职数学教学中的意义
  15. 0914WEB漏洞-二次,加解密,DNS等注入
  16. matlab 构建雅可比矩阵,matlab jacobian函数
  17. 【论文阅读 Journal of Financial Economics】Surprise election for Trump connections
  18. 通达OA前台任意用户登录漏洞+RCE漏洞复现
  19. 思科软件网络部署及命令总结
  20. 在linux系统中通过fw_printenv查看和设置u-boot中的环境变量

热门文章

  1. 泰勒级数、欧拉公式、三角函数
  2. html酷炫电子时钟效果,纯js实现电子时钟特效
  3. TOLUA的文件结构
  4. React18 tearing tree issue 撕裂状态问题
  5. ASA广告投放策略:建立、更新你的关键词库
  6. C++ PDF文档相关操作
  7. 求两个数中的最大值最小值算法
  8. 2018 中国人口研究,净增长500多万人。5年后注定人口负增长
  9. dcos里面跑jenkins的问题
  10. 北邮信通复试题c语言,北邮计算机考研复试题的C语言解答精选.pdf