标签:hadoop 电视 springmvc 对象 编辑 编译 否则 文件 java初学者
由 此也可以看出,这些学习的过程是环环相扣的,如果你任何一个阶段拉下来了,那么你就真的跟不上了,或者说是一步慢步步慢。而且我很负责
的告诉你,我在这个 阶段的时候,所学习的东西远多于这里所罗列出来的。因此千万不要觉得你已经学的很多了,我所说的这些都只是最低要求,
不光是我,很多人在这个时间段所学习 的内容都远超本文的范围。 如果你不能跟上节奏的话,若干年后,如果不是程序猿市场还不错的话,你很可能
不仅仅是工资比别人低,公司没别人好,而是根本就找不到工作。 总而言之,这个阶段,你需要做的是深入了解Java底层和Java类库(比如并发那本
书就是Java并发包java.concurrent的内容),也就是JVM和JDK的相关内容。而且还要更深入的去了解你所使用的框架,方式比较推荐看源码或者看
官方文档。 另外,还有一种学习的方式,在2年这个阶段,也应该启用了,那就是造轮子。 不要听信那套“不要重复造轮子”的论调,那是公司为了节省
时间成本编造出来的。重复造轮子或许对别人没有价值,因为你造的轮子可能早就有了,而且一般情况下你造出来的轮子还没有现存的好。但是对别人
没有价值,不代表对你自己没有价值。 一个造轮子的过程,是一个从无到有的过程。这个过程可以对你进行系统的锻炼,它不仅考察你的编码能力,还
考察你的框架设计能力,你需要让你的轮子拥有足够好的扩展性、健壮性。 而且在造轮子的过程中,你会遇到各种各样的难题,这些难题往往又是你学
习的契机。当你把轮子造好的时候,你一定会发现,其实你自己收获了很多。 所以,这个阶段,除了上面提到的了解JVM、JDK和框架源码以外,也请
你根据别人优秀的源码,去造一个任何你能够想象出来的轮子。
第四部分:参加工作3年到4年的同学 这个阶段的同学,提升已经是很难了,而且这个阶段的学习往往会比较多样化。 因为在前3年的过程中,你肯定
或多或少接触过一些其它的技术,比如大数据、分布式缓存、分布式消息服务、分布式计算、软负载均衡等等。这些技术,你能精通任何一项,都将
是你未来面试时巨大的优势,因此如果你对某一项技术感兴趣的话,这个时候可以深入去研究一下。这项技术不一定是你工作所用到的,但一定是相
关的。 而且在研究一门新技术时,切忌朝三暮四。有的同学今天去整整大数据,搞搞Hadoop、hbase一类的东西。过不了一段时间,就觉得没意思,
又去研究分布式缓存,比如redis。然后又过不了一段时间,又去研究分布式计算,比如整整Mapreduce或者storm。 结果到最后,搞得自己好像什么都
会一样,在简历上大言不惭的写上大数据、分布式缓存、分布式计算都了解,其实任何一个都只是浮于表面。到时候面试官随便一问,就把你给识破了。
一定要记住,作为一个程序猿,平日里所接触的技术可能会很多,但是想要让一门技术成为你的优势,那么一定是你对这门技术的了解强过绝大多数人
才行。 因此在这个阶段,你就不能再简单的去学习前3年的内容了,虽然前面的学习如果还不够深入的话依旧要继续,但这个时候你应该更多的考虑建立
你的优势,也可以称为差异性。 差异性相信不难理解,就是让你自己变得与众不同。你前面三年的学习足够你成为一名基本合格的Java开发者,但你离成
为一名优秀的Java开发者还有很大的距离。 所 谓优秀,即能别人所不能。而你前三年所学习的内容,是很多做过几年的Java开发都能够掌握的。那么为了
让自己有差异性,你就需要另辟蹊径,找一个方向深 入研究下去,以期在将来,你能够成为这个领域的专家,比如分布式计算领域的专家,大数据领域的
专家,并发领域的专家等等。 此 外,你除了建立你的差异性之外,还要去弥补你基础上的不足,直到现在,我都没有提及基础知识。原因是基础是很枯燥
无味的,学的太早不仅容易懵逼,而且懵逼 的同时还容易产生心理阴影,以至于以后再不想去研究这些基础。但基础又是你深入研究一些领域时所必须掌
握的,比如你去研究分布式计算,你不懂算法你玩个毛 毛?比如你去做分布式缓存,你对计算机系统的内存不了解,你如何去做缓存? 如果你的基础本来
就非常强,那么恭喜你,相信你在之前的工作中已经充分体会到了这些基础对你的帮助。但我相信大部分人的基础都很薄弱,哪怕是科班毕业的人,很多人
也不敢说自己当初的基础学的多么强大,比如算法、计算机系统原理、编译原理这些。 但是每个人时间都是有限的,而且这些基础的书籍每一本读下来,没
个一年半载的,还真拿不下来,因此还是要有所抉择的。虽然艺多不压身,但问题是艺多是有代价的,是需要你付出时间和精力的,而我个人更赞成在同等
代价的情况下获取最大的收获。 首先,我比较推崇的基础书籍有三本,分别是《深入理解计算机系统》,《tcp/ip详解 卷一、二、三》,《数据结构与算法》。
其中TCP/IP有三本书,但我们这里把这三本看成是一本大书。 这三本分别适合三种人,《深入理解计算机系统》比较适合一直从事Java Web开发和APP后端
开发工作的人群。《tcp/ip详解 卷一、二、三》比较适合做网络编程的人群,比如你使用netty去开发的话,那么就要对TCP/IP有更深入的了解。而《数据结构
与算法》这本书,则比较适合做计算研究工作的人,比如刚才提到的分布式计算。 另外,我要强调的是,这里所说的适合,并不是其它两本对你就没有用。
比如你做Java Web和APP后端开发,《tcp/ip详解 卷一、二、三》这本书对你的作用也是很大的。这里只是分出个主次关系而已,你要是时间足够的话,
能把三本都精读那当然最好不过了。但如果时间有限的话,那么就先挑对你帮助最大的书去读。 理论上来讲,这一年你能把这三本其中一本精读下来,
就已经非常厉害了。有了基础,有了前面的工作经验,你就可以去开拓属于你的领域了。 在这一年里,一定要规划好自己的领域,建立好自己的优势,
制造出差异性。如果你对自己的领域不够清晰的话,随着你工作的时间日益增多,你接触的技术会越来越多,这个时候,你很容易被淹死在技术的海洋
里,看似接触的技术越来越多,会用的也越来越多,但你毫无优势。 有的同学可能会问,“我,我也不知道我的领域是什么啊?怎么办呢?” 对于这种人,
我只想说,“卧槽,这还问我?要不干脆我替你学习得了,好不好?”
第五部分:参加工作4年到5年的同学 经过前面一年的历练,相信你在自己所钻研的领域已经有了自己一定的见解,这个时候,技术上你应该已经遇到瓶颈了。
这个时候不要着急提高自己的技术,已经是时候提高你的影响力了,你可以尝试去一些知名的公司去提高你的背景,你可以发表一些文章去影响更多的人。
当然,你也可以去Github创建一个属于你的开源项目,去打造自己的产品。这次的开源项目不同于之前的造轮子,你这个时候是真的要去尽量尝试造出来真
正对别人有价值的轮子。 技术学到这个阶段,很容易遇到瓶颈,而且往往达到一定程度后,你再深入下去的收效就真的微乎其微了,除非你是专门搞学术研
究的。然而很可惜,大部分程序猿做不到这一步,那是科学家做的事情。 这个时候提高影响力不仅仅是因为技术上容易遇到瓶颈,更多的是影响力可以给你
创造更多的机会。程序猿在某种程度上和明星很像,一个好的电视剧和电影就可以成就一批明星,程序猿有的时候也是,一个好的项目就可以成就一群程序猿
。 比如国内几个脍炙人口的项目,像淘宝、支付宝、QQ、百度、微信等等。这每一个项目,都成就了一批程序猿。我敢说,这里面任何一个项目,如果你是
它的核心开发,光是这样一个Title,就已经是你非常大的优势。更何况还不止如此,Title说到底也是个名头,更重要的是,这种项目在做的时候,对你的历练
一定也是非常给力的。 而你如果想要参与这样的项目,除了靠运气之外,影响力也是很重要的一个手段。比如你在分布式计算领域有一定的影响力,那么如果
有什么好的关于分布式计算的项目,对方就很可能会邀请你。就算人家不邀请你,你自己主动去面试的时候,对方如果知道你在这个领域的影响力,也肯定会
起到很大的作用,而这个作用,甚至可能会超过你现在的技术能力。 所以,在这个阶段,你最大的任务是提高自己的影响力,为自己未来的十年工作生涯那一天
做准备。如果你能够靠你的影响力和以前积累的技术,参与到一个伟大的项目当中,那么你后面的五年也就有着落了。 当然了,我现在满打满算,做程序猿也就
4年半不到,因此关于4年到5年这一部分,我的见解不一定是对的,就算是对的,也不一定是适合任何人的。所以,希望大家自己有的判断力,去决定到底该如何
度过这一年。
作者:头条号 / 中华影生
标签:hadoop 电视 springmvc 对象 编辑 编译 否则 文件 java初学者
原文地址:https://www.cnblogs.com/beyondcj/p/9040722.html