1 总览
作为开发者,基础知识非常重要的,尤其一些大厂非常注重基础,基础是一切的根本,在面试时候,如果没有事先准备,很容易被淘汰。笔者整理这套知识点,大大小小的一共几百多条,方便大家查漏补缺。
参考答案点击这里
分为以下几个部分
-
Java 知识点
-
Android 知识点
-
计算机基础知识点
-
算法
2 Java 知识点
2.1 Java 基础
-
Java 语言有什么特点?
-
面向对象三大特征
-
Java 和 C++ 的区别?
-
import java 和 javax 有什么区别?
-
JVM、JDK、JRE 区别?
-
Java 语言是编译与解释并存?
-
Java 注释
-
Java 标识符和关键字
-
Oracle JDK 和 OpenJDK 的区别?
-
访问修饰符 public、private、protected、以及不写(默认)时的区别?
-
String 是最基本的数据类型吗?
-
String s = new String("xyz");创建了几个字符串对象?
-
是否可以继承 String 类?
-
float f=3.4;是否正确?
-
short s1 = 1; s1 = s1 + 1;有错吗?short s1 = 1; s1 += 1;有错吗?
-
int 和 Interger 区别?
-
new Integer(120) 与 Integer.valueOf(120) 有何区别?
-
&和&&的区别?
-
Math.round(11.5) 等于多少?Math.round(-11.5)等于多少?
-
switch 是否能作用在 byte 上,是否能作用在 long 上,是否能作用在String上?
-
用最有效率的方法计算2乘以8
-
数组有没有 length() 方法?String 有没有 length() 方法?
-
在 Java中,如何跳出当前的多重嵌套循?
-
构造器(constructor)是否可被重写(override)?
-
两个对象值相同 x.equals(y) == true,但却可有不同的 hashcode,对不对?
-
当一个对象被当作参数传递到一个方法后,此方法可改变这个对象的属性,并可返回变化后的结果,那么这里到底是值传递还是引用传递?(Java 没有引用传递,只有值传递)
-
String 和 StringBuilder、StringBuffer的区别?
-
重载(Overload)和重写(Override)的区别,重载的方法能否根据返回类型进行区分?
-
抽象类(abstract class)和接口(interface)有什么异同?
-
char 型变量中能不能存贮一个中文汉字,为什么?
-
静态嵌套类(Static Nested Class)和内部类(Inner Class)的不同?
-
抽象的(abstract)方法是否可同时是静态的(static),是否可同时是本地方法(native),是否可同时被 synchronized 修饰?
-
一个类中静态(static)方法是否可以调用非静态(non-static)方法?
-
如何实现对象克隆?
-
断点续传?
-
Java 中的 final 关键字有哪些用法?
-
try{}里有一个return语句,那么紧跟在这个try后的finally{}里的代码会不会被执行,什么时候被执行,在return前还是后?
-
阐述 final、finally、finalize 的区别?
-
Collection和Collections的区别?
-
字符型常量和字符串常量的区别?
-
Java 基本类型占用内存大小?
-
continue、break、和 return 的区别?
-
== 和 equals 区别?
-
hashCode() 与 equals()
-
在 Java 中定义一个不做事且没有参数的构造方法的作用?
-
对象的相等与指向他们的引用相等,两者有什么不同?
-
在一个静态方法内调用一个非静态成员为什么是非法的?
-
Object 类常见的方法?
-
Java 序列化中如果有些字段不想进行序列化,如何做?
-
重载和重写的区别?
-
成员变量与局部变量区别?
-
类的构造方法的作用是什么? 若一个类没有声明构造方法,该程序能正确执行吗? 为什么?
-
为什么不能通过返回值类型区分重载?
-
BIO、NIO、AIO 区别?
-
装箱和拆箱的原理?
-
反射
-
Java 泛型
-
泛型类型擦除?
-
获取 Class 对象的方法?
-
反射中创建对象的两种方法?
-
为什么重写 equals 时必须重写 hashCode 方法?
-
解决Hash碰撞冲突方法?
-
深拷贝和浅拷贝?
-
说说 Java 异常体系?
-
Java I/O 分为几种?
-
那些状态下 finally 不会被执行?
2.2 Java 容器
-
ArrayList、LinkedList、Vector 区别?
-
list、set、map 区别?
-
HashSet、LinkedHashSet、TreeSet 区别、源码?
-
HashMap、LinkedHashMap、Hashtable、TreeMap 区别、源码?
-
List、Set、Map 区别?
-
ArrayList 和 Vector 区别?
-
说说 ConcurrentHashMap?
-
ArrayList 扩容机制?
-
说说 ArrayList 源码中 ensureCapacity() 作用吧?
-
HashMap 的长度为什么是 2 的幂次方?
-
comparable 和 Comparator 的区别?
2.3 Java 并发
-
sleep() 和 wait() 区别?
-
sleep() 方法和 yield() 区别?
-
实现多线程程序有几种实现方式?
-
线程的生命周期?
-
为什么线程启动要调用 start(),而不是直接调用 run()?
-
interrupt()、interrupted()、isInterrupted() 区别?
-
start()、run() 区别?
-
说说乐观锁、悲观锁、自旋锁、共享锁、独占锁、重量级锁、轻量级锁?
-
说说 synchronized?
-
说说 ReentrantLock ?
-
说说线程的死锁吧?
-
如何避免死锁?
-
程序计数器为什么设计成私有?
-
虚拟机栈和本地方法栈为什么设计成私有?
-
公平锁、非公平锁、可重入锁?
-
Semaphore 信号量
-
JDK 1.6 synchronized 作了那些优化?
-
说说 ThreadPoolExecutor 构造方法的参数?
-
说说 Java 阻塞队列?
-
CyclicBarrier、CountDownLatch、Semaphore 的用法?
-
说说 volatile?
-
上下文切换?
-
说说 ThreadLocal ?
-
进程调度算法?
-
线程有哪些基本状态?
-
并发和并行区别?
-
线程和进程区别?
-
了解 CAS 吗?
-
说说 ABA 问题?
-
AQS 了解吗?
2.4 JVM
-
说说 JVM 运行时数据区?
-
说说 JVM 内存区域?
-
Java 对象如何创建的,对象创建过程?
-
MinorGC、MajorGC、FullGC 区别?
-
可作为 GC Roots 的对象?
-
垃圾回收算法?
-
类加载机制?
-
类加载器?
-
双亲委派机制?
-
内存分配策略?
-
对象的访问定位有哪几种?
-
虚拟机如何解决内存分配并发问题?
-
可作为 GC Roots 的对象包括几种?
-
String s1 = new String("abc");这句话创建了几个字符串对象?
-
String.intern() 作用?
2.5 设计模式
-
创建者模式
-
单例模式
-
工厂模式
-
原型模式
-
建造者模式
-
-
结构型模式
-
适配器模式
-
代理模式
-
装饰者模式
-
桥接模式
-
外观模式
-
享元模式
-
组合模式
-
桥接模式
-
-
行为型模式
-
模板模式
-
策略模式
-
命令模式
-
职责链模式
-
状态模式
-
观察者模式
-
中介者模式
-
迭代器模式
-
访问者模式
-
备忘录模式
-
解释器模式
-
3 Android 知识点
-
Activity 生命周期
-
横竖屏切换时候 Activity 的生命周期
-
ActivityA 跳转 ActivityB 然后 B 按 back 返回 A,各自的生命周期顺序,A 与 B 均不透明?如果B是透明主题的又或是个DialogActivity 呢?
-
Android中进程的优先级?
-
onSaveInstanceState()方法的作用 ? 何时会被调用?
-
Activity的四种启动模式、应用场景 ?
-
Activity 常用的标记位 Flags?
-
Activity 跟 window,view 之间的关系?
-
如何启动其他应用的 Activity?
-
什么是 ANR? 如何避免?
-
说说 Android 中的动画?
-
ACTION_CANCEL 事件触发?
-
动画的原理?
-
属性动画和 View 动画区别?
-
Android 各版本新版本
-
Serialzable 和 Parcelable 的区别?
-
Android 为每个应用程序分配的内存大小是多少?
-
Activity 的 startActivity 和 context 的 startActivity区别?、
-
怎么在Service中创建Dialog对话框?
-
程序A能否接收到程序B的广播?
-
数据加载更多涉及到分页,你是怎么实现的?
-
编译期注解跟运行时注解有何不同?
-
如何解析 xml,以及三种方式的区别?
-
更新 UI 方式?
-
jar 和 aar 的区别?
-
程序自启动?
-
BroadcastReceiver,LocalBroadcastReceiver 区别?
-
SharedPrefrences 的 apply 和 commit 有什么区别?
-
计算一个view的嵌套层级?
-
asset 目录与 res 目录的区别?
-
硬件加速
-
显式 Intent 和隐式 Intent
-
广播传输的数据是否有限制,是多少,为什么要限制?
-
安卓签名机制?
-
merge、ViewStub、include 的作用?
-
ContentProvider 使用
-
Android 怎么加速启动 Activity?
-
Json 解析方式的两种区别?
-
Fragment懒加载
-
Bitmap 使用时候注意什么?
-
多进程场景遇见过么?
-
Bitmap 的 recycler()
-
一张Bitmap所占内存以及内存占用的计算
-
数据库升级增加表和删除表都不涉及数据迁移,但是修改表涉及到对原有数据进行迁移,如何实现?
-
Canvas.save() 跟 Canvas.restore()的区别
-
为什么bindService可以跟Activity生命周期联动?
-
自定义 view 效率高于xml定义吗?说明理由。
-
Gradle 配置多渠道打包
-
Service 的生命周期
-
加速启动Activity?
-
断点续传和下载
-
Fragment 在 ViewPager 里面的生命周期,滑动 ViewPager 的页面时 Fragment 的生命周期的变化。
-
Android中跨进程通讯的几种方式?
-
HandlerThread
-
IntentService
-
说一说支付流程?
-
如何导入外部数据库
-
如何保证Service不被杀死?
-
简单说说 LinearLayout、FrameLayout、RelativeLayout 性能?
-
说说 scheme 跳转协议?
-
说说 Android 中集合框架?
-
Service 和 Activity 在同一个线程吗?
-
Service 里面可以弹吐司么?
-
说说 Activity、Intent、Service 是什么关系?
-
简单说一下 IntentService
-
Context 是 什 么 ? 一 个 应用有多少个 Context?
-
Context、 Activity、Application 有什么区别?
-
实现竖向的 TextView?TextView 文字描边效果?
-
广播的两种注册方式 ?
-
Activity 怎么和 Service 绑定,怎么在Activity 中启动自己对应的 Service?
-
如何将一个 Activity 设置成窗口的样式
-
简单说一下 Activity
-
Service 是否在 main thread 中执行, service 里面是否能执行耗时的操作?
-
说说ContentProvider、ContentResolver、ContentObserver 之间的关系?
-
ddms 和 traceView 的区别?
-
Handler、Thread和HandlerThread的差别
-
Android 适配方案
-
Android 中 HashMap 的优化
-
AsyncTask 的缺陷和问题,说说他的原理?
-
说说 AndroidManifest.xml?
-
Activty 和 Fragmengt 之间怎么通信,Fragmengt 和 Fragmengt怎么通信?
-
Android系统架构,你能说说每一层的作用吗?
-
反编译了解吗?
-
为什么 bindService 可以跟Activity生命周期联动?
-
oom 是否可以try catch ?
-
如何绕过 9.0 限制
-
你是如何做单元测试的
-
非UI线程可以更新UI吗?
-
怎么控制另外一个进程的View显示?
-
Android 程序运行时权限与文件系统权限
-
SurfaceView、TextureView、SurfaceTexture、GLSurfaceView?
-
Scroller 原理?
-
RecyclerView 的性能优化
-
ListView 与 RecyclerView 简单对比?
-
Android类加载器
-
onStart()与onResume()有什么区别?
-
说说 IdleHandler
-
同步屏障机制(sync barrier)
-
getWidth() 和 getMeasureWidth() 区别
-
requestLayout,invalidate,postInvalidate 之间的区别?
-
apk安装流程
-
app 瘦身
-
64k
-
遇到 Fragment 哪些问题?
-
View 绘制
-
如何解决View的事件冲突?
-
SharePreference性能优化
-
内存缓存和磁盘缓存是怎么实现的?
-
PathClassLoader与DexClassLoader有什么区别?
-
SQLite升级
-
WebView优化
-
什么是MeasureSpec?
-
Fragment的懒加载实现
-
DataBinding了解吗,你能说说它具体实现原理吗,有那些缺点?
-
MVC、MVP、MVVM 之间有何区别?
-
如何实现一个圆形头像?
-
Apk 加密?
-
Apk 打包流程?
-
Android 匿名共享内存
-
MMKV 用过吗、原理?
-
界面刷新机制?
-
打包的时候 v1、v2、v3 签名有何区别?
-
Activity启动过程
-
ContentProvider启动过程
-
Service启动过程
-
广播启动过程
-
Binder机制
-
插件化
-
组件化
-
热修复
-
换肤方案
-
事件分发
-
绘制流程
-
源码分析
-
ARouter
-
ButterKnife
-
Dagger2
-
EventBus
-
Glide
-
GreenDao
-
Leakcanary
-
Okhttp
-
Retrofit
-
RxJava
-
-
性能优化
-
内存优化
-
绘制优化
-
启动优化
-
数据存储优化
-
网络优化
-
电量优化
-
包体积优化
-
-
Kotlin
-
谈谈协程?
-
List 与 MutableList 的区别?
-
let、with、run、apply、also 之间的区别应用场景?
-
注解 @JvmOverloads 的作用?
-
实现单例的几种常见方式?
-
data class 理解?
-
集合遍历有哪几种方式?
-
什么是委托属性?请简要说说其使用场景和原理?
-
Kotlin中 Unit 类型的作用以及与Java中 Void 的区别?
-
Kotlin 中 infix 关键字的原理和使用场景?
-
"==" 和 "===" 区别?
-
介绍一下伴生对象和静态成员?
-
kotlin 中 var、val、const val 区别?
-
@JvmField 和 @JvmStatic 的使用
-
@JvmOverloads 的作用?
-
List 与 MutableList 区别?
-
Kotlin 中的数据类型有隐式转换吗?
-
Kotlin中的可见性修饰符有哪些?相比于 Java 有什么区别?
-
在 Kotlin 中,什么是内联函数?有什么作用?
-
谈谈 Kotlin 中的 Sequence,为什么它处理集合操作更加高效?
-
请谈谈 Kotlin 中的 Coroutines,它与线程有什么区别?有哪些优点?
-
Kotlin 中可见型修饰符有哪些?相比于Java有什么区别?
-
谈谈 Kotlin 中的Unit?它和 Java 中的 void 有什么区别?
-
如何安全地处理可空类型?
-
说说 Kotlin中 的 Any 与 Java 中的 Object 有何异同?
-
Kotlin中 Unit 类型的作用以及与Java中 Void 的区别?
-
分别通过对象表达式 object 和 lambda 表达式实现的函数式接口内部有何不同?
-
4 计算机基础知识点
-
tcp/ip 流量控制和滑动窗口如何实现的,能具体说说嘛?
-
DNS 解析过程?
-
三次握手和四次挥手?
-
谈谈 TCP/IP 协议?
-
TCP 协议如何保证可靠传输?
-
拥塞控制的算法?
-
在浏览器中输入 url 地址发生了什么?
-
URI 和 URL 的区别是什么?
-
HTTP1.0、HTTP2.0、HTTP3.0 区别?
-
HTTP 和 HTTPS 区别?
-
进程和线程区别?
-
进程有那几种的状态?
-
进程间有哪几种通信方式?
-
线程间的同步方式?(互斥量、信号量、事件)
-
进程间的调度算法?
-
页面置换算法?
5 算法
算法无论在面试还是日常开发中都非常重要,可以很好的培养我们编程思维,刷题网站这里推荐 LeetCode,如果有时间起码要刷 300 道,而且要反复刷,刷题可以参考极客算法训练营,五毒神掌。
-
第一遍
-
5分钟:读题 + 思考
-
如果没有思路,直接看解法,比较优劣
-
背诵、默写好的解法
-
-
第二遍
- 写代码测试 -> 最优
-
第三遍
- 过一天,重复做题
-
第四遍
- 过一周,重复做题
-
第五遍
- 过一个星期,恢复性训练
-
剑指Offer
-
数组中重复的数字
-
二维数组中的查找
-
替换空格
-
从尾到头打印链表 重建二叉树
-
用两个栈实现队列
-
斐波那契数列
-
青蛙跳台阶问题
-
旋转数组的最小数字
-
矩阵中的路径
-
机器人的运动范围
-
剪绳子
-
剪绳子 II
-
二进制中1的个数
-
数值的整数次方
-
打印从1到最大的n位数
-
删除链表的节点
-
正则表达式匹配
-
表示数值的字符串
-
调整数组顺序使奇数位于偶数前面
-
链表中倒数第k个节点
-
反转链表
-
合并两个排序的链表
-
树的子结构
-
二叉树的镜像
-
对称的二叉树
-
顺时针打印矩阵
-
栈的压入、弹出序列
-
从上到下打印二叉树
-
从上到下打印二叉树 II
-
从上到下打印二叉树 III
-
二叉搜索树的后序遍历序列
-
复杂链表的复制
-
二叉搜索树与双向链表
-
序列化二叉树
-
字符串的排列
-
数组中出现次数超过一半的数字
-
最小的k个数
-
数据流中的中位数
-
连续子数组的最大和
-
1~n 整数中 1 出现的次数
-
数字序列中某一位的数字
-
把数组排成最小的数
-
把数字翻译成字符串
-
礼物的最大价值
-
最长不含重复字符的子字符串
-
丑数
-
第一个只出现一次的字符
-
数组中的逆序对
-
两个链表的第一个公共节点
-
在排序数组中查找数字 I
-
0~n-1中缺失的数字
-
二叉搜索树的第k大节点
-
二叉树的深度
-
平衡二叉树
-
数组中数字出现的次数
-
数组中数字出现的次数 II
-
和为s的两个数字
-
和为s的连续正数序列
-
翻转单词顺序
-
左旋转字符串
-
滑动窗口的最大值
-
队列的最大值
-
n个骰子的点数
-
扑克牌中的顺子
-
圆圈中最后剩下的数字
-
股票的最大利润
-
求1+2+…+n
-
不用加减乘除做加法
-
构建乘积数组
-
把字符串转换成整数
-
二叉搜索树的最近公共祖先
-
二叉树的最近公共祖先
-
-
HOT 100
-
1 两数之和
-
2 两数相加
-
3 无重复字符的最长子串
-
4 寻找两个正序数组的中位数
-
5 最长回文子串
-
10 正则表达式匹配
-
11 盛最多水的容器
-
15 三数之和
-
17 电话号码的字母组合
-
19 删除链表的倒数第 N 个结点
-
20 有效的括号
-
21 合并两个有序链表
-
22 括号生成
-
23 合并K个升序链表
-
31 下一个排列
-
32 最长有效括号
-
33 搜索旋转排序数组
-
34 在排序数组中查找元素的第一个和最后一个位置
-
39 组合总和
-
42 接雨水
-
46 全排列
-
48 旋转图像
-
49 字母异位词分组
-
53 最大子序和
-
55 跳跃游戏
-
56 合并区间
-
62 不同路径
-
64 最小路径和
-
70 爬楼梯
-
72 编辑距离
-
75 颜色分类
-
76 最小覆盖子串
-
78 子集
-
79 单词搜索
-
84 柱状图中最大的矩形
-
85 最大矩形
-
94 二叉树的中序遍历
-
96 不同的二叉搜索树
-
98 验证二叉搜索树
-
101 对称二叉树
-
102 二叉树的层序遍历
-
104 二叉树的最大深度
-
105 从前序与中序遍历序列构造二叉树
-
114 二叉树展开为链表
-
121 买卖股票的最佳时机
-
124 二叉树中的最大路径和
-
128 最长连续序列
-
136 只出现一次的数字
-
139 单词拆分
-
141 环形链表
-
142 环形链表 II
-
146 LRU 缓存机制
-
148 排序链表
-
152 乘积最大子数组
-
155 最小栈
-
160 相交链表
-
169 多数元素
-
198 打家劫舍
-
200 岛屿数量
-
206 反转链表
-
207 课程表
-
208 实现 Trie (前缀树)
-
215 数组中的第K个最大元素
-
221 最大正方形
-
226 翻转二叉树
-
234 回文链表
-
236 二叉树的最近公共祖先
-
238 除自身以外数组的乘积
-
239 滑动窗口最大值
-
240 搜索二维矩阵 II
-
253 会议室 II
-
279 完全平方数
-
283 移动零
-
287 寻找重复数
-
297 二叉树的序列化与反序列化
-
300 最长递增子序列
-
301 删除无效的括号
-
309 最佳买卖股票时机含冷冻期
-
312 戳气球
-
322 零钱兑换
-
337 打家劫舍 III
-
338 比特位计数
-
347 前 K 个高频元素
-
394 字符串解码
-
399 除法求值
-
406 根据身高重建队列
-
416 分割等和子集
-
437 路径总和 III
-
438 找到字符串中所有字母异位词
-
448 找到所有数组中消失的数字
-
461 汉明距离
-
494 目标和
-
538 把二叉搜索树转换为累加树
-
543 二叉树的直径
-
560 和为K的子数组
-
581 最短无序连续子数组
-
617 合并二叉树
-
621 任务调度器
-
647 回文子串
-
739 每日温度
-
-
排序算法
-
冒泡排序
-
选择排序
-
插入排序
-
希尔排序
-
归并排序
-
快速排序
-
堆排序
-
计数排序
-
桶排序
-
基数排序
-