Android的学习路线-初级到资深(Important,进阶)

本文详细介绍了自学Android技术的系统化方法,包括基础知识、技能树、学习路径和提升建议,从初级到高级工程师的各个阶段都有详尽的指导。内容涵盖了Android应用开发的核心技能,如四大组件使用、并发编程、网络编程、数据结构和算法、设计模式、框架原理、性能优化、架构模式等。此外,还提供了书籍推荐和实践技巧,帮助开发者深入理解Android框架、系统核心机制和设计模式,最终达到高级开发工程师和资深工程师的能力水平。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如何自学Android?- https://zhuanlan.zhihu.com/p/20708611

  移动技术的远景规划、技术架构选型、外部技术方案评估等工作,关注移动端架构、安全、自动化测试及移动大数据等。习惯去思考问题、总结问题并将其融会贯通。

-- 一名Android 高手必须掌握和遵循的一些准则: 
1. 学会懒惰 
2. 精通Android 体系架构、MVC、常见的设计模式、控制反转(IoC) 
3. 编写可重用、可扩展、可维护、灵活性高的代码 
4. 高效的编写高效的代码 
5. 学会至少一门服务器端开发技术

-- 1.如何系统化学习 Android 技术?(Android 知识体系) 
2.企业到底需要什么样的 Android 开发人才?(Android 市场行情) 
3.Android 学习的方式都有哪些?(Android 学习方式) 
4.对 Android 学习和提升的一些建议。(Android 提升建议) 

本篇注:只针对Android应用开发,不针对Rom开发和逆向工程等.

>  Android 研发技术进阶之路- https://mp.weixin.qq.com/s/5j0-Fgj7l39NmnNhcW31mw
- 高级工程师
1.掌握java高级特性,如JUC、线程池、NIO\BIO等;掌握jvm虚拟机知识,如内存模型、GC原理、类加载机制、线程模型等。
2.对android运行环境有深入理解,理解android沙盒机制,掌握AIDL原理及Binder通信原理,了解app和activity启动原理。
3.掌握热修复原理,各大厂商方案的优缺点。
4.对于android事件分发有深入理解,重点掌握触摸事件机制。
5.深入理解android绘制原理,理解VSYNC和surface机制和窗口原理。
6.深入理解android动画原理,包括补间动画和属性动画。
7.对于android安全机制有基本认知,理解android安全原理。
8.深入理解端上设计范式思想,如mvc\mvp\mvvm\clean-arch等。
9.理解架构演进,有良好的分层和拆分思路,掌握模块化、插件化、动态部署等。
10.对新技术敏感,理解掌握下一代架构dynamic feature等。
 至此,android 端研发你已经炉火纯青,能够面对各种情况,达到泰山崩于前而色不变的境界。如果还想继续前进,就需要突破技术栈,从更高架构层次考虑问题。

- 资深工程师
 而到了资深层次,技术栈已经不再是阻碍。能够从更高层面看待问题,理解整个系统的设计,作为系统架构师的角色存在。
 1.理解微服务、SOA思想,对于后端开发有一定涉猎。
 2.了解前端研发工具和思想,知道vue react等研发框架。
 3.深入理解跨端技术,如phonegap、weex/RN flutter、小程序快应用等。

> Android基础:(Android的知识体系/技能树)
学好 Java,安卓,并发编程、网络编程、数据结构和算法,JVM 等。
Android进阶:(Android的知识体系/技能树)
设计模式、框架原理,性能优化、架构模式,Android Framework,项目开发 等。

1> 初级工程师
  编程基础、数据结构、C语言都有一定基础,Java语法什么的也都掌握的比较好,Android才有java语言。对Android的历史、结构、代码规范等都有了一个大概的了。滑动冲突的??
  “学好Android,官方文档是必须看的,既全面又权威”。官方文档的guide和training看一遍,再者通过写博客和记笔记的方式来做总结。
技术要求: 
- 基本知识点 
  比如四大组件如何使用、如何创建Service、如何进行布局、简单的自定义View、动画等常见技术 
- 书籍推荐 

 《第一行代码 Android》、《疯狂Android》

2> 中级工程师
学习内容有:
- AIDL:熟悉AIDL,理解其工作原理,懂transact和onTransact的区别; 
- Binder:从Java层大概理解Binder的工作原理,懂Parcel对象的使用; 
- 多进程:熟练掌握多进程的运行机制,懂Messenger、Socket等; 
- 事件分发:弹性滑动、滑动冲突等; 
- 玩转View:View的绘制原理、各种自定义View; 
- 动画系列:熟悉View动画和属性动画的不同点,懂属性动画的工作原理; 
- 懂性能优化、熟悉mat等工具 
- 懂点常见的设计模式
    阅读进阶书籍,阅读Android源码,阅读官方文档并尝试自己写相关的技术文章,需要有一定技术深度和自我思考。在这个阶段的学习过程中,有2个点是比较困扰大家的,一个是阅读源码,另一个是自定义View以及滑动冲突。
    如何阅读源码呢?这是个头疼的问题,但是源码必须要读。阅读源码的时候不要深入代码细节不可自拔,要关注代码的流程并尽量挖掘出对应用层开发有用的结论。另外仔细阅读源码中对一个类或者方法的注释,在看不懂源码时,源码中的注释可以帮你更好地了解源码中的工作原理,这个过程虽然艰苦,但是别无他法。

  如何玩转自定义View呢?我的建议是不要通过学习自定义view而学习自定义view。为什么这么说呢?因为自定义view的种类太多了,各式各样的绚丽的自定义效果,如何学的玩呢!我们要透过现象看本质,更多地去关注自定义view所需的知识点,这里做如下总结: 
- 搞懂view的滑动原理 
- 搞懂如何实现弹性滑动 
- 搞懂view的滑动冲突 
- 搞懂view的measure、layout和draw 
- 然后再学习几个已有的自定义view的例子 
- 最后就可以搞定自定义view了,所谓万变不离其宗

技术要求: 
- 稍微深入的知识点 
AIDL、Messenger、Binder、多进程、动画、滑动冲突、自定义View、消息队列等 
- 书籍推荐 

《Android开发艺术探索》、《Android群英传》

3> 高级开发工程师

  细说高级程序员的几个成长阶段-http://www.codeceo.com/article/the-role-of-a-senior-developer.html

  为了成为Android资深工程师,需要学习的东西就更多了,并且有些并不是那么具体了,如下所示: 

- 继续加深理解”稍微深入的知识点“中所定义的内容 
- 了解系统核心机制: 
1. 了解SystemServer的启动过程 
2. 了解主线程的消息循环模型 
3. 了解AMS和PMS的工作原理 
4. 能够回答问题”一个应用存在多少个Window?“ 
5. 了解四大组件的大概工作流程 
6. … 
- 基本知识点的细节 
1. Activity的启动模式以及异常情况下不同Activity的表现 
2. Service的onBind和onReBind的关联 
3. onServiceDisconnected(ComponentName className)和binderDied()的区别 
4. AsyncTask在不同版本上的表现细节 
5. 线程池的细节和参数配置 
6. … 
- 熟悉设计模式,有架构意识
看书、看源码和做项目,平时多种总结,尽量将知识融会贯通从而形成一种体系化的感觉。同时这个阶段对架构是有一定要求的,架构是抽象的,但是设计模式是下设计模式的学习。关具体的,所以一定要加强于设计模式的学习,最近一本新书推荐给大家《Android 源码设计模式解析与实战》,既可以学习设计模式,又可能体会到Android源码中的设计思想,我最近也在阅读此书。
技术要求: 
- 稍微深入的知识点 
- 系统核心机制 
- 基本知识点的细节 
- 设计模式和架构 
- 书籍推荐 
《Android开发艺术探索》、《Android 源码设计模式解析与实战》、《Android内核剖析》

   高级开发人员理解并权衡领域涉及的一切,同时会思考如何去支持设计模式、库、框架和流程。

    高级开发人员不仅仅了解自我,还知晓组织和客户的工作方式和价值观,以及对于组织和客户而言成功相关的重要和不重要的因素。一旦出现问题,高级开发人员会想方设法地去解决。“这不是我的工作”——他们永远,永远也不会说这样的话语。胜任选择技术和平台.

4> 资深工程师
  这个阶段的程序员也许并没有太具体的学习路线了。

5> 架构师及领域砖家
  在某个或多个领域 能够成为这个领域的专家,比如分布式计算领域的专家,大数据领域的专家,并发领域的专家等。

> 引用:http://blog.youkuaiyun.com/wdong_love_cl/article/details/52108741      https://zhuanlan.zhihu.com/stormzhang
      资深程序员要做到能在不同抽象层之间不慌不忙,修改后,依旧确保它们各层独立,并且,懂得最合适的是哪一层,做出修改。处在薪资瓶颈期的程序员很难真正懂得这个道理,显而易见,辨别出最合适的修改位置非常重要,然而,是在底层大规模改动,还是在上层直接修改,能够确认最佳方案的程序员太少。阿文认为影响程序员薪资的点,在于辨别的境界。
    设计模式是前人对一些有共性的问题的优秀解决方案的经验总结,一个设计模式针对一类不断重复发生的问题给出了可复用的、经过了时间考验的较完善的解决方案。使用设计模式可以提高代码的可重用性、可靠性,从而大大提高开发效率.

.m-md-n1 { margin: -0.25rem !important; } .m-md-n2 { margin: -0.5rem !important; } .m-md-n3 { margin: -1rem !important; } .m-md-n4 { margin: -1.5rem !important; } .m-md-n5 { margin: -3rem !important; } .m-md-n6 { margin: -5rem !important; } .mx-md-n1 { margin-right: -0.25rem !important; margin-left: -0.25rem !important; } .mx-md-n2 { margin-right: -0.5rem !important; margin-left: -0.5rem !important; } .mx-md-n3 { margin-right: -1rem !important; margin-left: -1rem !important; } .mx-md-n4 { margin-right: -1.5rem !important; margin-left: -1.5rem !important; } .mx-md-n5 { margin-right: -3rem !important; margin-left: -3rem !important; } .mx-md-n6 { margin-right: -5rem !important; margin-left: -5rem !important; } .my-md-n1 { margin-top: -0.25rem !important; margin-bottom: -0.25rem !important; } .my-md-n2 { margin-top: -0.5rem !important; margin-bottom: -0.5rem !important; } .my-md-n3 { margin-top: -1rem !important; margin-bottom: -1rem !important; } .my-md-n4 { margin-top: -1.5rem !important; margin-bottom: -1.5rem !important; } .my-md-n5 { margin-top: -3rem !important; margin-bottom: -3rem !important; } .my-md-n6 { margin-top: -5rem !important; margin-bottom: -5rem !important; } .mt-md-n1 { margin-top: -0.25rem !important; } .mt-md-n2 { margin-top: -0.5rem !important; } .mt-md-n3 { margin-top: -1rem !important; } .mt-md-n4 { margin-top: -1.5rem !important; } .mt-md-n5 { margin-top: -3rem !important; } .mt-md-n6 { margin-top: -5rem !important; } .me-md-n1 { margin-right: -0.25rem !important; } .me-md-n2 { margin-right: -0.5rem !important; } .me-md-n3 { margin-right: -1rem !important; } .me-md-n4 { margin-right: -1.5rem !important; } .me-md-n5 { margin-right: -3rem !important; } .me-md-n6 { mar
最新发布
04-03
<think>好的,我需要帮助用户查找关于CSS负边距类(negative margin classes)的定义和用法。首先,我需要确认用户的需求是什么。他们提到了“negative margin classes”,这可能是指使用CSS类(classes)来应用负边距(margin-top, margin-right, margin-bottom, margin-left)的设置。用户可能想了解如何定义这些类,以及在实际布局中如何使用它们。 接下来,我需要回忆CSS中关于负边距的基本知识。负边距允许元素的外边距为负值,这可以影响元素的定位和周围元素的布局。例如,负边距可以让元素向左或向上移动,覆盖其他元素,或者调整容器的间距。这在某些布局技巧中很常见,比如等高列布局、垂直居中或者调整网格系统的间距。 然后,用户提到“classes”,所以需要结合类选择器的使用。通常,在CSS中,类选择器以点号开头,比如.mt-n1 { margin-top: -4px; }。负边距类可能是指预定义的一系列类,用于快速应用不同的负边距值,类似于Bootstrap等框架中的工具类。例如,Bootstrap有类似.mt-n1的类来设置负上边距。 接下来,我需要查找相关的资料。根据用户提供的引用,引用[1]提到了margin-top和margin-bottom对行内元素的影响,这可能与负边距的行为有关。引用[2]提到了CSS页面规则,可能不直接相关,但需要确认是否有关于负边距的内容。不过用户提供的引用似乎和负边距类没有直接关系,可能需要依赖其他知识。 然后,我需要组织回答的结构。首先解释负边距的基本概念,然后说明如何定义负边距类,接着举例说明用法,最后讨论注意事项和常见应用场景。同时,需要确保使用正确的中文术语,并遵循用户要求的格式,如行内数学表达式用$...$,但这里可能不涉及数学公式,所以可能不需要。不过要注意LaTeX格式的使用,如果有的话。 需要确认是否有权威资料支持负边距类的定义和使用。例如,Bootstrap的文档确实有负边距工具类,可以参考这一点。同时,W3C的CSS规范中关于margin属性的部分允许负值,这可以作为定义负边距的依据。 另外,需要注意负边距可能引起的布局问题,比如元素溢出容器导致滚动条出现,或者覆盖其他内容影响可访问性。这些应该在回答中提到,作为使用时的注意事项。 现在,将这些点整合成一个结构化的回答,确保符合用户的要求:定义、类定义方法、示例代码、使用场景、注意事项,并生成相关问题。同时,检查是否需要添加引用标识。由于用户提供的引用[1]和[2]可能与负边距不直接相关,但可能在讨论margin属性时提及,所以需要适当引用。 最后,生成相关问题,如负边距对布局的影响、在响应式设计中的应用、浏览器兼容性等。</think>### CSS负边距类的定义与使用 #### 1. 负边距的基本概念 在CSS中,负边距(Negative Margin)允许通过设置`margin-top`、`margin-right`、`margin-bottom`或`margin-left`为负值来调整元素位置。例如,`margin-left: -10px`会使元素向左移动10px,可能覆盖相邻元素或扩展父容器[^1]。 #### 2. 负边距类的定义 负边距类是通过CSS类选择器预定义的样式规则,用于快速应用负边距值。通常采用以下格式: ```css .mt-n1 { margin-top: -4px; } /* 负上边距 */ .mr-n2 { margin-right: -8px; } /* 负右边距 */ .mb-n3 { margin-bottom: -12px; } /* 负下边距 */ .ml-n4 { margin-left: -16px; } /* 负左边距 */ ``` 这里的`n1`、`n2`等通常表示间距等级(如Bootstrap框架中的设计)。 #### 3. 使用示例 ```html <div class="container"> <div class="box mt-n1">元素A(向上偏移4px)</div> <div class="box ml-n2">元素B(向左偏移8px)</div> </div> ``` 此代码中,`.mt-n1`和`.ml-n2`类分别对元素应用了负边距,改变了其默认布局位置。 #### 4. 常见应用场景 - **调整布局间距**:在网格系统中消除多余的间距。 - **视觉层叠效果**:通过负边距覆盖部分内容(如图片重叠)。 - **垂直居中**:结合`transform`或`position`实现复杂对齐。 #### 5. 注意事项 - **溢出风险**:负边距可能导致元素超出父容器边界,触发滚动条。 - **行内元素影响**:对行内元素(如`<span>`)的垂直负边距可能不会影响行高,但会改变内容位置。 - **浏览器兼容性**:需测试不同浏览器的渲染差异(尤其是旧版本IE)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值