近期一个多月面试过一下公司(均为实习):

腾讯:内推一面卒。

正式校招拿到offer

阿里:内推二面卒。

蘑菇街:面完三面技术面,等待HR面

网易:拿到offer。

能够看到,大部分问题不难,可是能回答对和回答的好不好又是两个两个不同的情况了。不论什么问题都尽量回答的越具体,越清晰。越全面,面试官就会越觉得你掌握的越好。

比方问一下内存泄露,那么试着多列举一些情况:

首先解释内存泄露是什么。

最常见的handler引用Activity。static+WeakReference解决

耗时线程

bitmap调用recycle,3.0前和后,3.0后偷换native内存

想持久化Drawable,定义成static,老版本号他持有view,view持有activity,可能间接造成activity泄露。4.0已修复。

广播记得取消注冊

除此之外,如能提到jdk1.6中String的substring方法。那效果更好。

再比方问到性能优化:

从布局优化ViewStub,merge,include

overdraw。GPU选项观察overdraw情况

view的ondraw。尽量别new对象,不能耗时,60fps,16ms。GPU加速

必要情况下使用SurfaceView

避免内存泄露(又回到上一个问题了)

ListView的优化:holder。分页载入,滑动停止后再下载图片等

Bitmap的优化。载入单个bitmap。多个bitmap时的内存硬盘缓存

利用android中的一些数据结构比方ArrayMap和SparseArray

少用枚举。多用static訪问快

下面是面试中问到的问题,可能不全,由于隔得时间有些长可能忘记了。

jvm:

内存模型,特点。类信息在哪个区

栈和堆的差别

GC怎么知道一个对象要被回收,

GC Root

强引用,软引用,弱引用,虚引用

类载入过程

在项目中哪里使用过JVM的知识

java:

java基本数据类型

多态是什么,怎么实现的

==和equals

hashcode

HashMap和HashTable差别

HashMap,LinkedHashMap底层实现

HashMap的整过过程,怎么设计一个hash函数散列均匀

并发容器包,ConcurrentHashMap原理

ArrayList和LinkedList差别

虚函数实现

反射。项目中啥时候用过。

wait和sleep的差别

并发同步,synchronized为什么是重量级的方式

votilekeyword的特点

线程和线程池,线程池的实现的原理

两个线程依次打印一串数字

NIO。原理。裸写NIO的难点在哪

unix的I/O模型

数据结构算法

堆得实现。数组保存二叉树

堆排序

高速排序

数组找反复数字,位置

讲一下常见排序算法的思想和复杂度

android:

activity生命周期,每一个函数调用发生在什么情况下

Fragment生命周期。开发中须要注意什么问题

android中几种上下文的差别

bitmap优化。复用,偷换native内存,BitmapFrctory.option几个參数

缓存策略,LruCache和DiskLruCache原理。加上软引用。缓存框架的构架大概是什么样子。

网络请求缓存

handler机制

handler一般用来干什么?还有在哪些地方看到使用handler

HandlerThread

Service和IntentService

启动服务的方式。有没有使用过bindService

view绘制过程

事件分发过程

使用过Canvas没

ListView优化

做过什么自己定义控件,须要注意什么问题

View的onDraw方法扯到SurfaceView

ANR怎么避免

OOM怎么避免

Binder底层实现,框架

ViewRoot源代码,这个类的主要功能

内存泄露

怎么检測内存泄露

性能优化

动态载入了解不

activity启动过程

/data/app/的目录和文件的权限(非常犀利的面试官问的。项目中用到最重要的一点。不愧10年工作经验)

Android是怎么学的

强行装逼时刻:想办法扯到Binder的源代码。动态载入。插件框架:360的DroidPlugin和百度的DynamicLoad原理,activity启动流程,跨进程回调上面来,以及一些开源库。基本上讲完动态载入的框架就是和面试官聊天了。

设计模式:

知道哪些设计模式,平时怎么用的?

口头念出一个单例每行怎么写,多线程问题

外观模式

http:

(每次http的问题我回答不出来我就告诉面试官,http这些我仅仅知道简单的,没有深入研究,android的能够随便问,然后就不问http的问题了)

304

缓存

tcp/ip:

七层模型

TIME_WAIT

流量控制,拥塞控制

http头里面的host有什么用url里面都有了为什么在头字段要有

操作系统:

进程与线程

操作系统看了那些内容

进程间通信的方式

死锁。怎么避免。平时遇到没

项目:

每讲一个点的时候都会问我为什么这么设计,你从哪里学到的?在哪里看到这么做的?

遇到了什么问题。怎么解决的?是怎么发现问题的?log。单步调试

项目的架构

有没有为面试做准备。准备了哪些内容。

大概就是这些,有些可能时间太长我也记不太清了。

近期面试Android的一些面试题的更多相关文章

  1. 近期面试总结(Android)

    关于近期面试总结(2018年下半年) 有些是老生常谈有些是没有遇到的. 1.HTTP和HTTPS的区别 HTTP协议传输的数据都是未加密的,也就是明文的,因此使用HTTP协议传输隐私信息非常不安全,为 ...

  2. Java面试总结(面试流程及核心面试题)

    Java面试流程及核心面试题 面试整体流程 1.1 简单的自我介绍      我是xxxx,工作xxx年.我先后在xxxx公司.yyyy公司工作.先后做个xxxx项目.yyyy项目. 1.2 你简单介 ...

  3. 腾讯面试Android高级岗,居然被一个多线程基础面倒了?

    前言 一个在深圳从事开发五年的老友一个月前从原公司辞职后,昨天去腾讯总部面试Android高级岗,一面的时候,自我介绍后,陆陆续续问了很多问题,有着五年的从业经验很多项目开发的技术问题都回答的很通顺, ...

  4. JQuery选择器大全 前端面试送命题:面试题篇 对IOC和DI的通俗理解 c#中关于协变性和逆变性(又叫抗变)帮助理解

    JQuery选择器大全   jQuery 的选择器可谓之强大无比,这里简单地总结一下常用的元素查找方法 $("#myELement")    选择id值等于myElement的元素 ...

  5. 关于面试总结-SQL经典面试题

    关于面试总结6-SQL经典面试题 前言 用一条SQL 语句查询xuesheng表每门课都大于80 分的学生姓名,这个是面试考sql的一个非常经典的面试题 having和not in 查询 xueshe ...

  6. 2017、2018面试分享(js面试题记录)记得点赞分享哦;让更多的人看到~~

    2017面试分享(js面试题记录) 1. 最简单的一道题 '11' * 2 'a8' * 3 var a = 2, b = 3; var c = a+++b; // c = 5 2. 一道this的问 ...

  7. 2019Android阿里&腾讯&百度&字节面试汇总(附面试题总结、Android书单)

    1.基本情况 先简单说说我今年的面试经历吧,本人2018届211软件工程硕士生,Android开发岗.此文主要是2019年年初春招的面试和秋招面试经验汇总,最终拿到了阿里,腾讯,字节跳动,百度等off ...

  8. 近期面试总结(PHP后端开发工程师)(部分笔试题)

    1.字符串"0"在PHP和js中转换为布尔值是false还是true php:false; php 弱语言 '0'和0一样: js:true:字符串除了空字符串('')其他都是tr ...

  9. Android开发工程师面试题总结。android开发面试经验

    1:Android中五种数据存储方式分别是什么?他们的特点?     (1)SharedPreference,存放较少的五种类型的数据,只能在同一个包内使用,生成XML的格式存放在设备中 (2) SQ ...

随机推荐

  1. CodeForces 779E Bitwise Formula

    位运算,枚举. 按按分开计算,枚举$?$是$0$还是$1$,分别计算出$sum$,然后就可以知道该位需要填$1$还是$0$了. #include<map> #include<set& ...

  2. 循序渐进PYTHON3(十三) --2-- DJANGO之FORM表单(自动生成HTML标签和自定制提示信息)

    在上一次的代码上做出进一步修改,使之能在页面上显示自定制的报错信息,并且使用form自动创建标签的功能. views.py from django.shortcuts import render,Ht ...

  3. HDU6058 Kanade's sum(思维 链表)

    Kanade's sum Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Tota ...

  4. Codeforces Round #300 Quasi Binary(DP)

    Quasi Binary time limit per test 2 seconds memory limit per test 256 megabytes input standard input ...

  5. 【BZOJ 1027】 (凸包+floyd求最小环)

    [题意] 某公司加工一种由铁.铝.锡组成的合金.他们的工作很简单.首先进口一些铁铝锡合金原材料,不同种类的原材料中铁铝锡的比重不同.然后,将每种原材料取出一定量,经过融解.混合,得到新的合金.新的合金 ...

  6. 【BZOJ 3881】【COCI 2015】Divljak

    http://www.lydsy.com/JudgeOnline/problem.php?id=3881 好难的一道题啊qwq 一开始我想对T建AC自动机,根本不可做. 正解是对S建AC自动机. fa ...

  7. sum nowcode

    时间限制:1秒 空间限制:131072K 题目描述 考虑维护一个这样的问题:(1) 给出一个数组A,标号为1~n(2) 修改数组中的一个位置.(3) 询问区间[l,r]中所有子集的位运算and之和mo ...

  8. 【数学期望】hdu5984 Pocky

    http://www.oyohyee.com/post/HDU/5984.html 看这篇吧,懒得写了. 训练时推得的式子有点鬼畜. #include<cstdio> #include&l ...

  9. 【动态规划】mr351-办签证

    [题目大意] xuzhenyi要办个签证.办证处是一座M层的大楼,1<=M<=100. 每层楼都有N个办公室,编号为1..N(1<=N<=500).每个办公室有一个签证员. 签 ...

  10. MySQL InnoDB引擎锁的总结

    为什么要锁 我们开的的各式各样系统中,系统运行需要CPU.内存.I/O.磁盘等等资源.但除了硬资源外,还有最为重要的软资源:数据. 当人们访问操作我们的系统时,其实归根是对数据的查看与生产.那么对于同 ...