编程漫谈(二十):如何自学编程及Java、上手真实开发及转行程序员的建议
前路漫漫,吾将上下而求索!
最近有时在知乎上逛逛,发现很多人对自学编程及转行程序员有困惑。我是在25岁读研时转程序员,正赶上好时候(中国云计算刚刚起步及移动互联网正红的阶段),同时又走了不少弯路,因此,基于自己的开发经历及思考认识(目前有八年 Java 开发经验),希望能够给后来者一些建议和参考。
本文主要面向编程初学者、大学生、初中级工程师(三年以下)。
为什么要学编程
-
编程能够有力地锻炼人的逻辑思维能力,而逻辑思考是理性思考和决策的必要件,也是思考任何问题所不可或缺的基本思维能力;
-
编程是一项集设计、发明、创造、表达于一体的很有乐趣很有挑战的职业,如果你乐于钻研事物原理、创造新事物,那就是你没错了!无论别人怎么看,我个人还是很喜欢编程的!
-
做软件开发的薪水相对较高,因为有一定门槛,需要耐心、时间、理解字符、理解逻辑,很多人可能都没法忍受天天跟字符打交道,很难忍受调试程序的枯燥(程序报错可能仅仅是一个字符没写或写错了,看到眼瞎),很难忍受软件的复杂性(现代软件通常基于大量框架、库、中间件的聚合体,出了底层问题排查会很困难异常耗时);
-
在知识经济时代,在信息化智能化越来越深入的时代,不懂编程,就像在现代文明社会里不识字一样。
何时学习编程
作为兴趣
只是对编程感兴趣,希望学会一门新技能。任何时候都不晚,哪怕 60 岁开始都没问题。
编程作为辅助技能
工作中用到,但非软件开发职业,编程只是作为辅助技能。比如科学家、数据分析师、产业编程等。推荐学习编程的理由:编程能高效提升工作效率。一些日常文本处理,懂一点编程,就能在秒级别解决大量问题,减少大量繁琐重复的工作。
转行程序员
需要慎重考虑:
- 互联网是一个适合弯道超车的行业, 也是对年轻人友好的行业;
- 国内互联网企业还是比较看重年龄的,如果年龄较高,又没有特别的建树(管理团队经验、技术牛等),就会比较被动;
- 做程序员有年龄红利。年龄越早,享受越多的红利;越晚加入,红利越少;
- 做程序员是一个可积累性不佳的职业。即使你有很丰富的经验,那些优秀应届生只要有扎实的专业基础,又善于学习和借用 Github 上的代码,善于学习新技术,是可以快速成长为后起之秀的;
- 程序员职业,是以个人的牺牲换来了行业的快速发展,以个人的可积累性差换来了行业的强积累性;
- 做程序员需要善于学习,这是最重要的能力之一;
- 做程序员需要思维缜密周全,能够考虑各种错误和异常情况,考虑可扩展性及很多质量指标,不然,写出的程序可能会漏洞百出,或者难以修改和扩展;
- 所谓的经验丰富,是指实操大型项目的经验,实操具有特殊性项目的经验,这种机遇非常难得;中小型项目开发不叫经验,因为谁都能经历。
编程开发不神秘
编程没什么神秘的。本质上,编程与写作、绘画、雕塑一样,也是一种手艺,一种探索和求解问题的方式。只不过,编程高度依赖于算法步骤的正确性和可行性,需要高度的理性。
编程如同纺织,就像编织逻辑的衣裳。
上手真实开发的建议
很多编程新手,对于项目开发有一种好奇感和神秘感。当然,没做过真实软件开发的人会有这种感觉。行外人对行内总有一种好奇感和神秘感。我对其它行业也是一样感觉好奇。
上手真实开发,难也不难。可以分为四个部分:
-
理解编程为何物。 这方面极力推荐《编程珠玑I》。可以说是编程入门的最佳读物。并不需要多少编程知识就能理解。作者循循善诱地讲解编程的基本方法、思考过程、如何使程序逐渐趋于完善。
-
学会一门编程语言,学会使用 Github。当前服务端比较主流的是 Java 语言。这方面,我写了一个工程,汇聚了在 Java 所学到的各种基础,包括数据结构与算法、设计模式等。 项目地址: [“ALLINJAVA”](https://github.com/shuqin/ALLIN)
-
学会在项目中开发。这方面,熟悉项目流程,做一遍就知道了。需要与产品沟通,理解需求,理解需要哪些数据,如何存储和组织这些数据,需要怎样的算法去处理,理解和使用 API 文档。这方面,我写了一个简单而实用的项目,项目地址: “springboot-template” 。 把这个简单项目弄明白,就能理解一个真实的项目工程了。百度网盘:https://pan.baidu.com/s/12tBjn46YSxYQzdnk7V9GJQ?pwd=v55b, 提取码: v55b 。 永久有效。
-
写出好的代码。写出好的代码,能够在技术面试中加分,对日后工作也大有裨益。这方面,我写过一本电子书:《代码修行:一步一步写出整洁的业务代码》,总结了多年开发生涯中的开发经验,书中有很多实际例子。百度网盘地址: https://pan.baidu.com/s/1w_QYkojJyCY4_G7RrFZVLA?pwd=1fvp 提取码: 1fvp 。 一个月有效。
如何自学编程
如果雷神都挡不住你要学习编程的决心和信念,那就开始吧!
学习编程语言
- 学习编程语言,几乎不需要任何必要件,3-5 岁小孩都能学会,汝何以惧之?
- 选择一门语言,比如 Java 或 Python 。如果不是急于找工作或者作为工作辅助技能,推荐 Python。因为 Python 是“著名”的简洁易学易用的编程语言。Python 的库和模块也特别多,足够胜任各种日常所需。
- 找一本好的编程书籍,在豆瓣上搜下 Java 或 Python ,选评分最高或次高的即可。
- 在寻找编程书籍时最好找两本,一本国内人写的,一个国外人写的;国内浅显,国外深入。
- 我倾向于学习国外人写的技术书籍,能教会有益的思考方式;在看不懂的时候,再找本国内的看看。
- 《C程序设计语言》 :即使你不打算学 C ,这本书也是讲述编程语言的经典之作。
- Java :《Java编程思想 》,《JAVA核心技术(卷1)》 选一,我读的是前一本。
- Python: 《Python编程》,《流畅的Python》 。
- 找一个相关的编程语言视频,边做边看。
- 编程重在实践,不写代码是学不会的。一定要大量练习编程,做到“惟手熟尔”。做到编程熟练,就具备了编程开发的最基本能力。
- 如果你正好有位朋友做程序员,可不定期请教,有个师傅引领编程是很好的。
- 学好英语,否则你能学到的编程知识永远是二手的甚至是 N 手的!
- 学会使用 word, excel, ppt 等办公处理软件。
- 这一阶段重点在学会编程的基本思想,能独立写出一个单词解析程序,就是通关成功!
编程初步进阶
-
在学会一门编程语言之后,需要学习数据结构、算法、数据库、网络、操作系统 。
-
尤其要打好数据结构和算法基础,好比编程的武器装备加成(子弹和炮弹)。如果缺乏数据结构和算法基础,就好比拿着刀剑上战场,还没走两步,就被一发炮弹轰上了天 。
-
操作系统是基础课。要能运用操作系统提供的能力,写出更实用的程序,就不能不懂操作系统 。
-
数据库是存储和操作大量数据的技术,实际项目开发中必备的基本功 。
-
网络是互联网技术的基础,不可不知,至少要理解基本原理及协议 。
-
学习顺序:数据结构及算法 => 操作系统 => 数据库 => 网络 。
-
数据结构书籍: 《数据结构与算法分析》 。
-
算法书籍: 《算法设计与分析基础》 , 《算法(第4版)》, 《算法导论》(可挑战)。
-
网络书籍:《计算机网络》 ,《TCP/IP详解 卷1:协议》 (进阶)。
-
算法刷题:当你具备一定的数据结构和算法基础,能够编写程序时,推荐到 “力扣网” 刷刷题,进行更深入的算法实践(有充足时间或挤出时间)。我到 2020 年才知道力扣的存在。
-
当你能够比较灵活使用数据结构和算法,能够理解操作系统的原理并调用系统函数,设计比较规范的数据库表,代表编程初步进阶通关成功!
Web项目
-
当你具备数据结构、算法基础和数据库设计的基础时,就可以开始尝试做 Web 项目了,正式踏入开发征程。
-
基本技术栈:后端(SpringMVC, MyBatis) + 前端 ( Javascript , jQuery ) ,可以暂时先不管底层原理,先做起来。
-
工程模板:这里有一个 Springboot 模板工程,含有一个真实项目商品交易快照项目的代码实例,你可以学习真实项目中软件是怎样子的,也可以在里面做更多的尝试和探索。要运行这个项目,运行 Application.java 即可,然后在浏览器敲入 "http://localhost:8080/" ;项目地址: “springboot-template” 。
-
如何从 Github 拉取工程代码,见: “使用git和github托管个人项目”。
-
学习基本的 git 命令: git clone, git add , git commit , git push , git merge 。
-
编程语言进阶,比如 “Effective java 中文版(第2版)” 。
-
源码阅读: 此时,你应当开始学习阅读源码。可以先阅读一些简单的类,比如 JDK 容器。为什么要阅读源码及基本技巧,可参阅 “解锁优秀源代码的基本方法与技巧” 。
-
程序调试:在开发项目时,程序调试必不可少,最简单的打断点、单步调试得学会。程序调试技能可参阅 “软件调试的基本技巧” 。
-
单测编写:学习编写单测,让代码更加可靠,《单元测试之道Java版:使用JUnit 》。
-
程序风格:学习编写好的程序必不可少。面试找工作非常看重这一点。可参阅 《Java编程风格》 , 《编写可读代码的艺术》, 《代码整洁之道》 。
-
当你能够运用数据结构、算法、数据库做出一个简单的 CRUD 管理系统时,能够编写比较规范的代码时,Web 项目阶段通关成功!
踏上征程
- 你已经能够做出一个基本的软件管理系统了,此时,你意气风发,将要向更广阔的软件开发征程出发!
- 必备网站: “Github” (学习和寻找组件实现时), “StackOverflow” (提问题找答案)。
- 学习 《深入理解计算机系统》 。
- 学习 Java 并发:《Java并发编程实战》 ;
- 学习 Java 内存模型及JVM原理: 《深入理解Java虚拟机(第2版)》 。
- 学习软件设计原则和思想,理解大型软件如何构建: “【转载】一些软件设计原则”。
- 学习设计模式,理解框架源码必备:《深入浅出设计模式(影印版)》 , 《设计模式》 。
- 学习架构初步:《架构整洁之道》 。
- 深入了解软件开发职业: “程序员工作中的理性与感性活动及所需的技能素养 ”, “软件开发思考” 。
- ALLIN:是我在学习和开发生涯中所积累的各种东西,包括数据结构、算法、设计模式、单测、具体技术等。要运行这个项目,运行 Application.java 即可,然后在浏览器敲入 "http://localhost:8080/" ;项目地址:“ALLIN” 。
- 时常膜拜一下大神: 《Coders at Work》 ,我的桌面除了背景图就只有这本书。
真实战场
- 你已经找到一份程序员工作,进入了真实战场。
- 做好分配给你的事情,做好接手的系统,同时,阅读各类技术书籍,让自己技术能力更加丰实。
- 广泛阅读各种编程相关书籍,这里有我读过的书,可以参考: “计算机专业及软件开发推荐书籍” 。
- 阅读源码,对你所用到的技术,探究其实现原理。
- 原理和设计思想是最最最精髓的东西。实用技术虽必不可少,却不可沉迷其中。切勿买椟还珠!
- 阅读 JDK 源码,阅读小型框架源码。
- 及早考一个教师资格证,给自己留条后路(我没有考虑到)。
一两年后
- 深入理解业务、从产品角度思考,能够让你有更宽阔的视野和更快的成长速度(我当时没意识到)。
- 不要怼产品,不要怼测试,不要怼运维,不要怼来怼去怼到没朋友(血的教训)。
- 做事要严谨,对人要宽容;两者不可偏废(我只做到了前者,后者做的不够好)。
- 开始写技术博客;你会发现,三五年后,只有博客上记录的东西还能记得(有益经验)。
- 制订技术研习计划,比如工作中用到的技术的原理,或者新技术,每周或每月写一篇技术博客(有计划但我没能坚持)。
- 了解软件开发攻略:“软件开发的升级打怪攻略:从新手到高级工程师”。
- 深入学习软件设计与开发:这是我关于软件设计与开发的思考:“软件设计要素初探”。
- 当你要跳槽时,不要冲动;先多征求意见,明确意愿,找到下家后再辞职(我辞职时不知道这个套路)。
三年后
- 构建自己的技术体系结构,持续丰富这个体系结构(如今我才开始做这个事情,有些晚)。
- 这是我最近构建的一个技术体系结构: “互联网应用服务端的常用技术思想与机制纲要” 。
- 努力寻找中大型项目和中大型系统实操的机遇,并提升自己的综合能力(我没有这个主动意识,才有此劝诫)。
- 敲重点: 踏实做事,但不要埋头写代码!不要埋头写代码!不要埋头写代码!(我埋头做事,才有此劝诫)。
- 试着去录制一些编程开发视频,拓展自己的技能树(我不知道还能这么玩)。
五年后
- 大量阅读源码,具备成熟系统的源码探究能力(目前正在做)。
- 寻求并主动承担大型、核心、有难度的项目或系统研发。
此去经年
- 你已经是初中级工程师了,悟空也从菩提祖师那里毕业了。
- 身边的每一个人都可能是你的导师,欣赏和学习每个人的长处。
- 拓展你的技能树,学会从一切可能的地方学习。
- 多交往,拓展自己的活动区域(我偶然参加了TMC演讲,还是有益的)。