安卓开发从源码看后端技术——搭建环境与断点调试

简介: 今天就让我们开启源码共读的篇章吧,希望这不同的眼界探索可以在这截然不同的领域会有所收获,为自身技术带来启发。

前言

源码阅读其实在工作中也是经常的事,但我毕竟是安卓开发,后端技术我真不是很了解,不过既然掘金提供了这么一个学习的机会,那我自然不会放过,今天就让我们开启源码共读的篇章吧,希望这不同的眼界探索可以在这截然不同的领域会有所收获,为自身技术带来启发。

正篇

本章是根据源码共读活动提供的小册学习任务学习收获而得,内容是有关Netty的,总共七块任务以及一个额外任务,本篇是完成第一个任务。

事先申明,本人从未接触过相关内容,如果在分析过程中有问题,望各位积极指正!


网络异常,图片无法展示
|

导入项目与准备工作

根据文章给出的git克隆命令:

git clone https://github.com/arthur-zhang/netty-study.git

我使用其URL地址(github.com/arthur-zhan… )在GitHub Desktop软件上获取了相应项目库


网络异常,图片无法展示
|


后面发现家中电脑中没有安装IDEA,只有Android Studio,所以还需要安装IDEA,直接官网安装社区版免费的(Download IntelliJ IDEA: The Capable & Ergonomic Java IDE by JetBrains)就可以。


网络异常,图片无法展示
|


安装好IDEA后我们打开拉到本地的项目:


网络异常,图片无法展示
|


作者很贴心的为我们分好了任务结构以及附带README.md文件方便查看任务目标,我一般选择project files(项目文件)形式的目录,我安装的IDEA默认安装了简体中文插件,有点不适应,但官方推荐就安了,安装好要重启一遍才能显示中文版


网络异常,图片无法展示
|

网络异常,图片无法展示
|


接着我们可以看到一行要求导入netty的建议在你打开MyServer.java文件时,我们确定后等待完成即可


网络异常,图片无法展示
|


全部完成我们就能进入源码阅读任务阶段了

断点调试

第一个任务是进行断点调试,这在工作中也经常使用,一般出现日志缺少或需要知道某一结构的具体运行情况时,我们通过在相应位置断点,就可以查看运行时这个区域的相应情形,甚至可以模拟数据来分析相应情况,这在我之前的文章中也提到,虽然我是使用Android Studio的,但AS也是IDEA的魔改,所以都差不多。

但本任务中是使用断点看调用堆栈,据我了解,调用堆栈可以一句一句溯源该语句运行的逻辑;


网络异常,图片无法展示
|


我们可以在MyServer文件中Ctrl+F查询“bind”(Windows系统中),然后定位到该使用语句,在该语句左侧如上图红框处点击鼠标打断点,红色圆代表该处有断点

运行查看

但netty需要服务端和客户端,这里demo是Netty echo server的,所以可以如下操作:

服务端在netty依赖添加好后运行MyServer文件即可


网络异常,图片无法展示
|


如果依赖添加中途关掉了,下次也可以自己在maven文件处右击鼠标选meavn添加好:


网络异常,图片无法展示
|
网络异常,图片无法展示
|


客户端方面,我们在windows系统上先在控制面版上打开Telnet客户端功能,接着直接Win+R,然后cmd,输入命令

telnet localhost 8888

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|


下面nc方法未成功,且作者电脑运行IDEA中突然抽风一次,自动重启了而且重启商标画面变红,有点后怕,暂时建议读者如果没有试过就不要试试,或者等评论区大佬有正确方法再尝试

客户端也可以用nc(netcat)方式,Windows系统需要先下载(netcat 1.11 for Win32/Win64 (eternallybored.org)


网络异常,图片无法展示
|

网络异常,图片无法展示
|


会触发病毒提醒,需要运行在设备上,然后执行操作,再重新下载,解压文件


网络异常,图片无法展示
|


将nc.exe 复制到C:\Windows\System32的文件夹下

作者nc方式未成功,目前原因未解决

命令类似

nc -l -p 8888

网络异常,图片无法展示
|

调试断点,分析结果

我们在main()方法出点击绿色三角形然后选择调试(debug):


网络异常,图片无法展示
|


调试完成后结果如下:


网络异常,图片无法展示
|


可以把光标对到bind代码处,然后Ctrl+单击鼠标可以跳到源码处,如果没有下载,会有提示:


网络异常,图片无法展示
|


至此我成功发现自己没找到任务要求bind的正确位置,但方法同理,我们看看要求在哪个地方断点:


网络异常,图片无法展示
|


原来是ServerSocketChannelImpl类,我们全局搜索一下,Ctrl+Shift+R,再选择最后一个范围,可以查看所有含该关键词的代码:


网络异常,图片无法展示
|


在这个类的第8个bind关键词搜索到我们任务需要的地方,再打断点 这次再调试,成功,我们找到了任务所需要的调试任务栈:


网络异常,图片无法展示
|

backlog参数分析

接下来我们看看打印的backlog参数,


网络异常,图片无法展示
|


可以看到默认为0 然后我们在源码中可以定位到unixBind和netBind方法


网络异常,图片无法展示
|

网络异常,图片无法展示
|


发现该参数小于1时会在Net.listen(...,...)方法中第二个参数转为值50。 到这里看字面意思是网络监听文件描述器,有点懵,去查了一下网上的博客,有如下解释:

backlog影响的accept队列大小

客户端把数据放到accept队列,JVM再从accept队列取。

如果accept队列太小,JVM取数据不够快,那么accept队列就会溢出 不知道靠不靠谱,又看了一下listen方法是native方法:


网络异常,图片无法展示
|


而且四处使用都一样的逻辑:


网络异常,图片无法展示
|


上述的解释有点靠谱,暂时分析到此处。

总结

这次因为包含安装和环境搭建过程,所以总用时较长,阅读源码千万不能钻牛角尖,我们可以在不清楚的地方多查查搜索引擎,看看大神博客,结合起来,才能收获更多,断点的方式也能更好的回溯我们的方法调用过程,在开发维护的时候还是很方便的,源码阅读第一次使用,在文中没有展现出来,我们其实可以从栈底部到顶部依次去看到如何跳到bind方法的:


网络异常,图片无法展示
|
如上图,我们从main方法开始向上一行行点击就能找到运行的跳转逻辑,最终到达断点处bind方法。

除此以外,肯定也有很多实用其他方法,等待我们去发现,也希望掘友们能够提出自己的使用方法,集思广益,才能更利于技术发展!

相关文章
|
4天前
|
Web App开发 JavaScript 前端开发
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念,包括事件驱动、单线程模型和模块系统;探讨其安装配置、核心模块使用、实战应用如搭建 Web 服务器、文件操作及实时通信;分析项目结构与开发流程,讨论其优势与挑战,并通过案例展示 Node.js 在实际项目中的应用,旨在帮助开发者更好地掌握这一强大工具。
19 1
|
6天前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
11天前
|
搜索推荐 Android开发 开发者
探索安卓开发中的自定义视图:打造个性化UI组件
【10月更文挑战第39天】在安卓开发的世界中,自定义视图是实现独特界面设计的关键。本文将引导你理解自定义视图的概念、创建流程,以及如何通过它们增强应用的用户体验。我们将从基础出发,逐步深入,最终让你能够自信地设计和实现专属的UI组件。
|
14天前
|
存储 SQL API
探索后端开发:构建高效API与数据库交互
【10月更文挑战第36天】在数字化时代,后端开发是连接用户界面和数据存储的桥梁。本文深入探讨如何设计高效的API以及如何实现API与数据库之间的无缝交互,确保数据的一致性和高性能。我们将从基础概念出发,逐步深入到实战技巧,为读者提供一个清晰的后端开发路线图。
|
8天前
|
JSON API 开发者
构建高效API:后端开发中的RESTful最佳实践####
在数字化时代,API作为不同系统间通信的桥梁,其重要性日益凸显。本文将深入探讨RESTful API的设计原则与最佳实践,通过实际案例分析,揭示如何构建高效、可维护且易于使用的API接口,助力后端开发者提升项目质量与用户体验。 ####
|
13天前
|
监控 API 微服务
后端技术演进:从单体架构到微服务的转变
随着互联网应用的快速增长和用户需求的不断演化,传统单体架构已难以满足现代软件开发的需求。本文深入探讨了后端技术在面对复杂系统挑战时的演进路径,重点分析了从单体架构向微服务架构转变的过程、原因及优势。通过对比分析,揭示了微服务架构如何提高系统的可扩展性、灵活性和维护效率,同时指出了实施微服务时面临的挑战和最佳实践。
34 7
|
9天前
|
JSON 缓存 API
探索后端开发中的RESTful API设计原则
【10月更文挑战第41天】在后端开发的广阔天地中,API的设计如同绘制一幅精细的地图,指引着数据的流向和前端的交互。本文将带你走进RESTful API的世界,一起探索如何用简洁高效的设计原则来构建一个清晰、可维护且易于理解的API结构。我们将从RESTful API的基础概念出发,通过实际案例分析,揭示如何在实践中应用这些设计原则,并讨论如何在复杂的业务逻辑中保持API的简洁性和一致性。
|
13天前
|
JSON 前端开发 API
后端开发中的API设计与文档编写指南####
本文探讨了后端开发中API设计的重要性,并详细阐述了如何编写高效、可维护的API接口。通过实际案例分析,文章强调了清晰的API设计对于前后端分离项目的关键作用,以及良好的文档习惯如何促进团队协作和提升开发效率。 ####
|
13天前
|
Android开发 Swift iOS开发
探索安卓与iOS开发的差异和挑战
【10月更文挑战第37天】在移动应用开发的广阔舞台上,安卓和iOS这两大操作系统扮演着主角。它们各自拥有独特的特性、优势以及面临的开发挑战。本文将深入探讨这两个平台在开发过程中的主要差异,从编程语言到用户界面设计,再到市场分布的不同影响,旨在为开发者提供一个全面的视角,帮助他们更好地理解并应对在不同平台上进行应用开发时可能遇到的难题和机遇。
|
15天前
|
存储 SQL 数据库
深入浅出后端开发之数据库优化实战
【10月更文挑战第35天】在软件开发的世界里,数据库性能直接关系到应用的响应速度和用户体验。本文将带你了解如何通过合理的索引设计、查询优化以及恰当的数据存储策略来提升数据库性能。我们将一起探索这些技巧背后的原理,并通过实际案例感受优化带来的显著效果。
31 4

热门文章

最新文章

下一篇
无影云桌面