- 堆的实现,最大堆,最小堆,优先队列原理。
算法算法其实就是我们平时常见的一些排序:选择排序,插入排序,冒泡排序,希尔排序,归并排序,快速排序。以及和数据结构相关联的解决部分问题的一些计算方法。
算法面试遇到的一些题:
- 手写快速排序,插入排序,冒泡排序
- 翻转一个数字
- 翻转一个链表
- O(n)复杂度找出数组中和是9的两个数的索引
- 写出二分搜索树前中后序遍历中的其中一个
- 实现一个队列,并能记录队列中最大的数。
算法这一块是需要练习的推荐去Leetcode上面刷刷题,开拓一下思维。算法也并不一定要求你能写出来,主要考察你的思路,已经如何优化你的算法。
3)JVM虚拟机
JVM虚拟机我们需要知道他们内部组成:堆,虚拟机栈,本地方法栈,方法区,计数器。每一块都存放什么东西,以及垃圾回收的时候主要回收哪些块的东西。GC-ROOT链是从哪些地方开始的,垃圾回收集算法(很少遇到问的)。
类加载ClassLoader已经双亲委派机制,类加载的过程,类加载的信息对应在JVM的哪些块中。
列一个遇到的类加载的面试题:
public class TestClassLoader {
static class Father {
public static final String TAG = “Father”;
static {
System.out.println(“static Father”);
}
{
System.out.println(“unStatic Father”);
}
public Father() {
System.out.println(“constract Father”);
method();
}
public void method() {
System.out.println(“method Father”);
}
@Override
public String toString() {
return “toString Father”;
}
}
static class Son extends Father {
public static Son instance = new Son();
static {
System.out.println(“static Son”);
}
{
System.out.println(“unStatic Son”);
}
public Son() {
System.out.println(“constract Son”);
method();
}
public void method() {
System.out.println(“method Son”);
}
@Override
public String toString() {
return “toString Son”;
}
}
public static void main(String[] args) {
System.out.println(“1.---------------------”);
System.out.println(Son.TAG);
Son[] sons = new Son[10];
System.out.println(sons);
System.out.println(“2.---------------------”);
System.out.println(Son.instance);
System.out.println(“3.---------------------”);
Son son = new Son();
Father father = son;
father.method();
System.out.println(son);
}
}
写出打印输出。
加一个小插曲:上面的题是饿了吗面试问到的。面试我的人自己说是17年北航毕业的研究生。说自己非常注重基础,全程问了很多JAVA基础,包括上面的类加载的题,很自豪的说这个题是他自己出的。还有Collections下面的子类都有哪些,都有什么不同。但是Android相关的题目问的水平很一般,说这个没有嘲讽的意思。想说的是有些面试从一开始就注定了你可能进不了这个公司。面试有的时候也是要看眼缘的。不要灰心,找出自己的不足,补齐它,继续前行。还有就是上面那个题,的确很不错。
4)线程安全
当多个线程访问一个对象的时候,如果不用考虑这些线程在运行时环境下的调度和交替执行,也不需要进行额外的同步,或者在调用方进行任何其他的协调操作,调用这个对象的行为都可以获取正确的结果,我们就认为这个对象时线程安全的。
线程安全就是一些多线程下载,同步,锁,死锁,线程池。volatile关键字的特性,变量的原子性。以及java.util.concurrent包下的类,也需要了解一下。
一般会问的是手写单例,以及双重锁式单例的优点。还有就是让你自己实现一个多线程下载,看你怎么设计。
5)编程思想
封装,继承,多态,抽象,反射,注解,设计模式,设计模式的原则。
面试中一般会问下:
- 抽象和接口有什么不一样
- 工作中常用的设计模式,一些源码中的设计模式
- 具体给你一个设计模式让你说说你对他的了解,比如观察者,工厂。
以上这些东西主要考察你的代码设计能力。
6)网络协议
- 互联网的实现主要分为几层,http、ftp、tcp、ip分别位于哪一层。
- http和https的区别
- 为什么tcp要经过三次握手,四次挥手
- socket了解过吗
一般http和https问的比较多,对称加密和非对称加密也会问。tcp和socket偶尔遇见问的。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
尾声
最后,我再重复一次,如果你想成为一个优秀的 Android 开发人员,请集中精力,对基础和重要的事情做深度研究。
对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。
这里,笔者分享一份从架构哲学的层面来剖析的视频及资料分享给大家梳理了多年的架构经验,筹备近6个月最新录制的,相信这份视频能给你带来不一样的启发、收获。
Android进阶学习资料库
一共十个专题,包括了Android进阶所有学习资料,Android进阶视频,Flutter,java基础,kotlin,NDK模块,计算机网络,数据结构与算法,微信小程序,面试题解析,framework源码!
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
11704)]
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-Yve0KmgP-1712593511705)]