一个程序员的 2015年 的学习总结

程序人生 · lvjian700 · 于 发布 · 最后由 lvjian700回复 · 1825 次阅读
30

Reading

又是一年的年终,时间依然如同往年一样匆匆的流逝,为了让自己觉得今年并没有虚度,本文将回顾以下自己作为一个程序员在今年的成长。做一个学习总结,给 2015 画上一个句号。

读书

博客

今年博客从 JavaEye 迁移到简书。从此终于可以舒服的用 markdown 编写博客。

由于去年总是希望一次写一篇完整的 blog,导致去年可怜的只写了一篇博客。今年采用KISS的方式写博客,小的idea写短博客,大的idea写长一些的。随着时间推移不断重构博客内容,这样负担不会太重。

按照KISS原则,今年一共写了 19 篇博客:
http://www.jianshu.com/users/MjqJJb/latest_articles

敏捷实践

自从在国内项目中打拼以来,一直有一个愿景:

『不仅高效的交付高质量的软件,而且还要交付一种高效的工作方式』

今年终于在为 Lenovo 做项目的时候,达成了个这个成就。不但成功交付超高质量的软件,而且帮助客户进行了敏捷团队改造。

在于传统企业管理模式和瀑布流开发方式的碰撞的过程中,保持敏捷团队的优势,并且让敏捷跟传统企业的 Water-Fall, KPI 进行了融合。在 Lenovo 和卓越的小伙伴们共同打造了务实的敏捷团队实践: Water-Scrum-Fall

对这部分内容现在只写了一篇博客,2016 年还会继续总结:

Sessions

  • 卓有成效的程序员
  • Agile in Practice
  • How to encapsulate UI in OOP way
  • Not only OOP in ruby
  • iOS consulting Q&A session

Workshop

  • How to create a iOS app

Ruby

终于在正式项目中使用 Ruby。Ruby 水平直线提升, Ruby 已经成为我的首要编程语言之一。曾经渴望使用的 Rails, 今年也有幸参与 Rails 的项目。

基于 RSpec 的 TDD/BDD 在今年有质的提升。以前习惯于从底层向上层慢慢构建代码,TDD 属于 classic 方式,less mock,下半年开始尝试 mockist 方式写测试,尝试从上层向下层写代码。在按照从上向下 TDD 的时候,之前困惑的如何使用 test 定义 scope 的问题迎刃而解。

写过的与 Ruby 相关的博客:

Eclipse Plugin

Eclipse 是我工作前 5 年中,以及学生时期主要的开发工具,今年有幸做了 eclipse plugin 开发的项目,回想起来非常激动,也终于实现了当年为 eclipse 写 plugin 的愿望。

eclipse 背后的 OSGi 扩展性非常强大,eclipse 犹如 GUI 时代的 Emacs, 此部分掌握的内容涉及:

  • eclipse plugin CI/CD
  • OSGi
  • eclipse SWT/JFace SDK

写了两篇关于 eclipse 的博客

iOS Development

虽然今年没有参与 iOS 项目,但是整理出了《iOS中RSA加密解密算法的使用》

整理出了 iOS TDD Sample,内容包括:

  • ObjC TDD: Objective C, OCHamcrest, OCMockito
  • Swift TDD: Quick
  • UI Test: Appium 和 RSpec 两个方案

iOS TDD repository 地址: https://github.com/lvjian700/ios-tdd-samples

Javascript

  • 一直不想使用 Angular.js, 但是今年有机会在项目中尝试 Angular.js。 以TDD的方式写js, Angular.js 的组织方式的确很赞
  • 使用 gulp.js 搭建 front-end 基本 CI pipeline
  • coffeescript, 刚开始使用感觉很赞,尤其配合 node.js 使用。虽然语法非常简洁,但是个人还是比较喜欢直接用javascript
  • 尝试使用 Zombie.js 进行 Font-End UI test, 这个框架很轻量级,但是不适合大量的Ajax应用
  • 在项目中尝试使用 ES6, template string 和 class 都非常好用,但是项目原因没有继续使用ES6

编写了2篇博客:

UX and Mobile design

Mobile design 是今年获得的重要技能之一。花了一个月的学习了 https://designcode.io/ Design part。 现在已经基本掌握 iOS UI Design 方面的技巧。

由于 get 了这个技能,让我在思考如何将 idea 转换为 product 有了新的思路。当脑袋迸发出一个新 idea 时,不再是从 tech 角度思考问题,而是从 design 的角度考虑,这样的思路更能贴近真实的用户场景。

新的思路

  • 一句话描述 idea
  • 构建用户故事,发现故事中主人公的痛点
  • 使用 design 的手段验证想法
  • 最后是实现(以前始终从实现角度出发, 先想我要用 xxx 技术)

编写一篇关于 design 的博客

在公司组织的hack中,尝试使用新技能分析 idea 和 design app

  • Survive in China
  • Micro services Wall

icons模仿练习:

Icons

Survive in China App:

Servive in China

DevOps

以前在 DevOps 方面知识几乎为零。今年开始涉及 AWS 和 Docker 容器化技术。 AWS 和 Docker是今年 get 的重要技能之一。

  • AWS: EC2 instance, S3, CloudFormation, Route53, LoadBalance, AutoScalingGroup, AWS RDS
  • Docker: docker, docker-compose
  • 使用 Splunk 查询日志
  • 使用 Bamboo 搭建 CI, 终于抛弃了刀耕火种的 Jenkins

写了 3 篇关于 Docker 入门的文章

Microservices architecture

Microservices 也是今年获得的重要技能之一。从下半年开始参与基于Microservices 架构的项目,这个项目帮助客户进行老系统改造。按照Microservices对老系统进行拆分,centralize 各种服务,数据。

从下半年开始,基本跟 UI 说拜拜了,每天都在跟 JSON API,部署打交道。

由于项目属于客户核心 API, 项目对代码和设计质量要求非常高。这种高要求带来很大的挑战,也引出了很多知识:

  • 更多的考虑 REST-ful API 设计,开始使用 HAL + JSON 这种 self discoverable 的 JSON 数据格式。
  • 接触 CQRS 读写分离的架构方式,采用 CQRS 可以将 API 中的写入和读取分别优化,但是副作用很大,只适合很少的场景。
  • 由于 Microservices 架构推荐拆小的 API services, 这个对 DevOps 是非常大的挑战,今年 AWS 和 DevOps 经验大幅提升.
  • Microservices 间的集成测试也是一个挑战,目前采用Consumer Driven Contracts的方式,使用 Unit Test代替 Integration Test

这部分总结大多保存在个人的 evernote 中,由于涉及客户的内容,暂时发布2篇博客:

总结

纵观今年的成长,和去年一样依然涉猎了很多方面的内容。今年成功的步入了Ruby Programmer,也算是达成了这些年的希望达到的成就。

在 Ruby 团队中有幸跟当前 2012 RubyConfChina 讲师 FredWu 共事(Slim 作者之一),这也是今年非常大的惊喜。

技术方面通过 Microservices architecture 让我更多的思考架构和 DevOps 方面的东西。这让我意识到软件开发并不只是 Development, Ops 也是非常重要的环节,自动化 Ops 可以节省开发人员的生命,没有全方位的自动化工具的支持,Microservices 会进行的非常痛苦。DevOps 和 Microservices architecture 会是2016需要持续积累的方面。

自从加入ThoughtWorks 两年以来,终于达成了打造敏捷团队的成就。

团队管理,开发流程,如何同软件开发一样都没有银弹。『拥抱变化』应该永恒的目标,在项目的演进中需要及时改进团队,需要持续关注团队成员提升。

人始终是团队中最有价值的部分,关注人,关注沟通,拥抱变化,轻流程和制度,这样可以让每个人都发挥最大的优势。

虽然今年计划专注于 mobile 方面,但是计划不如变化。不过在 mobile 方面也收获了 TDD 和 Mobile Design的能力。

我们常讲软件开发需要拥抱变化,个人成长也需要拥抱变化。 今年跳出了舒适区,步入了纯英文环境的团队,这对我来说是一个非常大的挑战。现在正在享受这种挑战,当然挑战背后带来的是飞速成长。

再见2015。在新的一年持续拥抱挑战,继续不断的挑战舒适区,继续享受成长的快乐。


「软件匠艺社区」旨在传播匠艺精神,通过分享好的「工作方式」和「习惯」以帮助程序员更加快乐高效地编程。
本帖已被设为精华帖!
共收到 10 条回复
178
sam_su · #1 ·

帮顶下。
自己也曾经参与过一个漫长的Eclipse plugin的项目,所以对于LZ那两篇plugin dev的博客还是很有共鸣的
不过关于pde的开发建议好像遗漏了plugin spy这个神器?

另外,CI我们还是基于maven+jenkins,原来tw已经转投Bamboo了?差距呐~

171
aaron · #2 ·

https://designcode.io/ 那个看起来不错,楼主是买了那本书了吗?感觉怎么样?

30

#2楼 @aaron 恩,买的。 非常超值。附带Ember.app 和 Sketch 3 的优惠码,很划算。虽然书是45$, 但是加上软件的折扣,书算下来可能只有10$。

内容非常赞,我觉得学习iOS开发,就应该从这个教程开始。

在iOS上面实现UI对于iOS Dev不是难事,如何设计一个好的App。如何从设计的角度出发,从设计到实现。我估计只有这本书将整个流程都教到了。

除了文字内容,教程包含了大量的视频教程和Sample Code。而且Sample Code质量极高,基本是一个完整的App。

除了教程的内容之外,购买教程之后会加入作者的邮件订阅列表。定期会收到非常优秀的设计资源。

Facebook上有一个design+code group,购买教程的学员都会在这里交流,每当我看到学员设计的东西,都会感到震惊。

P.S
这个教程将我带入了另一个世界,如果对设计感兴趣,对交互体验感兴趣,可以试试,45$ 一个好耳机都买不了,但有可能将你带入另一个世界。想想应该蛮值得 :)

30
lvjian700 · #4 ·

#1楼 @sam_su cool ! 当时做 eclipse plugin 的时候,也是用的 Jenkins + maven。Bamboo 有些项目用(客户土豪),有些项目也会用 Jenkins 。 Bamboo 用起来比较省事儿,Jenkins 刀耕火种的需要自己搭。不过CI 一般搭一次,以后基本不怎么动了。

BTW,plugin spy 好像没用过。 = =|

1
hkliya · #5 ·

#3楼 @lvjian700 我也买了 design code 的,结果一直没开始学,计划全都跑偏了。

171
aaron · #6 ·

@lvjian700 多谢介绍,最近在写自己的一个app,深刻觉得设计能力不足,那我也买来看看。虽然现在贵了5刀,多谢推荐:)

96
shane51 · #7 ·

专程注册账户过来赞下,希望今年能像lvjian同学一样迈入Ruby programmer的行列

30
lvjian700 · #8 ·

#7楼 @shane51 cool! 加油。

469
111ibm111 · #9 ·

请问后台程序员怎样才能快速上手AngularJS,许多资料根本都不涉及所mvc部分

30

#9楼 @111ibm111 按照我对AngularJS上手经验来说,AngularJS 首页的 sample 上手基本了。
从架构方式来说,AngularJS 基本是按照后端程序员来涉及的。如果你熟悉 Java 中的 Spring,熟悉 AOP,会非常容易上手 Angular.js。

对于Angular.js 推荐一本书 《Angular.js 深度剖析与最佳实践》:https://read.douban.com/reader/ebook/17826372/
我有幸跟本书作者之一 @asnowwolf 共事过,对 Angular.js 的了解也是从那时候开始。

回到问题,Angular.js MVC

angular.js 中的 MVC 还是很明显的:

以 BeerCounter sample 为例子:

Controller

angular.module('app', ['components'])
.controller('BeerCounter', function($scope, $locale) {
});

Model

angular.module('app', ['components'])
.controller('BeerCounter', function($scope, $locale) {
  $scope.beers = [0, 1, 2, 3, 4, 5, 6];
});

View

<div ng-controller="BeerCounter">
    <div ng-repeat="beerCount in beers">
        <ng-pluralize count="beerCount" when="beerForms"></ng-pluralize>
    </div>
</div>

Angular.js 特色不仅是 MVC

  • 双向绑定
  • 模块化 js 代码
需要 登录 后回复方可回复, 如果你还没有账号你可以 注册 一个帐号。