笼统来说,中年程序员容易被淘汰的原因其实不外乎三点。
1、输出能力已到顶点。这个人奋斗十来年了,依旧碌碌无为,很明显这人的天花板就这样了,说白了,天赋就这样。
2、适应能力越来越差。年纪大,有家庭,老油条,学习能力下降,磨洋工等等。
3、性价比逐渐降低。到了35岁的年薪基本都不会低的,然而输出能力到天花板了,随着年纪的逐渐增大,性价比会越来越低。说来说去就那经典的一句话:可替代性太高。25岁的年轻人便宜且前途可期,35岁已兑现天赋价格还高,这两选谁都差不多的时候,你说企业会怎么选……任何一个当了老板的人都会选前者。而如何增加自己的不可替代性?
1.保存在内存中的图片,是否做过压缩处理再保存在内存里否则可能由于图片质量太高,导致 OOM
2.Intent 传递的数据太大,会导致页面跳转过慢。太大的数据可以通过持久化的形式传递,例如读写文件
3.频繁地操作同一个文件或者执行同一个数据库操作,是否考虑把它用静态变量或者局部变量的形式缓存在内存里。用空间换时间
4.放在主页面的控件,是否可以考虑用 ViewStub 来优化启动速度
1.build.gradle 远程依赖第三方包时,版本号建议写死,不要使用+号避免由于新版本的第三方包引入了新的问题
2.导入第三方工程时,记得把编码转换成自己工程当前是用的编码
3.调用第三方的包或者 JDK 的方法时,要跳进他们的源码,看要不要加 try-catch否则可能会导致自己应用的崩溃
4.使用第三方包时,是否加上其混淆规则若漏掉加上第三方包的混淆规则,会导致第三方包不该混淆的代码被混淆。在 Debug 版本没有发现问题,但是 Release 版本就会出现问题
5.系统应用添加 so 时,是否在固件对应的 Android.mk 文件上加入新增的 so,否则系统可能编译不过
1.系统的、自己写的,注册和反注册的方法,是否成对出现
2.在生命周期的回调里,创建和销毁的代码是否对应起来比如:onCreate() 里面创建了 Adapter,那么对应 Adapter 的退出处理操作(比如清空Image 缓存),一般就要写在 onDestory(),而不能写在 onDestoryView()。
类似的生命周期对应的代码有:onStart()、onStop();onCreate()、onDestory();onResume()、onPause();onCreateView()、onDestoryView()
3.若 ListView 的 item 复用了,对 Item 里 View 的操作是否成对出现比如:
比如以上对 mTitleView、mGreenLabelView 和 mRedLabelView 的操作,都是成对出现。否则 ListView 可能会由于 Item 复用,导致 Item 显示错乱问题
1.内部类,比如 Handler、Listener、Callback 是否是成 static class因为非静态内部类会持有外部类的引用。
2.假如子线程持有了 Activity,要用弱引用来持有比如 Request 的 Activity 就应该用弱引用的形式,防止内存泄漏。
3.要求传入 Activity 作为参数的函数,是否可以改用 getApplicationContext() 来作为参数
1.使用 View.post() 是否会有问题因为在 View 处于 detached 状态期间,post() 里面的 Runnable 是不会被执行的。只有在此 View 处于 attached 状态时才会被执行。
如果想改 Runnable 每次肯定会被执行,那么应该是用 Handler.post 来替代
2.假如程序可能多次在同一个 Handler 里 post 同一个 Runnable,每次 post 之前都应该先清空这个 Handler 中还没执行的该 Runnable如:
1.多思考某些情况下,某变量是否会为空而且在函数体内,处理参数前,必须加上判空语句
2.回调函数是否处理好回调函数很容易出问题。比如网络请求的回调,需要判断此时的 Aciivity 等是否还存在,再进行调用。因为异步操作回来,Activity 可能就消失不存在了。而且还要对一些可能被回收的变量进行判空。
3.修改数据库后,是否把数据库的版本号+1
4.启动第三方的 Activity 时,是否判断了该 Intent 能否被解析
若 Activity 不存在,会出现 ActivityNotFoundException 的异常
5.新注册的 Activity、Service 或 Provider,若 AndroidManifest.xml 中 exported 属性为 true,要考虑是否会引发安全性问题
因为 exported 属性为 true 时,外部应用就可以直接调用起该 Activity。可能导致的问题:1)若外部应用直接启动详情页,从而让某些验证页面直接被绕过2)若外部应用给该 Activity 传递乱七八糟的 Intent,可能让该应用崩溃。也就是 Android中的拒绝服务漏洞
5.除数是否做了非 0 判断
6.不要在 Activity 的 onCreate 里调用 PopupWindow 的 showAsLoaction 方法,由于Activity 还没被加载完,会报错
一转眼时间真的过的飞快。我们各奔东西,也各自踏上了自己的旅途,但是即使多年不见,也因为这份情谊我们依旧如从前那般“亲密”。不忘初心方得始终。加油吧,程序员们,在我看来35岁,40岁从来不是危机,只要永远不要忘记自己为何踏上征程!
为了让更多在学习中或者最近要准备面试的朋友们看到这篇文章,希望你们能多多评论,点赞+转发!
再次感谢所有给我提供过题目的朋友们,感谢一路有你!
做了6年Android开发,这个回答让我错失offer!含BATJM大厂
原文:https://www.cnblogs.com/dhsfdhfhgufdu/p/15209908.html