mirror of
https://github.com/phodal/github
synced 2026-05-22 00:29:47 +00:00
统一规范,在中英文,数字和中文之间添加空格
This commit is contained in:
parent
a2c55f5590
commit
929410e3ea
15 changed files with 334 additions and 334 deletions
62
README.md
62
README.md
|
|
@ -4,21 +4,21 @@
|
|||
|
||||
在线阅读:[GitHub 漫游指南](http://github.phodal.com/),下载:[pdf](https://github.com/phodal/github-roam/raw/gh-pages/github-roam.pdf)、[mobi](https://github.com/phodal/github-roam/raw/gh-pages/github-roam.mobi)、[epub](https://github.com/phodal/github-roam/raw/gh-pages/github-roam.epub)
|
||||
|
||||
2014年,写了《[一步步搭建物联网系统](https://github.com/phodal/designiot)》(电子书)。
|
||||
2014 年,写了《[一步步搭建物联网系统](https://github.com/phodal/designiot)》(电子书)。
|
||||
|
||||
2015.3.9号,想着写个《[GitHub漫游指南](http://github.phodal.com/)》,于是在最开始的地方写着:
|
||||
2015.3.9 号,想着写个《[GitHub 漫游指南](http://github.phodal.com/)》,于是在最开始的地方写着:
|
||||
|
||||
> 我的GitHub主页上写着加入的时间——``Joined on Nov 8, 2010``,那时才大一。在那之后的日子里,也许是因为我学的不是计算机的关系,并没有熟练使用它。到了今天——``2015.3.9``,我发现GitHub是程序员的社交网站。
|
||||
> 我的 GitHub 主页上写着加入的时间——``Joined on Nov 8, 2010``,那时才大一。在那之后的日子里,也许是因为我学的不是计算机的关系,并没有熟练使用它。到了今天——``2015.3.9``,我发现 GitHub 是程序员的社交网站。
|
||||
|
||||
但是过了很久都没有动静,今天是2015.10.24,我想是时候完成这个目标了。
|
||||
但是过了很久都没有动静,今天是 2015.10.24,我想是时候完成这个目标了。
|
||||
|
||||
## 目录
|
||||
|
||||
* [前言](http://github.phodal.com/#前言)
|
||||
* [我与GitHub的故事](http://github.phodal.com/#我与github的故事)
|
||||
* [GitHub与收获](http://github.phodal.com/#github与收获)
|
||||
* [GitHub与成长](http://github.phodal.com/#github与成长)
|
||||
* [为什么你应该深入GitHub](http://github.phodal.com/#为什么你应该深入github)
|
||||
* [我与 GitHub 的故事](http://github.phodal.com/#我与github的故事)
|
||||
* [GitHub 与收获](http://github.phodal.com/#github与收获)
|
||||
* [GitHub 与成长](http://github.phodal.com/#github与成长)
|
||||
* [为什么你应该深入 GitHub](http://github.phodal.com/#为什么你应该深入github)
|
||||
* [方便工作](http://github.phodal.com/#方便工作)
|
||||
* [获得一份工作](http://github.phodal.com/#获得一份工作)
|
||||
* [扩大交际](http://github.phodal.com/#扩大交际)
|
||||
|
|
@ -26,19 +26,19 @@
|
|||
* [取一个好的名字](http://github.phodal.com/#取一个好的名字)
|
||||
* [挑选好 LICENSE](http://github.phodal.com/#挑选好-license)
|
||||
* [官方主页](http://github.phodal.com/#官方主页)
|
||||
* [Git基本知识与GitHub使用](http://github.phodal.com/#git基本知识与github使用)
|
||||
* [Git 基本知识与 GitHub 使用](http://github.phodal.com/#git基本知识与github使用)
|
||||
* [Git](http://github.phodal.com/#git)
|
||||
* [Git初入](http://github.phodal.com/#git初入)
|
||||
* [GitHub](http://github.phodal.com/#github)
|
||||
* [版本管理与软件部署](http://github.phodal.com/#版本管理与软件部署)
|
||||
* [GitHub与Git](http://github.phodal.com/#github与git)
|
||||
* [在GitHub创建项目](http://github.phodal.com/#在github创建项目)
|
||||
* [GitHub流行项目分析](http://github.phodal.com/#github流行项目分析)
|
||||
* [GitHub 流行项目分析](http://github.phodal.com/#github流行项目分析)
|
||||
* [Pull Request](http://github.phodal.com/#pull-request)
|
||||
* [我的第一个PR](http://github.phodal.com/#我的第一个pr)
|
||||
* [CLA](http://github.phodal.com/#cla)
|
||||
* [构建GitHub项目](http://github.phodal.com/#构建github项目)
|
||||
* [如何用好GitHub](http://github.phodal.com/#如何用好github)
|
||||
* [构建 GitHub 项目](http://github.phodal.com/#构建github项目)
|
||||
* [如何用好 GitHub](http://github.phodal.com/#如何用好github)
|
||||
* [敏捷软件开发](http://github.phodal.com/#敏捷软件开发)
|
||||
* [测试](http://github.phodal.com/#测试)
|
||||
* [CI](http://github.phodal.com/#ci)
|
||||
|
|
@ -62,9 +62,9 @@
|
|||
* [可用示例](http://github.phodal.com/#可用示例)
|
||||
* [改善 GitHub 项目代码质量:重构](http://github.phodal.com/#改善-github-项目代码质量重构)
|
||||
* [为什么重构?](http://github.phodal.com/#为什么重构)
|
||||
* [重构uMarkdown](http://github.phodal.com/#重构umarkdown)
|
||||
* [重构 uMarkdown](http://github.phodal.com/#重构umarkdown)
|
||||
* [代码说明](http://github.phodal.com/#代码说明)
|
||||
* [Intellij Idea重构](http://github.phodal.com/#intellij-idea重构)
|
||||
* [Intellij Idea 重构](http://github.phodal.com/#intellij-idea重构)
|
||||
* [Rename](http://github.phodal.com/#rename)
|
||||
* [Extract Method](http://github.phodal.com/#extract-method)
|
||||
* [Inline Method](http://github.phodal.com/#inline-method)
|
||||
|
|
@ -86,7 +86,7 @@
|
|||
* [这个项目做什么——一句话文案](http://github.phodal.com/#这个项目做什么一句话文案)
|
||||
* [它解决了什么问题](http://github.phodal.com/#它解决了什么问题)
|
||||
* [它有什么特性](http://github.phodal.com/#它有什么特性)
|
||||
* [安装及hello, world 示例](http://github.phodal.com/#安装及hello-world-示例)
|
||||
* [安装及 hello,world 示例](http://github.phodal.com/#安装及hello-world-示例)
|
||||
* [技术文档](http://github.phodal.com/#技术文档)
|
||||
* [技术文档](http://github.phodal.com/#技术文档-1)
|
||||
* [更多的示例程序](http://github.phodal.com/#更多的示例程序)
|
||||
|
|
@ -95,21 +95,21 @@
|
|||
* [开源项目维护](http://github.phodal.com/#开源项目维护)
|
||||
* [Release](http://github.phodal.com/#release)
|
||||
* [Git 工具推荐](http://github.phodal.com/#git-工具推荐)
|
||||
* [GitHub用户分析](http://github.phodal.com/#github用户分析)
|
||||
* [GitHub 用户分析](http://github.phodal.com/#github用户分析)
|
||||
* [生成图表](http://github.phodal.com/#生成图表)
|
||||
* [数据解析](http://github.phodal.com/#数据解析)
|
||||
* [Matplotlib](http://github.phodal.com/#matplotlib)
|
||||
* [每周分析](http://github.phodal.com/#每周分析)
|
||||
* [Python GitHub 每周情况分析](http://github.phodal.com/#python-github-每周情况分析)
|
||||
* [Python 数据分析](http://github.phodal.com/#python-数据分析)
|
||||
* [Python Matplotlib图表](http://github.phodal.com/#python-matplotlib图表)
|
||||
* [Python Matplotlib 图表](http://github.phodal.com/#python-matplotlib图表)
|
||||
* [存储到数据库中](http://github.phodal.com/#存储到数据库中)
|
||||
* [SQLite3](http://github.phodal.com/#sqlite3)
|
||||
* [数据导入](http://github.phodal.com/#数据导入)
|
||||
* [Redis](http://github.phodal.com/#redis)
|
||||
* [邻近算法与相似用户](http://github.phodal.com/#邻近算法与相似用户)
|
||||
* [如何在GitHub“寻找灵感(fork)”](http://github.phodal.com/#如何在github寻找灵感fork)
|
||||
* [Lettuce构建过程](http://github.phodal.com/#lettuce构建过程)
|
||||
* [如何在 GitHub “寻找灵感(fork)”](http://github.phodal.com/#如何在github寻找灵感fork)
|
||||
* [Lettuce 构建过程](http://github.phodal.com/#lettuce构建过程)
|
||||
* [需求](http://github.phodal.com/#需求)
|
||||
* [计划](http://github.phodal.com/#计划)
|
||||
* [实现第一个需求](http://github.phodal.com/#实现第一个需求)
|
||||
|
|
@ -117,31 +117,31 @@
|
|||
* [如何以“正确的姿势”阅读开源软件代码](http://github.phodal.com/#如何以正确的姿势阅读开源软件代码)
|
||||
* [阅读过程](http://github.phodal.com/#阅读过程)
|
||||
* [示例](http://github.phodal.com/#示例)
|
||||
* [GitHub连击](http://github.phodal.com/#github连击)
|
||||
* [100天](http://github.phodal.com/#天)
|
||||
* [40天的提升](http://github.phodal.com/#天的提升)
|
||||
* [100天的挑战](http://github.phodal.com/#天的挑战)
|
||||
* [140天的希冀](http://github.phodal.com/#天的希冀)
|
||||
* [200天的Showcase](http://github.phodal.com/#天的showcase)
|
||||
* [GitHub 连击](http://github.phodal.com/#github连击)
|
||||
* [100 天](http://github.phodal.com/#天)
|
||||
* [40 天的提升](http://github.phodal.com/#天的提升)
|
||||
* [100 天的挑战](http://github.phodal.com/#天的挑战)
|
||||
* [140 天的希冀](http://github.phodal.com/#天的希冀)
|
||||
* [200 天的 Showcase](http://github.phodal.com/#天的showcase)
|
||||
* [一些项目简述](http://github.phodal.com/#一些项目简述)
|
||||
* [Google Maps solr polygon 搜索](http://github.phodal.com/#google-map-solr-polygon-搜索)
|
||||
* [技能树](http://github.phodal.com/#技能树)
|
||||
* [365天](http://github.phodal.com/#天-1)
|
||||
* [365 天](http://github.phodal.com/#天-1)
|
||||
* [编程的基础能力](http://github.phodal.com/#编程的基础能力)
|
||||
* [技术与框架设计](http://github.phodal.com/#技术与框架设计)
|
||||
* [领域与练习](http://github.phodal.com/#领域与练习)
|
||||
* [其他](http://github.phodal.com/#其他-1)
|
||||
* [500天](http://github.phodal.com/#天-2)
|
||||
* [500天与10000小时](http://github.phodal.com/#天与10000小时)
|
||||
* [500 天](http://github.phodal.com/#天-2)
|
||||
* [500 天与 10000 小时](http://github.phodal.com/#天与10000小时)
|
||||
* [编程的情绪周期](http://github.phodal.com/#编程的情绪周期)
|
||||
* [有意图的练习](http://github.phodal.com/#有意图的练习)
|
||||
* [预见性练习](http://github.phodal.com/#预见性练习)
|
||||
* [小结](http://github.phodal.com/#小结)
|
||||
* [365*2-7天里](http://github.phodal.com/#天里)
|
||||
* [365*2-7 天里](http://github.phodal.com/#天里)
|
||||
* [编码的练习](http://github.phodal.com/#编码的练习)
|
||||
* [See you Again](http://github.phodal.com/#see-you-again)
|
||||
* [GitHub 里程碑](http://github.phodal.com/#github-里程碑)
|
||||
* [写在GitHub 的第 19999 个 Star 时](http://github.phodal.com/#写在github-的第-19999-个-star-时)
|
||||
* [写在 GitHub 的第 19999 个 Star 时](http://github.phodal.com/#写在github-的第-19999-个-star-时)
|
||||
* [从创建开源框架说起](http://github.phodal.com/#从创建开源框架说起)
|
||||
* [下一个开源项目](http://github.phodal.com/#下一个开源项目)
|
||||
* [GitHub 寻宝指南](http://github.phodal.com/#github-寻宝指南)
|
||||
|
|
@ -166,7 +166,7 @@
|
|||
* [技巧五:把握 GitHub Trending](#技巧五把握-github-trending)
|
||||
* [不是技巧的技巧:持续性](#不是技巧的技巧持续性)
|
||||
* [FAQ](#faq)
|
||||
* [如何看待 GitHub 项目刷Star行为?](http://github.phodal.com/#如何看待github-项目刷star行为)
|
||||
* [如何看待 GitHub 项目刷 Star 行为?](http://github.phodal.com/#如何看待github-项目刷star行为)
|
||||
|
||||
## License
|
||||
|
||||
|
|
|
|||
|
|
@ -21,9 +21,9 @@
|
|||
- 知乎:[https://www.zhihu.com/people/phodal](https://www.zhihu.com/people/phodal)
|
||||
- SegmentFault:[https://segmentfault.com/u/phodal](https://segmentfault.com/u/phodal)
|
||||
|
||||
当前为预览版,在使用的过程中遇到任何问题请及时与我联系。阅读过程中的问题,不妨在GitHub上提出来:[Issues](https://github.com/phodal/github/issues)
|
||||
当前为预览版,在使用的过程中遇到任何问题请及时与我联系。阅读过程中的问题,不妨在 GitHub 上提出来:[Issues](https://github.com/phodal/github/issues)
|
||||
|
||||
阅读过程中遇到语法错误、拼写错误、技术错误等等,不妨来个Pull Request,这样可以帮助到其他阅读这本电子书的童鞋。
|
||||
阅读过程中遇到语法错误、拼写错误、技术错误等等,不妨来个 Pull Request,这样可以帮助到其他阅读这本电子书的童鞋。
|
||||
|
||||
我的电子书:
|
||||
|
||||
|
|
@ -31,7 +31,7 @@
|
|||
* 《[我的职业是前端工程师](https://github.com/phodal/fe)》
|
||||
* 《[Serverless 架构应用开发指南](https://github.com/phodal/serverless)》
|
||||
* 《[Growth:全栈增长工程师指南](https://github.com/phodal/growth-ebook)》
|
||||
* 《[Phodal's Idea实战指南](https://github.com/phodal/ideabook)》
|
||||
* 《[Phodal's Idea 实战指南](https://github.com/phodal/ideabook)》
|
||||
* 《[一步步搭建物联网系统](https://github.com/phodal/designiot)》
|
||||
* 《[RePractise](https://github.com/phodal/repractise)》
|
||||
* 《[Growth:全栈增长工程师实战](https://github.com/phodal/growth-in-action)》
|
||||
|
|
@ -48,43 +48,43 @@
|
|||
|
||||
 
|
||||
|
||||
我的GitHub主页上写着加入的时间——``Joined on Nov 8, 2010``,那时才大一,在那之后的那么长的日子里我都没有登录过。也许是因为我学的不是计算机,到了今天——``2015.3.9``,我才发现这其实是程序员的社交网站。
|
||||
我的 GitHub 主页上写着加入的时间——``Joined on Nov 8, 2010``,那时才大一,在那之后的那么长的日子里我都没有登录过。也许是因为我学的不是计算机,到了今天——``2015.3.9``,我才发现这其实是程序员的社交网站。
|
||||
|
||||
过去,曾经有很长的一些时间我试过在GitHub上连击,也试着去了解别人是如何用好这个工具的。当然粉丝在GitHub上也是很重要的。
|
||||
过去,曾经有很长的一些时间我试过在 GitHub 上连击,也试着去了解别人是如何用好这个工具的。当然粉丝在 GitHub 上也是很重要的。
|
||||
|
||||
在这里,我会试着将我在GitHub上学到的东西一一分享出来。
|
||||
在这里,我会试着将我在 GitHub 上学到的东西一一分享出来。
|
||||
|
||||
## 我与GitHub的故事
|
||||
## 我与 GitHub 的故事
|
||||
|
||||
在我大四找工作的时候,试图去寻找一份硬件、物联网相关的工作(ps:专业是电子信息工程)。尽管简历上写得满满的各种经历、经验,然而并没有卵用。跑了几场校园招聘会后,十份简历(ps:事先已经有心里准备)一个也没有投出去——因为学校直接被拒。我对霸面什么的一点兴趣都没有,千里马需要伯乐。后来,我加入了[Martin Flower](https://martinfowler.com/)所在的公司,当然这是后话了。
|
||||
|
||||
这是一个残酷的世界,在学生时代,如果你长得不帅不高的话,那么多数的附加技能都是白搭(ps:通常富的是看不到这篇文章的)。在工作时期,如果你上家没有名气,那么将会影响你下一份工作的待遇。而,很多东西却可以改变这些,GitHub就是其中一个。
|
||||
这是一个残酷的世界,在学生时代,如果你长得不帅不高的话,那么多数的附加技能都是白搭(ps:通常富的是看不到这篇文章的)。在工作时期,如果你上家没有名气,那么将会影响你下一份工作的待遇。而,很多东西却可以改变这些,GitHub 就是其中一个。
|
||||
|
||||
注册GitHub的时候大概是大一的时候,我熟悉的时候已经是大四了,现在已经毕业一年了。在过去的近两年里,我试着以几个维度在GitHub上创建项目:
|
||||
注册 GitHub 的时候大概是大一的时候,我熟悉的时候已经是大四了,现在已经毕业一年了。在过去的近两年里,我试着以几个维度在 GitHub 上创建项目:
|
||||
|
||||
1. 快速上手框架来实战,即demo
|
||||
1. 快速上手框架来实战,即 demo
|
||||
2. 重构别人的代码
|
||||
3. 创建自己可用的框架
|
||||
4. 快速构建大型应用
|
||||
5. 构建通用的框架
|
||||
|
||||
### GitHub与收获
|
||||
### GitHub 与收获
|
||||
|
||||
先说说**与技能无关的收获**吧,毕业设计做的是一个《[最小物联网系统](https://github.com/phodal/iot)》,考虑到我们专业老师没有这方面知识,答辩时会带来问题,尽量往这方面靠拢。当我毕业后,这个项目已经有过百个 Star 了,这样易上手的东西还是比较受欢迎的(ps:不过这种硬件相关的项目通常受限于GitHub上硬件开发工程师比较少的困扰)。
|
||||
|
||||
毕业后一个月收到PACKT出版社的邮件(ps:他们是在 GitHub 上找到我的),内容是关于Review一本[物联网](iot)书籍,即在《[从Review到翻译IT书籍](http://www.phodal.com/blog/review-it-books-with-translate-book/)》中提到的《Learning Internet of Things》。作为一个四级没过的"物联网专家",去审阅一本英文的物联网书籍。。。
|
||||
毕业后一个月收到 PACKT 出版社的邮件(ps:他们是在 GitHub 上找到我的),内容是关于 Review 一本[物联网](iot)书籍,即在《[从 Review 到翻译 IT书籍](http://www.phodal.com/blog/review-it-books-with-translate-book/)》中提到的《Learning Internet of Things》。作为一个四级没过的"物联网专家",去审阅一本英文的物联网书籍。。。
|
||||
|
||||
当然,后来是审阅完了,书上有我的英文简介。
|
||||
|
||||

|
||||
|
||||
一个月前,收到MANNING出版社的邮件(ps:也是在 GitHub 上),关于Review一本[物联网](iot)书籍的目录,并提出建议。
|
||||
一个月前,收到 MANNING 出版社的邮件(ps:也是在 GitHub 上),关于 Review 一本[物联网](iot)书籍的目录,并提出建议。
|
||||
|
||||
也因此带来了其他更多的东西,当然不是这里的主题。在这里,我们就不讨论各种骚扰邮件,或者中文合作。从没有想象过,我也可以在英语世界有一片小天地。
|
||||
|
||||
这些告诉我们,GitHub上找一个你擅长的主题,那么会有很多人找上你的。
|
||||
这些告诉我们,GitHub 上找一个你擅长的主题,那么会有很多人找上你的。
|
||||
|
||||
### GitHub与成长
|
||||
### GitHub 与成长
|
||||
|
||||
过去写过一篇《[如何通过 GitHub 提升自己](http://www.phodal.com/blog/use-github-grow-self/)》的文章,现在只想说三点:
|
||||
|
||||
|
|
@ -96,31 +96,31 @@
|
|||
|
||||
如果你的项目代码有上千行,如果你能保证测试覆盖率可以达到95%以的话,那么我想你的项目不会有太复杂的函数。假使有这样的函数,那么它也是被测试覆盖住的。
|
||||
|
||||
如果你在用心做这个项目,那么你看到代码写得不好也会试着改进,即重构。当有了一些,你的技能会不断提升。你开始会试着接触更多的东西,如stub,如mock,如fakeserver。
|
||||
如果你在用心做这个项目,那么你看到代码写得不好也会试着改进,即重构。当有了一些,你的技能会不断提升。你开始会试着接触更多的东西,如 stub,如 mock,如 fakeserver。
|
||||
|
||||
有一天,你会发现你离不开测试。
|
||||
|
||||
然后就会相信:**那些没有写测试的项目都是在耍流氓**
|
||||
|
||||
## 为什么你应该深入GitHub
|
||||
## 为什么你应该深入 GitHub
|
||||
|
||||
上面我们说的都是我们可以收获到的东西,我们开始尝试就意味着我们知道它可能给我们带来好处。上面已经提到很多可以提升自己的例子了,这里再说说其他的。
|
||||
|
||||
### 方便工作
|
||||
|
||||
我们可以从中获取到不同的知识、内容、信息。每个人都可以从别人的代码中学习,当我们需要构建一个库的时候,我们可以在上面寻找不同的库和代码来实现我们的功能。如当我在实现一个库的时候,我会在GitHub上找到相应的组件:
|
||||
我们可以从中获取到不同的知识、内容、信息。每个人都可以从别人的代码中学习,当我们需要构建一个库的时候,我们可以在上面寻找不同的库和代码来实现我们的功能。如当我在实现一个库的时候,我会在 GitHub 上找到相应的组件:
|
||||
|
||||
- Promise 支持
|
||||
- Class类(ps:没有一个好的类使用的方式)
|
||||
- Class 类(ps:没有一个好的类使用的方式)
|
||||
- Template 一个简单的模板引擎
|
||||
- Router 用来控制页面的路由
|
||||
- Ajax 基本的Ajax Get/Post请求
|
||||
- Ajax 基本的 Ajax Get/Post 请求
|
||||
|
||||
### 获得一份工作
|
||||
|
||||
越来越多的人因为GitHub获得工作,因为他们的做的东西正好符合一些公司的要求。那么,这些公司在寻找代码的时候,就会试着邀请他们。
|
||||
越来越多的人因为 GitHub 获得工作,因为他们的做的东西正好符合一些公司的要求。那么,这些公司在寻找代码的时候,就会试着邀请他们。
|
||||
|
||||
因而,在GitHub寻找合适的候选人,已经是一种趋势。
|
||||
因而,在 GitHub 寻找合适的候选人,已经是一种趋势。
|
||||
|
||||
### 扩大交际
|
||||
|
||||
|
|
|
|||
|
|
@ -1,40 +1,40 @@
|
|||
# Git基本知识与GitHub使用
|
||||
# Git 基本知识与 GitHub 使用
|
||||
|
||||
## Git
|
||||
|
||||
从一般开发者的角度来看,git有以下功能:
|
||||
从一般开发者的角度来看,Git 有以下功能:
|
||||
|
||||
1. 从服务器上克隆数据库(包括代码和版本信息)到单机上。
|
||||
2. 在自己的机器上创建分支,修改代码。
|
||||
3. 在单机上自己创建的分支上提交代码。
|
||||
4. 在单机上合并分支。
|
||||
5. 新建一个分支,把服务器上最新版的代码fetch下来,然后跟自己的主分支合并。
|
||||
5. 新建一个分支,把服务器上最新版的代码 fetch 下来,然后跟自己的主分支合并。
|
||||
6. 生成补丁(patch),把补丁发送给主开发者。
|
||||
7. 看主开发者的反馈,如果主开发者发现两个一般开发者之间有冲突(他们之间可以合作解决的冲突),就会要求他们先解决冲突,然后再由其中一个人提交。如果主开发者可以自己解决,或者没有冲突,就通过。
|
||||
8. 一般开发者之间解决冲突的方法,开发者之间可以使用pull 命令解决冲突,解决完冲突之后再向主开发者提交补丁。
|
||||
8. 一般开发者之间解决冲突的方法,开发者之间可以使用 pull 命令解决冲突,解决完冲突之后再向主开发者提交补丁。
|
||||
|
||||
从主开发者的角度(假设主开发者不用开发代码)看,git有以下功能:
|
||||
从主开发者的角度(假设主开发者不用开发代码)看,git 有以下功能:
|
||||
|
||||
1. 查看邮件或者通过其它方式查看一般开发者的提交状态。
|
||||
2. 打上补丁,解决冲突(可以自己解决,也可以要求开发者之间解决以后再重新提交,如果是开源项目,还要决定哪些补丁有用,哪些不用)。
|
||||
3. 向公共服务器提交结果,然后通知所有开发人员。
|
||||
|
||||
### Git初入
|
||||
### Git 初入
|
||||
|
||||
如果是第一次使用Git,你需要设置署名和邮箱:
|
||||
如果是第一次使用 Git,你需要设置署名和邮箱:
|
||||
|
||||
```
|
||||
$ git config --global user.name "用户名"
|
||||
$ git config --global user.email "电子邮箱"
|
||||
```
|
||||
|
||||
将代码仓库clone到本地,其实就是将代码复制到你的机器里,并交由Git来管理:
|
||||
将代码仓库 clone 到本地,其实就是将代码复制到你的机器里,并交由 Git 来管理:
|
||||
|
||||
```
|
||||
$ git clone git@github.com:someone/symfony-docs-chs.git
|
||||
```
|
||||
|
||||
你可以修改复制到本地的代码了(symfony-docs-chs项目里都是rst格式的文档)。当你觉得完成了一定的工作量,想做个阶段性的提交:
|
||||
你可以修改复制到本地的代码了(symfony-docs-chs 项目里都是 rst 格式的文档)。当你觉得完成了一定的工作量,想做个阶段性的提交:
|
||||
|
||||
向这个本地的代码仓库添加当前目录的所有改动:
|
||||
|
||||
|
|
@ -62,12 +62,12 @@ $git status
|
|||
|
||||

|
||||
|
||||
可以看到状态的变化是从黄色到绿色,即unstage到add。
|
||||
可以看到状态的变化是从黄色到绿色,即 unstage 到 add。
|
||||
|
||||
|
||||
## GitHub
|
||||
|
||||
Wiki百科上是这么说的
|
||||
Wiki 百科上是这么说的
|
||||
|
||||
> GitHub 是一个共享虚拟主机服务,用于存放使用Git版本控制的软件代码和内容项目。它由GitHub公司(曾称Logical Awesome)的开发者Chris Wanstrath、PJ Hyett和Tom Preston-Werner
|
||||
使用Ruby on Rails编写而成。
|
||||
|
|
@ -92,7 +92,7 @@ Wiki百科上是这么说的
|
|||
|
||||
### 版本管理与软件部署
|
||||
|
||||
jQuery[^jQuery]在发布版本``2.1.3``,一共有152个commit。我们可以看到如下的提交信息:
|
||||
jQuery[^jQuery] 在发布版本``2.1.3``,一共有 152 个 commit。我们可以看到如下的提交信息:
|
||||
|
||||
- Ajax: Always use script injection in globalEval … bbdfbb4
|
||||
- Effects: Reintroduce use of requestAnimationFrame … 72119e0
|
||||
|
|
@ -101,7 +101,7 @@ jQuery[^jQuery]在发布版本``2.1.3``,一共有152个commit。我们可以
|
|||
- Build: Update commitplease dev dependency
|
||||
- ...
|
||||
|
||||
### GitHub与Git
|
||||
### GitHub 与 Git
|
||||
|
||||
> Git是一个分布式的版本控制系统,最初由Linus Torvalds编写,用作Linux内核代码的管理。在推出后,Git在其它项目中也取得了很大成功,尤其是在Ruby社区中。目前,包括Rubinius、Merb和Bitcoin在内的很多知名项目都使用了Git。Git同样可以被诸如Capistrano和Vlad the Deployer这样的部署工具所使用。
|
||||
|
||||
|
|
@ -141,7 +141,7 @@ git push -u origin master
|
|||
|
||||
## GitHub 流行项目分析
|
||||
|
||||
之前曾经分析过一些GitHub的用户行为,现在我们先来说说GitHub上的Star吧。(截止:2015年3月9日23时。)
|
||||
之前曾经分析过一些 GitHub 的用户行为,现在我们先来说说 GitHub 上的 Star 吧。(截止:2015年3月9日23时。)
|
||||
|
||||
用户 | 项目名 | Language | Star | Url
|
||||
-----|---------- |----------|------|----
|
||||
|
|
@ -151,7 +151,7 @@ angular | angular.js | JavaScript | 36,061 | [https://github.com/angular/angular
|
|||
mbostock | d3 | JavaScript | 35,257 | [https://github.com/mbostock/d3](https://github.com/mbostock/d3)
|
||||
joyent | node | JavaScript | 35,077 | [https://github.com/joyent/node](https://github.com/joyent/node)
|
||||
|
||||
上面列出来的是前5的,看看大于1万个 Stars 的项目的分布,一共有82个:
|
||||
上面列出来的是前5的,看看大于 1 万个 Stars 的项目的分布,一共有 82 个:
|
||||
|
||||
语言 | 项目数
|
||||
-----|-----
|
||||
|
|
@ -179,11 +179,11 @@ C | 2
|
|||
|
||||
## Pull Request
|
||||
|
||||
除了创建项目之外,我们也可以创建Pull Request来做贡献。
|
||||
除了创建项目之外,我们也可以创建 Pull Request 来做贡献。
|
||||
|
||||
### 我的第一个PR
|
||||
### 我的第一个 PR
|
||||
|
||||
我的第一个PR是给一个小的Node的CoAP相关的库的Pull Request。原因比较简单,是因为它的README.md写错了,导致我无法进行下一步。
|
||||
我的第一个 PR 是给一个小的 Node 的 CoAP 相关的库的 Pull Request。原因比较简单,是因为它的 README.md 写错了,导致我无法进行下一步。
|
||||
|
||||
const dgram = require('dgram')
|
||||
- , coapPacket = require('coap-packet')
|
||||
|
|
@ -204,14 +204,14 @@ C | 2
|
|||
|
||||
### CLA
|
||||
|
||||
CLA即Contributor License Agreement,在为一些大的组织、机构提交Pull Request的时候,可能需要签署这个协议。他们会在你的Pull Request里问你,只有你到他们的网站去注册并同意协议才会接受你的PR。
|
||||
CLA 即 Contributor License Agreement,在为一些大的组织、机构提交 Pull Request 的时候,可能需要签署这个协议。他们会在你的 Pull Request 里问你,只有你到他们的网站去注册并同意协议才会接受你的 PR。
|
||||
|
||||
以下是我为Google提交的一个PR
|
||||
以下是我为 Google 提交的一个 PR
|
||||
|
||||

|
||||
|
||||
以及Eclipse的一个PR
|
||||
以及 Eclipse 的一个 PR
|
||||
|
||||

|
||||
|
||||
他们都要求我签署CLA。
|
||||
他们都要求我签署 CLA。
|
||||
|
|
|
|||
|
|
@ -2,13 +2,13 @@
|
|||
|
||||
## 如何用好 GitHub
|
||||
|
||||
如何用好 GitHub,并实践一些敏捷软件开发是一个很有意思的事情.我们可以在上面做很多事情,从测试到CI,再到自动部署.
|
||||
如何用好 GitHub,并实践一些敏捷软件开发是一个很有意思的事情.我们可以在上面做很多事情,从测试到 CI,再到自动部署.
|
||||
|
||||
### 敏捷软件开发
|
||||
|
||||
显然我是在扯淡,这和敏捷软件开发没有什么关系。不过我也不知道瀑布流是怎样的。说说我所知道的一个项目的组成吧:
|
||||
|
||||
- 看板式管理应用程序(如trello,简单地说就是管理软件功能)
|
||||
- 看板式管理应用程序(如 trello,简单地说就是管理软件功能)
|
||||
- CI(持续集成)
|
||||
- 测试覆盖率
|
||||
- 代码质量(code smell)
|
||||
|
|
@ -17,11 +17,11 @@
|
|||
|
||||
> 你存在,我深深的脑海里
|
||||
|
||||
当只有一个人的时候,你只需要明确知道自己想要什么就够了。我们还需要的是CI、测试,以来提升代码的质量。
|
||||
当只有一个人的时候,你只需要明确知道自己想要什么就够了。我们还需要的是 CI、测试,以来提升代码的质量。
|
||||
|
||||
### 测试
|
||||
|
||||
通常我们都会找Document,如果没有的话,你会找什么?看源代码,还是看测试?
|
||||
通常我们都会找 Document,如果没有的话,你会找什么?看源代码,还是看测试?
|
||||
|
||||
```javascript
|
||||
it("specifying response when you need it", function (done) {
|
||||
|
|
@ -53,7 +53,7 @@ it("specifying response when you need it", function (done) {
|
|||
- 我不希望在重构的时候发现破坏了原来的功能,而我还一无所知。
|
||||
- 我不敢push代码,因为我没有把握。
|
||||
|
||||
虽然,我不是TDD的死忠,测试的目的是保证功能正常,TDD没法让我们写出质量更高的代码。但是有时TDD是不错的,可以让我们写出逻辑更简单地代码。
|
||||
虽然,我不是 TDD 的死忠,测试的目的是保证功能正常,TDD 没法让我们写出质量更高的代码。但是有时TDD是不错的,可以让我们写出逻辑更简单地代码。
|
||||
|
||||
也许你已经知道了``Selenium``、``Jasmine``、``Cucumber``等等的框架,看到过类似于下面的测试
|
||||
|
||||
|
|
@ -83,7 +83,7 @@ lettuce.js | 98.58% (209 / 212)| 82.98%(78 / 94) | 100.00% (54 / 54) | 98.58% (2
|
|||
|
||||
### CI
|
||||
|
||||
虽然node.js不算是一门语言,但是因为我们用的node,下面的是一个简单的``.travis.yml``示例:
|
||||
虽然 node.js 不算是一门语言,但是因为我们用的 node,下面的是一个简单的 ``.travis.yml`` 示例:
|
||||
|
||||
```yml
|
||||
language: node_js
|
||||
|
|
@ -100,21 +100,21 @@ after_success: CODECLIMATE_REPO_TOKEN=321480822fc37deb0de70a11931b4cb6a2a3cc4116
|
|||
|
||||
代码来源:[https://github.com/phodal/lettuce](https://github.com/phodal/lettuce)
|
||||
|
||||
我们把这些集成到``README.md``之后,就有了之前那张图。
|
||||
我们把这些集成到 ``README.md`` 之后,就有了之前那张图。
|
||||
|
||||
CI对于一个开发者在不同城市开发同一项目上来说是很重要的,这意味着当你添加的部分功能有测试覆盖的时候,项目代码会更加强壮。
|
||||
|
||||
### 代码质量
|
||||
|
||||
像``jslint``这类的工具,只能保证代码在语法上是正确的,但是不能保证你写了一堆bad smell的代码。
|
||||
像 ``jslint`` 这类的工具,只能保证代码在语法上是正确的,但是不能保证你写了一堆 bad smell 的代码。
|
||||
|
||||
- 重复代码
|
||||
- 过长的函数
|
||||
- 等等
|
||||
|
||||
``Code Climate``是一个与github集成的工具,我们不仅仅可以看到测试覆盖率,还有代码质量。
|
||||
``Code Climate`` 是一个与 github 集成的工具,我们不仅仅可以看到测试覆盖率,还有代码质量。
|
||||
|
||||
先看看上面的ajax类:
|
||||
先看看上面的 ajax 类:
|
||||
|
||||
```javascript
|
||||
Lettuce.get = function (url, callback) {
|
||||
|
|
@ -143,7 +143,7 @@ Lettuce.send = function (url, method, callback, data) {
|
|||
|
||||
代码来源:[https://github.com/phodal/lettuce](https://github.com/phodal/lettuce)
|
||||
|
||||
在[Code Climate](https://codeclimate.com/github/phodal/lettuce/src/ajax.js)在出现了一堆问题
|
||||
在 [Code Climate](https://codeclimate.com/github/phodal/lettuce/src/ajax.js) 在出现了一堆问题
|
||||
|
||||
- Missing "use strict" statement. (Line 2)
|
||||
- Missing "use strict" statement. (Line 14)
|
||||
|
|
@ -159,11 +159,11 @@ Lettuce.send = function (url, method, callback, data) {
|
|||
|
||||
在之前说到
|
||||
|
||||
> 奋斗了近半个月后,将fork的代码读懂、重构、升级版本、调整,添加新功能、添加测试、添加CI、添加分享之后,终于almost finish。
|
||||
> 奋斗了近半个月后,将 fork 的代码读懂、重构、升级版本、调整,添加新功能、添加测试、添加 CI、添加分享之后,终于 almost finish。
|
||||
|
||||
今天就来说说是怎样做的。
|
||||
|
||||
以之前造的[Lettuce](https://github.com/phodal/lettuce)为例,里面有:
|
||||
以之前造的 [Lettuce](https://github.com/phodal/lettuce) 为例,里面有:
|
||||
|
||||
- 代码质量(Code Climate)
|
||||
- CI状态(Travis CI)
|
||||
|
|
@ -171,7 +171,7 @@ Lettuce.send = function (url, method, callback, data) {
|
|||
- 自动化测试(npm test)
|
||||
- 文档
|
||||
|
||||
按照[Web Developer路线图](https://github.com/phodal/awesome-developer)来说,我们还需要有:
|
||||
按照 [Web Developer 路线图](https://github.com/phodal/awesome-developer)来说,我们还需要有:
|
||||
|
||||
- 版本管理
|
||||
- 自动部署
|
||||
|
|
@ -180,11 +180,11 @@ Lettuce.send = function (url, method, callback, data) {
|
|||
|
||||
### 代码模块化
|
||||
|
||||
在SkillTree的源码里,大致分为三部分:
|
||||
在 SkillTree 的源码里,大致分为三部分:
|
||||
|
||||
- namespace函数:顾名思义
|
||||
- Calculator也就是TalentTree,主要负责解析、生成url,头像,依赖等等
|
||||
- Skill 主要是tips部分。
|
||||
- namespace 函数:顾名思义
|
||||
- Calculator 也就是 TalentTree,主要负责解析、生成 url,头像,依赖等等
|
||||
- Skill 主要是 tips 部分。
|
||||
|
||||
而这一些都在一个 JS 里,对于一个库来说,是一件好事,但是对于一个项目来说,并非如此。
|
||||
|
||||
|
|
@ -193,13 +193,13 @@ Lettuce.send = function (url, method, callback, data) {
|
|||
- jQuery
|
||||
- Knockout
|
||||
|
||||
好在Knockout可以用Require.js进行管理,于是,使用了``Require.js``进行管理:
|
||||
好在 Knockout 可以用 Require.js 进行管理,于是,使用了 ``Require.js`` 进行管理:
|
||||
|
||||
```html
|
||||
<script type="text/javascript" data-main="app/scripts/main.js" src="app/lib/require.js"></script>
|
||||
```
|
||||
|
||||
``main.js``配置如下:
|
||||
``main.js`` 配置如下:
|
||||
|
||||
```javascript
|
||||
require.config({
|
||||
|
|
@ -220,7 +220,7 @@ require(['lib/knockout', 'scripts/TalentTree', 'json!data/web.json'], function(k
|
|||
});
|
||||
```
|
||||
|
||||
text、JSON 插件主要是用于处理web.json,即用 JSON 来处理技能,于是不同的类到了不同的 JS 文件。
|
||||
text、JSON 插件主要是用于处理 web.json,即用 JSON 来处理技能,于是不同的类到了不同的 JS 文件。
|
||||
|
||||
.
|
||||
|____Book.js
|
||||
|
|
@ -232,7 +232,7 @@ text、JSON 插件主要是用于处理web.json,即用 JSON 来处理技能,
|
|||
|____TalentTree.js
|
||||
|____Utils.js
|
||||
|
||||
加上了后来的推荐阅读书籍等等。而Book和Link都是继承自Doc。
|
||||
加上了后来的推荐阅读书籍等等。而 Book 和 Link 都是继承自 Doc。
|
||||
|
||||
```javascript
|
||||
define(['scripts/Doc'], function(Doc) {
|
||||
|
|
@ -246,7 +246,7 @@ define(['scripts/Doc'], function(Doc) {
|
|||
});
|
||||
```
|
||||
|
||||
而这里便是后面对其进行重构的内容。Doc类则是Skillock中类的一个缩影
|
||||
而这里便是后面对其进行重构的内容。Doc 类则是 Skillock 中类的一个缩影
|
||||
|
||||
```javascript
|
||||
define([], function() {
|
||||
|
|
@ -263,7 +263,7 @@ define([], function() {
|
|||
});
|
||||
```
|
||||
|
||||
或者说这是一个AMD的Class应该有的样子。考虑到this的隐性绑定,作者用了self=this来避免这个问题。最后Return了这个对象,我们在调用的就需要new一个。大部分在代码中返回的都是对象,除了在Utils类里面返回的是函数:
|
||||
或者说这是一个 AMD 的 Class 应该有的样子。考虑到 this 的隐性绑定,作者用了self=this 来避免这个问题。最后 Return 了这个对象,我们在调用的就需要 new 一个。大部分在代码中返回的都是对象,除了在 Utils 类里面返回的是函数:
|
||||
|
||||
```javascript
|
||||
return {
|
||||
|
|
@ -277,7 +277,7 @@ return {
|
|||
|
||||
### 自动化测试
|
||||
|
||||
一直习惯用Travis CI,于是也继续用Travis Ci,``.travis.yml``配置如下所示:
|
||||
一直习惯用 Travis CI,于是也继续用 Travis Ci,``.travis.yml`` 配置如下所示:
|
||||
|
||||
```yml
|
||||
language: node_js
|
||||
|
|
@ -292,9 +292,9 @@ branches:
|
|||
- gh-pages
|
||||
```
|
||||
|
||||
使用gh-pages的原因是,我们一push代码的时候,就可以自动测试、部署等等,好处一堆堆的。
|
||||
使用 gh-pages 的原因是,我们一 push 代码的时候,就可以自动测试、部署等等,好处一堆堆的。
|
||||
|
||||
接着我们需要在``package.json``里面添加脚本
|
||||
接着我们需要在 ``package.json`` 里面添加脚本
|
||||
|
||||
```javascript
|
||||
"scripts": {
|
||||
|
|
@ -302,7 +302,7 @@ branches:
|
|||
}
|
||||
```
|
||||
|
||||
这样当我们push代码的时候便会自动跑所有的测试。因为mocha的主要配置是用``mocha.opts``,所以我们还需要配置一下``mocha.opts``
|
||||
这样当我们 push 代码的时候便会自动跑所有的测试。因为 mocha 的主要配置是用 ``mocha.opts``,所以我们还需要配置一下 ``mocha.opts``
|
||||
|
||||
--reporter spec
|
||||
--ui bdd
|
||||
|
|
@ -310,7 +310,7 @@ branches:
|
|||
--colors
|
||||
test/spec
|
||||
|
||||
最后的``test/spec``是指定测试的目录。
|
||||
最后的 ``test/spec`` 是指定测试的目录。
|
||||
|
||||
### Jshint
|
||||
|
||||
|
|
@ -338,7 +338,7 @@ branches:
|
|||
|
||||
### 测试示例
|
||||
|
||||
简单地看一下Book的测试:
|
||||
简单地看一下 Book 的测试:
|
||||
|
||||
```javascript
|
||||
/* global describe, it */
|
||||
|
|
@ -377,7 +377,7 @@ describe('Book,Link', function () {
|
|||
});
|
||||
```
|
||||
|
||||
因为我们用``require.js``来管理浏览器端,在后台写测试来测试的时候,我们也需要用他来管理我们的依赖,这也就是为什么这个测试这么长的原因,多数情况下一个测试类似于这样子的。(用Jasmine似乎会是一个更好的主意,但是用习惯Jasmine了)
|
||||
因为我们用 ``require.js`` 来管理浏览器端,在后台写测试来测试的时候,我们也需要用他来管理我们的依赖,这也就是为什么这个测试这么长的原因,多数情况下一个测试类似于这样子的。(用 Jasmine 似乎会是一个更好的主意,但是用习惯 Jasmine 了)
|
||||
|
||||
```javascript
|
||||
describe('Book Test', function () {
|
||||
|
|
@ -403,13 +403,13 @@ it('should return book label & url', function () {
|
|||
- 当你写了一大堆代码,你没有意识到里面有一大堆重复。
|
||||
- 当你写了一大堆测试,却不知道覆盖率有多少。
|
||||
|
||||
这就是个问题了,于是偶然间看到了一个叫code climate的网站。
|
||||
这就是个问题了,于是偶然间看到了一个叫 code climate 的网站。
|
||||
|
||||
### Code Climate
|
||||
|
||||
> Code Climate consolidates the results from a suite of static analysis tools into a single, real-time report, giving your team the information it needs to identify hotspots, evaluate new approaches, and improve code quality.
|
||||
|
||||
Code Climate整合一组静态分析工具的结果到一个单一的,实时的报告,让您的团队需要识别热点,探讨新的方法,提高代码质量的信息。
|
||||
Code Climate 整合一组静态分析工具的结果到一个单一的,实时的报告,让您的团队需要识别热点,探讨新的方法,提高代码质量的信息。
|
||||
|
||||
简单地来说:
|
||||
|
||||
|
|
@ -437,7 +437,7 @@ A | lib/url_handler.js | 9 | 0 | 5 | 2.2 | 94.1% | 0
|
|||
|
||||
### 代码的坏味道
|
||||
|
||||
于是我们就打开``lib/database/sqlite_helper.js``,因为其中有两个坏味道
|
||||
于是我们就打开 ``lib/database/sqlite_helper.js``,因为其中有两个坏味道
|
||||
|
||||
Similar code found in two :expression_statement nodes (mass = 86)
|
||||
|
||||
|
|
|
|||
|
|
@ -49,7 +49,7 @@ Git 提交信息及几种不同的规范
|
|||
|
||||
示例 2,``[SkillTree] detail: add link data``。其中的 ``SkillTree`` 表示修改的是技能树 Tab 下的内容,``detail`` 则表示修改的是详情页,``add link data`` 则表示是添加了技能的数据
|
||||
|
||||
这样做的主要原因是,它可以轻松也帮我**filter 出相应业务的内容**。
|
||||
这样做的主要原因是,它可以轻松也帮我 **filter 出相应业务的内容**。
|
||||
|
||||
缺点:要这样做需要团队达到一致,因此付出一些额外的成本。
|
||||
|
||||
|
|
|
|||
|
|
@ -13,13 +13,13 @@
|
|||
|
||||
## README
|
||||
|
||||
README通常会显示在GitHub项目的下面,如下图所示:
|
||||
README 通常会显示在 GitHub 项目的下面,如下图所示:
|
||||
|
||||

|
||||
|
||||
通常一个好的README会让你立马对项目产生兴趣。
|
||||
通常一个好的 README 会让你立马对项目产生兴趣。
|
||||
|
||||
如下面的内容是React项目的简介:
|
||||
如下面的内容是 React 项目的简介:
|
||||
|
||||

|
||||
|
||||
|
|
@ -29,7 +29,7 @@ README通常会显示在GitHub项目的下面,如下图所示:
|
|||
* **Virtual DOM:** React abstracts away the DOM from you, giving a simpler programming model and better performance. React can also render on the server using Node, and it can power native apps using [React Native](https://facebook.github.io/react-native/).
|
||||
* **Data flow:** React implements one-way reactive data flow which reduces boilerplate and is easier to reason about than traditional data binding.
|
||||
|
||||
通常在这个README里,还会有:
|
||||
通常在这个 README 里,还会有:
|
||||
|
||||
* 针对人群
|
||||
* 安装指南
|
||||
|
|
@ -46,13 +46,13 @@ README通常会显示在GitHub项目的下面,如下图所示:
|
|||
|
||||
在一个开源项目中,良好和专业的文档是相当重要的,有时他可能会比软件还会重要。因为如果一个开源项目好用的话,多数人可能不会去查看软件的代码。这就意味着,多数时候他在和你的文档打交道。文档一般会有:API 文档、 配置文档、帮助文档、用户手册、教程等等
|
||||
|
||||
写文档的软件有很多,如Markdown、Doxygen、Docbook等等。
|
||||
写文档的软件有很多,如 Markdown、Doxygen、Docbook 等等。
|
||||
|
||||
## 可用示例
|
||||
|
||||
一个简单上手的示例非常重要,特别是通常我们是在为着某个目的而去使用一个开源项目的是时候,我们希望能马上使用到我们的项目中。
|
||||
|
||||
你希望看到的是,你打开浏览器,输入下面的代码,然后**It Works**:
|
||||
你希望看到的是,你打开浏览器,输入下面的代码,然后 **It Works**:
|
||||
|
||||
```
|
||||
var HelloMessage = React.createClass({
|
||||
|
|
|
|||
|
|
@ -2,15 +2,15 @@
|
|||
|
||||
或许你应该知道了,重构是怎样的,你也知道重构能带来什么。在我刚开始学重构和设计模式的时候,我需要去找一些好的示例,以便于我更好的学习。有时候不得不创造一些更好的场景,来实现这些功能。
|
||||
|
||||
有一天,我发现当我需要我一次又一次地重复讲述某些内容,于是我就计划着把这些应该掌握的技能放到GitHub上,也就有了[Artisan Stack](https://github.com/phodal-archive/artisanstack.github.io) 计划。
|
||||
有一天,我发现当我需要我一次又一次地重复讲述某些内容,于是我就计划着把这些应该掌握的技能放到 GitHub 上,也就有了 [Artisan Stack](https://github.com/phodal-archive/artisanstack.github.io) 计划。
|
||||
|
||||
每个程序员都不可避免地是一个Coder,一个没有掌握好技能的Coder,算不上是手工艺人,但是手工艺人,需要有创造性的方法。
|
||||
每个程序员都不可避免地是一个 Coder,一个没有掌握好技能的 Coder,算不上是手工艺人,但是手工艺人,需要有创造性的方法。
|
||||
|
||||
## 为什么重构?
|
||||
|
||||
> 为了更好的代码。
|
||||
|
||||
在经历了一年多的工作之后,我平时的主要工作就是修Bug。刚开始的时候觉得无聊,后来才发现修Bug需要更好的技术。有时候你可能要面对着一坨一坨的代码,有时候你可能要花几天的时间去阅读代码。而你重写那几十行代码可能只会花上你不到一天的时间。但是如果你没办法理解当时为什么这么做,你的修改只会带来更多的Bug。修Bug,更多的是维护代码。还是前人总结的那句话对:
|
||||
在经历了一年多的工作之后,我平时的主要工作就是修 Bug。刚开始的时候觉得无聊,后来才发现修 Bug 需要更好的技术。有时候你可能要面对着一坨一坨的代码,有时候你可能要花几天的时间去阅读代码。而你重写那几十行代码可能只会花上你不到一天的时间。但是如果你没办法理解当时为什么这么做,你的修改只会带来更多的 Bug。修 Bug,更多的是维护代码。还是前人总结的那句话对:
|
||||
|
||||
> 写代码容易,读代码难。
|
||||
|
||||
|
|
@ -22,13 +22,13 @@
|
|||
|
||||
让我们来看看我们的第一个训练,相当有挑战性。
|
||||
|
||||
## 重构uMarkdown
|
||||
## 重构 uMarkdown
|
||||
|
||||
代码及setup请见 GitHub:[js-refactor](https://github.com/artisanstack/js-refactor)
|
||||
代码及 setup 请见 GitHub:[js-refactor](https://github.com/artisanstack/js-refactor)
|
||||
|
||||
### 代码说明
|
||||
|
||||
``uMarkdown``是一个用于将Markdown转化为HTML的库。代码看上去就像一个很典型的过程代码:
|
||||
``uMarkdown`` 是一个用于将 Markdown 转化为HTML的库。代码看上去就像一个很典型的过程代码:
|
||||
|
||||
```javascript
|
||||
/* code */
|
||||
|
|
@ -48,11 +48,11 @@ while ((stra = micromarkdown.regexobject.mail.exec(str)) !== null) {
|
|||
}
|
||||
```
|
||||
|
||||
选这个做重构的开始,不仅仅是因为之前在写[EchoesWorks](https://github.com/phodal/echoesworks)的时候进行了很多的重构。而且它更适合于``重构到设计模式``的理论。让我们在重构完之后,给作者进行pull request吧。
|
||||
选这个做重构的开始,不仅仅是因为之前在写 [EchoesWorks](https://github.com/phodal/echoesworks) 的时候进行了很多的重构。而且它更适合于``重构到设计模式``的理论。让我们在重构完之后,给作者进行 pull request 吧。
|
||||
|
||||
Markdown的解析过程,有点类似于``Pipe and Filters``模式(架构模式)。
|
||||
Markdown 的解析过程,有点类似于``Pipe and Filters``模式(架构模式)。
|
||||
|
||||
Filter即我们在代码中看到的正规表达式集:
|
||||
Filter 即我们在代码中看到的正规表达式集:
|
||||
|
||||
```javascript
|
||||
regexobject: {
|
||||
|
|
@ -60,13 +60,13 @@ regexobject: {
|
|||
code: /\s\`\`\`\n?([^`]+)\`\`\`/g
|
||||
```
|
||||
|
||||
他会匹配对应的Markdown类型,随后进行替换和处理。而``str``,就是管理口的输入和输出。
|
||||
他会匹配对应的 Markdown 类型,随后进行替换和处理。而``str``,就是管理口的输入和输出。
|
||||
|
||||
接着,我们就可以对其进行简单的重构。
|
||||
|
||||
(ps:推荐用WebStrom来做重构,自带重构功能)
|
||||
(ps:推荐用 WebStrom 来做重构,自带重构功能)
|
||||
|
||||
作为一个示例,我们先提出codeHandler方法,即将上面的
|
||||
作为一个示例,我们先提出 codeHandler 方法,即将上面的
|
||||
|
||||
```javascript
|
||||
/* code */
|
||||
|
|
@ -83,7 +83,7 @@ codeFilter: function (str, stra) {
|
|||
},
|
||||
```
|
||||
|
||||
while语句就成了
|
||||
while 语句就成了
|
||||
|
||||
```javascript
|
||||
while ((stra = regexobject.code.exec(str)) !== null) {
|
||||
|
|
@ -97,7 +97,7 @@ while ((stra = regexobject.code.exec(str)) !== null) {
|
|||
grunt test
|
||||
```
|
||||
|
||||
同理我们就可以``mail``、``headline``等方法进行重构。接着就会变成类似于下面的代码,
|
||||
同理我们就可以 ``mail``、``headline`` 等方法进行重构。接着就会变成类似于下面的代码,
|
||||
|
||||
```javascript
|
||||
/* code */
|
||||
|
|
@ -121,7 +121,7 @@ str = tableHandler(str, execStr, strict);
|
|||
}
|
||||
```
|
||||
|
||||
然后你也看到了,上面有一堆重复的代码,接着让我们用JavaScript的``奇技淫巧``,即apply方法,把上面的重复代码变成。
|
||||
然后你也看到了,上面有一堆重复的代码,接着让我们用 JavaScript 的``奇技淫巧``,即apply方法,把上面的重复代码变成。
|
||||
|
||||
```javascript
|
||||
['code', 'headline', 'lists', 'tables', 'links', 'mail', 'url', 'smlinks', 'hr'].forEach(function (type) {
|
||||
|
|
@ -147,18 +147,18 @@ str = tableHandler(str, execStr, strict);
|
|||
|
||||
快来试试吧,[https://github.com/artisanstack/js-refactor](https://github.com/artisanstack/js-refactor)
|
||||
|
||||
是时候讨论这个Refactor利器了,最初看到这个重构的过程是从ThoughtWorks郑大晔校开始的,只是之前对于Java的另外一个编辑器Eclipse的坏感。。这些在目前已经不是很重要了,试试这个公司里面应用广泛的编辑器。
|
||||
是时候讨论这个 Refactor 利器了,最初看到这个重构的过程是从 ThoughtWorks 郑大晔校开始的,只是之前对于 Java 的另外一个编辑器 Eclipse 的坏感。。这些在目前已经不是很重要了,试试这个公司里面应用广泛的编辑器。
|
||||
|
||||
## Intellij Idea重构
|
||||
## Intellij Idea 重构
|
||||
|
||||
开发的流程大致就是这样子的,测试先行算是推荐的。
|
||||
|
||||
编写测试->功能代码->修改测试->重构
|
||||
|
||||
上次在和buddy聊天的时候,才知道测试在功能简单的时候是后行的,在功能复杂不知道怎么下手的时候是先行的。
|
||||
上次在和 buddy 聊天的时候,才知道测试在功能简单的时候是后行的,在功能复杂不知道怎么下手的时候是先行的。
|
||||
|
||||
|
||||
开始之前请原谅我对于Java语言的一些无知,然后,看一下我写的Main函数:
|
||||
开始之前请原谅我对于 Java 语言的一些无知,然后,看一下我写的 Main 函数:
|
||||
|
||||
```java
|
||||
package com.phodal.learing;
|
||||
|
|
@ -175,7 +175,7 @@ public class Main {
|
|||
}
|
||||
```
|
||||
|
||||
代码写得还好(自我感觉),先不管Cal和Cal2两个类。大部分都能看懂,除了c,d不知道他们表达的是什么意思,于是。
|
||||
代码写得还好(自我感觉),先不管 Cal 和 Cal2 两个类。大部分都能看懂,除了 c, d 不知道他们表达的是什么意思,于是。
|
||||
|
||||
### Rename
|
||||
|
||||
|
|
@ -183,8 +183,8 @@ public class Main {
|
|||
|
||||
**作用:重命名**
|
||||
|
||||
- 把光标丢到int c中的c,按下 Shift + F6,输入result_add
|
||||
- 把光标移到int d中的d,按下 Shift + F6,输入result_sub
|
||||
- 把光标丢到 int c 中的 c,按下 Shift + F6,输入 result_add
|
||||
- 把光标移到 int d 中的 d,按下 Shift + F6,输入 result_sub
|
||||
|
||||
于是就有
|
||||
|
||||
|
|
@ -209,9 +209,9 @@ public class Main {
|
|||
|
||||
**作用:扩展方法**
|
||||
|
||||
- 选中System.out.println(result_add);
|
||||
- 按下 Alt+command+m
|
||||
- 在弹出的窗口中输入mprint
|
||||
- 选中 System.out.println(result_add);
|
||||
- 按下 Alt + command + m
|
||||
- 在弹出的窗口中输入 mprint
|
||||
|
||||
于是有了
|
||||
|
||||
|
|
@ -229,17 +229,17 @@ private static void mprint(int result_sub) {
|
|||
}
|
||||
```
|
||||
|
||||
似乎我们不应该这样对待System.out.println,那么让我们内联回去
|
||||
似乎我们不应该这样对待 System.out.println,那么让我们内联回去
|
||||
|
||||
### Inline Method
|
||||
|
||||
**快捷键:Alt+command+n**
|
||||
**快捷键:Alt + command + n**
|
||||
|
||||
**作用:内联方法**
|
||||
|
||||
- 选中main中的mprint
|
||||
- Alt+command+n
|
||||
- 选中Inline all invocations and remove the method(2 occurrences) 点确定
|
||||
- 选中 main 中的 mprint
|
||||
- Alt + command + n
|
||||
- 选中 Inline all invocations and remove the method(2 occurrences) 点确定
|
||||
|
||||
然后我们等于什么也没有做了~~:
|
||||
|
||||
|
|
@ -257,7 +257,7 @@ public static void main(String[] args) {
|
|||
|
||||
### Pull Members Up
|
||||
|
||||
开始之前让我们先看看Cal2类:
|
||||
开始之前让我们先看看 Cal2 类:
|
||||
|
||||
```java
|
||||
public class Cal2 extends Cal {
|
||||
|
|
@ -268,7 +268,7 @@ public class Cal2 extends Cal {
|
|||
}
|
||||
```
|
||||
|
||||
以及Cal2的父类Cal
|
||||
以及 Cal2 的父类 Cal
|
||||
|
||||
```java
|
||||
public class Cal {
|
||||
|
|
@ -280,7 +280,7 @@ public class Cal {
|
|||
}
|
||||
```
|
||||
|
||||
最后的结果,就是将Cal2类中的sub方法,提到父类:
|
||||
最后的结果,就是将 Cal2 类中的 sub 方法,提到父类:
|
||||
|
||||
```java
|
||||
public class Cal {
|
||||
|
|
@ -332,7 +332,7 @@ public class replaceTemp {
|
|||
|
||||
#### 重构
|
||||
|
||||
选中``basePrice``很愉快地拿鼠标点上面的重构
|
||||
选中 ``basePrice`` 很愉快地拿鼠标点上面的重构
|
||||
|
||||

|
||||
|
||||
|
|
@ -382,9 +382,9 @@ public class replaceTemp {
|
|||
}
|
||||
```
|
||||
|
||||
接着我们选中``aString``,再打开重构菜单,或者
|
||||
接着我们选中 ``aString``,再打开重构菜单,或者
|
||||
|
||||
``Command``+``Alt``+``Shift``+``T`` 再选中Replace Temp with Query
|
||||
``Command``+``Alt``+``Shift``+``T`` 再选中 Replace Temp with Query
|
||||
|
||||
便会有下面的结果:
|
||||
|
||||
|
|
|
|||
|
|
@ -2,17 +2,17 @@
|
|||
|
||||
## TDD
|
||||
|
||||
虽然接触的TDD时间不算短,然而真正在实践TDD上的时候少之又少。除去怎么教人TDD,就是与人结对编程时的switch,或许是受限于当前的开发流程。
|
||||
虽然接触的 TDD 时间不算短,然而真正在实践 TDD 上的时候少之又少。除去怎么教人 TDD,就是与人结对编程时的 switch,或许是受限于当前的开发流程。
|
||||
|
||||
偶然间在开发一个物联网相关的开源项目——[Lan](https://github.com/phodal/lan)的时候,重拾了这个过程。不得不说提到的一点是,在我们的开发流程中**测试是由相关功能开发人员写的**,有时候测试是一种很具挑战性的工作。久而久之,为自己的开源项目写测试变成一种自然而然的事。有时没有测试,反而变得**没有安全感**。
|
||||
|
||||
### 一次测试驱动开发
|
||||
|
||||
之前正在重写一个[物联网](http://www.phodal.com/iot)的服务端,主要便是结合CoAP、MQTT、HTTP等协议构成一个物联网的云服务。现在,主要的任务是集中于协议与授权。由于,不同协议间的授权是不一样的,最开始的时候我先写了一个http put授权的功能,而在起先的时候是如何测试的呢?
|
||||
之前正在重写一个[物联网](http://www.phodal.com/iot)的服务端,主要便是结合 CoAP、MQTT、HTTP 等协议构成一个物联网的云服务。现在,主要的任务是集中于协议与授权。由于,不同协议间的授权是不一样的,最开始的时候我先写了一个 http put 授权的功能,而在起先的时候是如何测试的呢?
|
||||
|
||||
curl --user root:root -X PUT -d '{ "dream": 1 }' -H "Content-Type: application/json" http://localhost:8899/topics/test
|
||||
|
||||
我只要顺利在request中看有无``req.headers.authorization``,我便可以继续往下,接着给个判断。毕竟,我们对HTTP协议还是蛮清楚的。
|
||||
我只要顺利在 request 中看有无 ``req.headers.authorization``,我便可以继续往下,接着给个判断。毕竟,我们对 HTTP 协议还是蛮清楚的。
|
||||
|
||||
```javascript
|
||||
if (!req.headers.authorization) {
|
||||
|
|
@ -22,13 +22,13 @@ if (!req.headers.authorization) {
|
|||
}
|
||||
```
|
||||
|
||||
可是除了HTTP协议,还有MQTT和CoAP。对于MQTT协议来说,那还算好,毕竟自带授权,如:
|
||||
可是除了 HTTP 协议,还有 MQTT 和 CoAP。对于 MQTT 协议来说,那还算好,毕竟自带授权,如:
|
||||
|
||||
```bash
|
||||
mosquitto_pub -u root -P root -h localhost -d -t lettuce -m "Hello, MQTT. This is my first message."
|
||||
```
|
||||
|
||||
便可以让我们简单地完成这个功能,然而有的协议是没有这样的功能如CoAP协议中是用Option来进行授权的。现在的工具如libcoap只能有如下的简单功能
|
||||
便可以让我们简单地完成这个功能,然而有的协议是没有这样的功能如 CoAP 协议中是用 Option 来进行授权的。现在的工具如 libcoap 只能有如下的简单功能
|
||||
|
||||
```bash
|
||||
coap-client -m get coap://127.0.0.1:5683/topics/zero -T
|
||||
|
|
@ -51,9 +51,9 @@ req.setOption('Block2', [new Buffer('phodal'), new Buffer('phodal')]);
|
|||
req.end();
|
||||
```
|
||||
|
||||
写完测试脚本后发现不对了,这个不应该是测试的代码吗?于是将其放到了spec中,接着发现了上面的全部功能的实现过程为什么不用TDD实现呢?
|
||||
写完测试脚本后发现不对了,这个不应该是测试的代码吗?于是将其放到了 spec 中,接着发现了上面的全部功能的实现过程为什么不用 TDD 实现呢?
|
||||
|
||||
### 说说TDD
|
||||
### 说说 TDD
|
||||
|
||||
测试驱动开发是一个很"古老"的程序开发方法,然而由于国内的开发流程的问题——即开发人员负责功能的测试,导致这么好的一项技术没有在国内推广。
|
||||
|
||||
|
|
@ -69,30 +69,30 @@ req.end();
|
|||
1. 已经有了原型
|
||||
2. 框架设计
|
||||
|
||||
### TDD思考
|
||||
### TDD 思考
|
||||
|
||||
通常在我的理解下,TDD是可有可无的。既然我知道了我要实现的大部分功能,而且我也知道如何实现。与此同时,对Code Smell也保持着警惕、要保证功能被测试覆盖。那么,总的来说TDD带来的价值并不大。
|
||||
通常在我的理解下,TDD 是可有可无的。既然我知道了我要实现的大部分功能,而且我也知道如何实现。与此同时,对 Code Smell 也保持着警惕、要保证功能被测试覆盖。那么,总的来说 TDD 带来的价值并不大。
|
||||
|
||||
然而,在当前这种情况下,我知道我想要的功能,但是我并不理解其深层次的功能。我需要花费大量的时候来理解,它为什么是这样的,需要先有一些脚本来知道它是怎么工作的。TDD变显得很有价值,换句话来说,在现有的情况下,TDD对于我们不了解的一些事情,可以驱动出更多的开发。毕竟在我们完成测试脚本之后,我们也会发现这些测试脚本成为了代码的一部分。
|
||||
然而,在当前这种情况下,我知道我想要的功能,但是我并不理解其深层次的功能。我需要花费大量的时候来理解,它为什么是这样的,需要先有一些脚本来知道它是怎么工作的。TDD 变显得很有价值,换句话来说,在现有的情况下,TDD 对于我们不了解的一些事情,可以驱动出更多的开发。毕竟在我们完成测试脚本之后,我们也会发现这些测试脚本成为了代码的一部分。
|
||||
|
||||
在这种理想的情况下,我们为什么不TDD呢?
|
||||
在这种理想的情况下,我们为什么不 TDD 呢?
|
||||
|
||||
|
||||
## 功能测试
|
||||
|
||||
### 轻量级网站测试TWill
|
||||
### 轻量级网站测试 TWill
|
||||
|
||||
> twill was initially designed for testing Web sites, although since then people have also figured out that it's good for browsing unsuspecting Web sites.
|
||||
|
||||
之所以说轻量的原因是他是拿命令行测试的,还有DSL,还有Python。
|
||||
之所以说轻量的原因是他是拿命令行测试的,还有 DSL,还有 Python。
|
||||
|
||||
除此之外,还可以拿它做压力测试,这种压力测试和一般的不一样。可以模拟整个过程,比如同时有多少人登陆你的网站。
|
||||
|
||||
不过,它有一个限制是没有JavaScript。
|
||||
不过,它有一个限制是没有 JavaScript。
|
||||
|
||||
看了一下源码,大概原理就是用``requests``下载html,接着用``lxml``解析html,比较有意思的是内嵌了一个``DSL``。
|
||||
看了一下源码,大概原理就是用 ``requests`` 下载 html,接着用 ``lxml`` 解析 html,比较有意思的是内嵌了一个 ``DSL``。
|
||||
|
||||
这是一个Python的库。
|
||||
这是一个 Python 的库。
|
||||
|
||||
pip install twill
|
||||
|
||||
|
|
@ -100,7 +100,7 @@ req.end();
|
|||
|
||||
1.启动我们的应用。
|
||||
|
||||
2.进入twill shell
|
||||
2.进入 twill shell
|
||||
|
||||
twill-sh
|
||||
-= Welcome to twill! =-
|
||||
|
|
@ -131,7 +131,7 @@ req.end();
|
|||
fv 1 email test@tes.com
|
||||
fv 1 password test
|
||||
|
||||
6.修改action
|
||||
6.修改 action
|
||||
|
||||
formaction 1 http://127.0.0.1:5000/login
|
||||
|
||||
|
|
@ -145,7 +145,7 @@ req.end();
|
|||
|
||||
### Twill 测试脚本
|
||||
|
||||
当然我们也可以用脚本直接来测试``login.twill``:
|
||||
当然我们也可以用脚本直接来测试 ``login.twill``:
|
||||
|
||||
go http://127.0.0.1:5000/login
|
||||
|
||||
|
|
@ -193,11 +193,11 @@ req.end();
|
|||
|
||||
## Fake Server
|
||||
|
||||
实践了一下怎么用sinon去fake server,还没用respondWith,于是写一下。
|
||||
实践了一下怎么用 sinon 去 fake server,还没用 respondWith,于是写一下。
|
||||
|
||||
这里需要用到sinon框架来测试。
|
||||
这里需要用到 sinon 框架来测试。
|
||||
|
||||
当我们fetch的时候,我们就可以返回我们想要fake的结果。
|
||||
当我们 fetch 的时候,我们就可以返回我们想要 fake 的结果。
|
||||
|
||||
var data = {"id":1,"name":"Rice","type":"Good","price":12,"quantity":1,"description":"Made in China"};
|
||||
beforeEach(function() {
|
||||
|
|
@ -214,13 +214,13 @@ req.end();
|
|||
);
|
||||
});
|
||||
|
||||
于是在 afterEach 的时候,我们需要恢复这个server。
|
||||
于是在 afterEach 的时候,我们需要恢复这个 server。
|
||||
|
||||
afterEach(function() {
|
||||
this.server.restore();
|
||||
});
|
||||
|
||||
接着写一个jasmine测试来测试
|
||||
接着写一个 jasmine 测试来测试
|
||||
|
||||
describe("Collection Test", function() {
|
||||
it("should get data from the url", function() {
|
||||
|
|
|
|||
|
|
@ -105,7 +105,7 @@ numbers, objects, strings, etc. Lodash’s modular methods are great for:
|
|||
|
||||
当然了,这种事不能太过,要不然会招来一堆黑。
|
||||
|
||||
### 安装及hello, world 示例
|
||||
### 安装及 hello, world 示例
|
||||
|
||||
在我们看完了上面的介绍之后,紧接着接一个 hello, world 的示例。在运行 hello, world 之前,我们可能需要一些额外的安装工作,如:
|
||||
|
||||
|
|
|
|||
|
|
@ -1,8 +1,8 @@
|
|||
# GitHub用户分析
|
||||
# GitHub 用户分析
|
||||
|
||||
## 生成图表
|
||||
|
||||
如何分析用户的数据是一个有趣的问题,特别是当我们有大量的数据的时候。除了``matlab``,我们还可以用``numpy``+``matplotlib``
|
||||
如何分析用户的数据是一个有趣的问题,特别是当我们有大量的数据的时候。除了 ``matlab``,我们还可以用 ``numpy`` + ``matplotlib``
|
||||
|
||||
数据可以在这边寻找到
|
||||
|
||||
|
|
@ -12,11 +12,11 @@
|
|||
|
||||

|
||||
|
||||
要解析的 JSON 文件位于``data/2014-01-01-0.json``,大小6.6M,显然我们可能需要用每次只读一行的策略,这足以解释为什么诸如sublime打开的时候很慢,而现在我们只需要里面的 JSON 数据中的创建时间。。
|
||||
要解析的 JSON 文件位于``data/2014-01-01-0.json``,大小 6.6M,显然我们可能需要用每次只读一行的策略,这足以解释为什么诸如 sublime 打开的时候很慢,而现在我们只需要里面的 JSON 数据中的创建时间。。
|
||||
|
||||
==, 这个文件代表什么?
|
||||
|
||||
**2014年1月1日零时到一时,用户在 GitHub 上的操作,这里的用户指的是很多。。一共有4814条数据,从commit、create到issues都有。**
|
||||
**2014年1月1日零时到一时,用户在 GitHub 上的操作,这里的用户指的是很多。。一共有 4814 条数据,从 commit、create 到 issues 都有。**
|
||||
|
||||
### 数据解析
|
||||
|
||||
|
|
@ -35,7 +35,7 @@ lin = json.loads(line)
|
|||
date = dateutil.parser.parse(lin["created_at"])
|
||||
```
|
||||
|
||||
这里用到了``dateutil``,因为新鲜出炉的数据是string需要转换为``dateutil``,再到数据放到数组里头。最后有就有了``parse_data``
|
||||
这里用到了 ``dateutil``,因为新鲜出炉的数据是 string 需要转换为 ``dateutil``,再到数据放到数组里头。最后有就有了 ``parse_data``
|
||||
|
||||
```python
|
||||
def parse_data(jsonfile):
|
||||
|
|
@ -144,7 +144,7 @@ draw_date("data/2014-01-01-0.json")
|
|||
|
||||
a fulltime hacker who works best in the evening (around 8 pm).
|
||||
|
||||
不过这个是osrc的分析结果。
|
||||
不过这个是 osrc 的分析结果。
|
||||
|
||||
### python GitHub 每周情况分析
|
||||
|
||||
|
|
@ -259,7 +259,7 @@ if __name__ == '__main__':
|
|||
|
||||
### SQLite3
|
||||
|
||||
我们创建了一个名为``userdata.db``的数据库文件,然后创建了一个表,里面有owner,language,eventtype,name url
|
||||
我们创建了一个名为 ``userdata.db`` 的数据库文件,然后创建了一个表,里面有 owner, language, eventtype, name url
|
||||
|
||||
```python
|
||||
def init_db():
|
||||
|
|
@ -282,7 +282,7 @@ def get_count(username):
|
|||
return count, userinfo
|
||||
```
|
||||
|
||||
当我查询``gmszone``的时候,也就是我自己就会有如下的结果
|
||||
当我查询 ``gmszone`` 的时候,也就是我自己就会有如下的结果
|
||||
|
||||
```bash
|
||||
(u'gmszone', u'ForkEvent', u'RESUME', u'TeX', u'https://github.com/gmszone/RESUME')
|
||||
|
|
@ -297,9 +297,9 @@ def get_count(username):
|
|||
109
|
||||
````
|
||||
|
||||
一共有109个事件,有``Watch``,``Create``,``Push``,``Fork``还有其他的,
|
||||
项目主要有``iot``,``RESUME``,``iot-dashboard``,``wechat-wordpress``,
|
||||
接着就是语言了,``Tex``,``Javascript``,``Ruby``,接着就是项目的url了。
|
||||
一共有109个事件,有 ``Watch``, ``Create``, ``Push``, ``Fork`` 还有其他的,
|
||||
项目主要有``iot``, ``RESUME``, ``iot-dashboard``, ``wechat-wordpress``,
|
||||
接着就是语言了,``Tex``, ``Javascript``, ``Ruby``,接着就是项目的 url 了。
|
||||
|
||||
值得注意的是。
|
||||
|
||||
|
|
@ -307,9 +307,9 @@ def get_count(username):
|
|||
-rw-r--r-- 1 fdhuang staff 905M Apr 12 14:59 userdata.db
|
||||
```
|
||||
|
||||
这个数据库文件有**905M**,不过查询结果相当让人满意,至少相对于原来的结果来说。
|
||||
这个数据库文件有 **905M**,不过查询结果相当让人满意,至少相对于原来的结果来说。
|
||||
|
||||
Python自带了对SQLite3的支持,然而我们还需要安装SQLite3
|
||||
Python 自带了对 SQLite3 的支持,然而我们还需要安装 SQLite3
|
||||
|
||||
```bash
|
||||
brew install sqlite3
|
||||
|
|
@ -321,23 +321,23 @@ brew install sqlite3
|
|||
sudo port install sqlite3
|
||||
```
|
||||
|
||||
或者是Ubuntu的
|
||||
或者是 Ubuntu 的
|
||||
|
||||
```bash
|
||||
sudo apt-get install sqlite3
|
||||
```
|
||||
|
||||
openSUSE自然就是
|
||||
openSUSE 自然就是
|
||||
|
||||
```bash
|
||||
sudo zypper install sqlite3
|
||||
```
|
||||
|
||||
不过,用yast2也很不错,不是么。。
|
||||
不过,用 yast2 也很不错,不是么。。
|
||||
|
||||
### 数据导入
|
||||
|
||||
需要注意的是这里是需要 Python 2.7,起源于对gzip的上下文管理器的支持问题
|
||||
需要注意的是这里是需要 Python 2.7,起源于对 gzip 的上下文管理器的支持问题
|
||||
|
||||
```python
|
||||
def handle_gzip_file(filename):
|
||||
|
|
@ -389,11 +389,11 @@ def build_db_with_gzip():
|
|||
c.close()
|
||||
```
|
||||
|
||||
``executemany``可以插入多条数据,对于我们的数据来说,一小时的文件大概有五六千个会符合我们上面的安装,也就是有``actor``又有``type``才是我们需要记录的数据,我们只需要统计用户的那些事件,而非全部的事件。
|
||||
``executemany`` 可以插入多条数据,对于我们的数据来说,一小时的文件大概有五六千个会符合我们上面的安装,也就是有 ``actor`` 又有 ``type`` 才是我们需要记录的数据,我们只需要统计用户的那些事件,而非全部的事件。
|
||||
|
||||
我们需要去遍历文件,然后找到合适的部分,这里只是要找``2014-03-01``到``2014-03-31``的全部事件,而光这些数据的gz文件就有1.26G,同上面那些解压为 JSON 文件显得不合适,只能用遍历来处理。
|
||||
我们需要去遍历文件,然后找到合适的部分,这里只是要找``2014-03-01``到``2014-03-31``的全部事件,而光这些数据的 gz 文件就有 1.26G,同上面那些解压为 JSON 文件显得不合适,只能用遍历来处理。
|
||||
|
||||
这里参考了osrc项目中的写法,或者说直接复制过来。
|
||||
这里参考了 osrc 项目中的写法,或者说直接复制过来。
|
||||
|
||||
首先是正规匹配
|
||||
|
||||
|
|
@ -401,11 +401,11 @@ def build_db_with_gzip():
|
|||
date_re = re.compile(r"([0-9]{4})-([0-9]{2})-([0-9]{2})-([0-9]+)\.json.gz")
|
||||
```
|
||||
|
||||
不过主要的还是在于``glob.glob``
|
||||
不过主要的还是在于 ``glob.glob``
|
||||
|
||||
> glob是 Python 自己带的一个文件操作相关模块,用它可以查找符合自己目的的文件,就类似于Windows下的文件搜索,支持通配符操作。
|
||||
|
||||
这里也就用上了``gzip.GzipFile``又一个不错的东西。
|
||||
这里也就用上了 ``gzip.GzipFile`` 又一个不错的东西。
|
||||
|
||||
最后代码可以见
|
||||
|
||||
|
|
@ -425,7 +425,7 @@ pipe.zscore('osrc:user',"gmszone")
|
|||
pipe.execute()
|
||||
```
|
||||
|
||||
系统返回了``227.0``,试试别人。
|
||||
系统返回了 ``227.0``,试试别人。
|
||||
|
||||
```bash
|
||||
>>> pipe.zscore('osrc:user',"dfm")
|
||||
|
|
@ -458,9 +458,9 @@ pipe.execute()
|
|||
|
||||

|
||||
|
||||
蓝色的就是push事件,黄色的是create等等。
|
||||
蓝色的就是 push 事件,黄色的是 create 等等。
|
||||
|
||||
到这里我们算是知道了OSRC的数据库部分是如何工作的。
|
||||
到这里我们算是知道了 OSRC 的数据库部分是如何工作的。
|
||||
|
||||
#### Redis 查询
|
||||
|
||||
|
|
@ -503,7 +503,7 @@ def get_vector(user, pipe=None):
|
|||
['alesdokshanin', 'hjiawei', 'andrewreedy', 'christj6', '1995eaton']
|
||||
```
|
||||
|
||||
osrc最有意思的一部分莫过于flann,当然说的也是系统后台的设计的一个很关键及有意思的部分。
|
||||
osrc 最有意思的一部分莫过于 flann,当然说的也是系统后台的设计的一个很关键及有意思的部分。
|
||||
|
||||
## 邻近算法与相似用户
|
||||
|
||||
|
|
@ -517,7 +517,7 @@ osrc最有意思的一部分莫过于flann,当然说的也是系统后台的
|
|||
[227.0, {'1': '51', '0': '41', '3': '17', '2': '34', '5': '28', '4': '22', '6': '34'}, [('PushEvent', 154.0), ('CreateEvent', 41.0), ('WatchEvent', 18.0), ('GollumEvent', 8.0), ('MemberEvent', 3.0), ('ForkEvent', 2.0), ('ReleaseEvent', 1.0)], 0, 0, 0, 11, [('CSS', 74.0), ('JavaScript', 60.0), ('Ruby', 12.0), ('TeX', 6.0), ('Python', 6.0), ('Java', 5.0), ('C++', 5.0), ('Assembly', 5.0), ('C', 3.0), ('Emacs Lisp', 2.0), ('Arduino', 2.0)]]
|
||||
```
|
||||
|
||||
在代码中是构建了一个points.h5的文件来分析每个用户的points,之后再记录到hdf5文件中。
|
||||
在代码中是构建了一个 points.h5 的文件来分析每个用户的 points,之后再记录到 hdf5 文件中。
|
||||
|
||||
```
|
||||
[ 0.00438596 0.18061674 0.2246696 0.14977974 0.07488987 0.0969163
|
||||
|
|
@ -539,7 +539,7 @@ osrc最有意思的一部分莫过于flann,当然说的也是系统后台的
|
|||
- 贡献的数量,连接以及语言
|
||||
- 最多的语言
|
||||
|
||||
osrc中用于解析的代码
|
||||
osrc 中用于解析的代码
|
||||
|
||||
```python
|
||||
def parse_vector(results):
|
||||
|
|
@ -576,7 +576,7 @@ def parse_vector(results):
|
|||
return points
|
||||
```
|
||||
|
||||
这样也就返回我们需要的点数,然后我们可以用``get_points``来获取这些
|
||||
这样也就返回我们需要的点数,然后我们可以用 ``get_points`` 来获取这些
|
||||
|
||||
```python
|
||||
def get_points(usernames):
|
||||
|
|
|
|||
|
|
@ -1,13 +1,13 @@
|
|||
如何在GitHub"寻找灵感(fork)"
|
||||
如何在 GitHub "寻找灵感(fork)"
|
||||
===
|
||||
|
||||
> 重造轮子是重新创造一个已有的或是已被其他人优化的基本方法。
|
||||
|
||||
最近萌发了一个想法写游戏引擎,之前想着做一个JavaScript前端框架。看看,这个思路是怎么来的。
|
||||
最近萌发了一个想法写游戏引擎,之前想着做一个 JavaScript 前端框架。看看,这个思路是怎么来的。
|
||||
|
||||
## Lettuce构建过程
|
||||
## Lettuce 构建过程
|
||||
|
||||
> Lettuce是一个简约的移动开发框架。
|
||||
> Lettuce 是一个简约的移动开发框架。
|
||||
|
||||
故事的出发点是这样的:``写了很多代码,用的都是框架,最后不知道收获什么了``?事实也是如此,当自己做了一些项目之后,发现最后什么也没有收获到。于是,就想着做一个框架。
|
||||
|
||||
|
|
@ -15,10 +15,10 @@
|
|||
|
||||
有这样的几个前提
|
||||
|
||||
- 为什么我只需要jQuery里的选择器、Ajax要引入那么重的库呢?
|
||||
- 为什么我只需要一个Template,却想着用Mustache
|
||||
- 为什么我需要一个Router,却要用Backbone呢?
|
||||
- 为什么我需要的是一个isObject函数,却要用到整个Underscore?
|
||||
- 为什么我只需要 jQuery 里的选择器、Ajax 要引入那么重的库呢?
|
||||
- 为什么我只需要一个 Template,却想着用 Mustache
|
||||
- 为什么我需要一个 Router,却要用 Backbone 呢?
|
||||
- 为什么我需要的是一个 isObject 函数,却要用到整个 Underscore?
|
||||
|
||||
我想要的只是一个简单的功能,而我不想引入一个庞大的库。换句话说,我只需要不同库里面的一小部分功能,而不是一个库。
|
||||
|
||||
|
|
@ -34,12 +34,12 @@
|
|||
- Class类(ps:没有一个好的类使用的方式)
|
||||
- Template 一个简单的模板引擎
|
||||
- Router 用来控制页面的路由
|
||||
- Ajax 基本的Ajax Get/Post请求
|
||||
- Ajax 基本的 Ajax Get/Post 请求
|
||||
|
||||
在做一些实际的项目中,还遇到了这样的一些功能支持:
|
||||
|
||||
- Effect 简单的一些页面效果
|
||||
- AMD支持
|
||||
- AMD 支持
|
||||
|
||||
而我们有一个前提是要保持这个库尽可能的小、同时我们还需要有测试。
|
||||
|
||||
|
|
@ -49,14 +49,14 @@
|
|||
|
||||
#### 生成框架
|
||||
|
||||
因为Yeoman可以生成一个简单的轮廓,所以我们可以用它来生成这个项目的骨架。
|
||||
因为 Yeoman 可以生成一个简单的轮廓,所以我们可以用它来生成这个项目的骨架。
|
||||
|
||||
- Gulp
|
||||
- Jasmine
|
||||
|
||||
#### 寻找
|
||||
|
||||
在GitHub上搜索了一个看到了下面的几个结果:
|
||||
在 GitHub 上搜索了一个看到了下面的几个结果:
|
||||
|
||||
- [https://github.com/then/promise](https://github.com/then/promise)
|
||||
- [https://github.com/reactphp/promise](https://github.com/reactphp/promise)
|
||||
|
|
@ -64,7 +64,7 @@
|
|||
- [https://github.com/petkaantonov/bluebird](https://github.com/petkaantonov/bluebird)
|
||||
- [https://github.com/cujojs/when](https://github.com/cujojs/when)
|
||||
|
||||
但是显然,他们都太重了。事实上,对于一个库来说,80%的人只需要其中20%的代码。于是,找到了[https://github.com/stackp/promisejs](https://github.com/stackp/promisejs),看了看用法,这就是我们需要的功能:
|
||||
但是显然,他们都太重了。事实上,对于一个库来说,80% 的人只需要其中 20% 的代码。于是,找到了[https://github.com/stackp/promisejs](https://github.com/stackp/promisejs),看了看用法,这就是我们需要的功能:
|
||||
|
||||
```javascript
|
||||
function late(n) {
|
||||
|
|
@ -94,7 +94,7 @@ late(100).then(
|
|||
);
|
||||
```
|
||||
|
||||
接着打开看看Promise对象,有我们需要的功能,但是又有一些功能超出我的需求。接着把自己不需要的需求去掉,这里函数最后就变成了
|
||||
接着打开看看 Promise 对象,有我们需要的功能,但是又有一些功能超出我的需求。接着把自己不需要的需求去掉,这里函数最后就变成了
|
||||
|
||||
```javascript
|
||||
function Promise() {
|
||||
|
|
@ -131,7 +131,7 @@ var promise = {
|
|||
};
|
||||
```
|
||||
|
||||
需要注意的是:``License``,不同的软件有不同的License,如MIT、GPL等等。最好能在遵循协议的情况下,使用别人的代码。
|
||||
需要注意的是:``License``,不同的软件有不同的 License,如 MIT、GPL 等等。最好能在遵循协议的情况下,使用别人的代码。
|
||||
|
||||
### 实现第二个需求
|
||||
|
||||
|
|
|
|||
|
|
@ -5,9 +5,9 @@
|
|||
|
||||
我们并不建议所有的读者都直接看最新的代码,正确的姿势应该是:
|
||||
|
||||
- clone某个项目的代码到本地
|
||||
- 查看这个项目的release列表
|
||||
- 找到一个看得懂的release版本,如1.0或者更早的版本
|
||||
- clone 某个项目的代码到本地
|
||||
- 查看这个项目的 release 列表
|
||||
- 找到一个看得懂的 release 版本,如 1.0 或者更早的版本
|
||||
- 读懂上一个版本的代码
|
||||
- 向后阅读大版本的源码
|
||||
- 读最新的源码
|
||||
|
|
@ -16,30 +16,30 @@
|
|||
|
||||
## 阅读过程
|
||||
|
||||
在我阅读的前端库、Python后台库的过程中,我们都是以造轮子为目的展开的。所以在最开始的时候,我需要一个可以工作,并且拥有我想要的功能的版本。
|
||||
在我阅读的前端库、Python 后台库的过程中,我们都是以造轮子为目的展开的。所以在最开始的时候,我需要一个可以工作,并且拥有我想要的功能的版本。
|
||||
|
||||

|
||||
|
||||
紧接着,我就可以开始去实践这个版本中的一些功能,并理解他们是怎么工作的。再用`git`大法展开之前修改的内容,可以使用IDE自带的Diff工具:
|
||||
紧接着,我就可以开始去实践这个版本中的一些功能,并理解他们是怎么工作的。再用 `git` 大法展开之前修改的内容,可以使用 IDE 自带的 Diff 工具:
|
||||
|
||||

|
||||
|
||||
或者类似于`SourceTree`这样的工具,来查看修改的内容。
|
||||
或者类似于 `SourceTree` 这样的工具,来查看修改的内容。
|
||||
|
||||
在我们理解了基本的核心功能后,我们就可以向后查看大、中版本的更新内容了。
|
||||
|
||||
开始之前,我们希望大家对版本号管理有一些基本的认识。
|
||||
## 版本号管理
|
||||
|
||||
我最早阅读的开始软件是Linux,而下面则是Linux的Release过程:
|
||||
我最早阅读的开始软件是 Linux,而下面则是 Linux 的 Release 过程:
|
||||
|
||||

|
||||
|
||||
表格源自一本书叫《Linux内核0.11(0.95)完全注释》,简单地再介绍一下:
|
||||
|
||||
- 版本0.00是一个hello,world程序
|
||||
- 版本0.01包含了可以工作的代码
|
||||
- 版本0.11是基本可以正常的版本
|
||||
- 版本 0.00 是一个 hello, world 程序
|
||||
- 版本 0.01 包含了可以工作的代码
|
||||
- 版本 0.11 是基本可以正常的版本
|
||||
|
||||
这里就要扯到《GNU 风格的版本号管理策略》:
|
||||
|
||||
|
|
@ -52,22 +52,22 @@
|
|||
因此,我们可以得到几个简单的结论:
|
||||
|
||||
- 我们需要阅读最早的有核心代码的版本
|
||||
- 我们需要阅读1.0版本的Release
|
||||
- 往后每一次大的Release我们都需要了解一下
|
||||
- 我们需要阅读 1.0 版本的 Release
|
||||
- 往后每一次大的 Release 我们都需要了解一下
|
||||
|
||||
## 示例
|
||||
|
||||
以Flask为例:
|
||||
以 Flask 为例:
|
||||
|
||||
一、先Clone它。
|
||||
一、先 Clone 它。
|
||||
|
||||

|
||||
|
||||
二、从Release页面找到它的早期版本:
|
||||
二、从 Release 页面找到它的早期版本:
|
||||
|
||||

|
||||
|
||||
三、 从上面拿到它的提交号`8605cc3`,然后checkout到这次提交,查看功能。在这个版本里,一共有六百多行代码
|
||||
三、 从上面拿到它的提交号 `8605cc3`,然后 checkout 到这次提交,查看功能。在这个版本里,一共有六百多行代码
|
||||
|
||||

|
||||
|
||||
|
|
@ -77,12 +77,12 @@
|
|||
|
||||

|
||||
|
||||
然后查看它的`flask.py`文件,只有简单的三百多行,并且还包含一系列注释:
|
||||
然后查看它的 `flask.py` 文件,只有简单的三百多行,并且还包含一系列注释:
|
||||
|
||||

|
||||
|
||||
五、接着,再回过头去阅读
|
||||
|
||||
- 0.1版本
|
||||
- 0.1 版本
|
||||
- 。。。
|
||||
- 最新的0.10.1版本
|
||||
- 最新的 0.10.1 版本
|
||||
|
|
|
|||
|
|
@ -1,39 +1,39 @@
|
|||
GitHub连击
|
||||
GitHub 连击
|
||||
===
|
||||
|
||||
## 100天
|
||||
## 100 天
|
||||
|
||||
我也是蛮拼的,虽然我想的只是在GitHub上连击100~200天,然而到了今天也算不错。
|
||||
我也是蛮拼的,虽然我想的只是在 GitHub 上连击 100~200 天,然而到了今天也算不错。
|
||||
|
||||

|
||||
|
||||
``在不停地造轮子的过程中,也不停地造车子。``
|
||||
|
||||
在那篇连续冲击365天的文章出现之前,我们公司的大大([https://github.com/dreamhead](https://github.com/dreamhead))也曾经在公司内部说过,天天commit什么的。当然这不是我的动力,在连击140天之前
|
||||
在那篇连续冲击 365 天的文章出现之前,我们公司的大大([https://github.com/dreamhead](https://github.com/dreamhead))也曾经在公司内部说过,天天 commit 什么的。当然这不是我的动力,在连击 140 天之前
|
||||
|
||||
- 给过google的``ngx_speed``、``node-coap``等项目创建过pull request
|
||||
- 给过 google 的``ngx_speed``、``node-coap`` 等项目创建过 pull request
|
||||
- 也有``free-programming-books``、``free-programming-books-zh_CN``这样的项目。
|
||||
- 当然还有一个连击20天。
|
||||
- 当然还有一个连击 20 天。
|
||||
|
||||
对比了一下365天连击的commit,我发现我在total上整整多了近0.5倍。
|
||||
对比了一下 365 天连击的 commit,我发现我在 total 上整整多了近 0.5 倍。
|
||||
|
||||

|
||||
|
||||
同时这似乎也意味着,我每天的commit数与之相比多了很多。
|
||||
同时这似乎也意味着,我每天的 commit 数与之相比多了很多。
|
||||
|
||||
在连击20的时候,有这样的问题:*为了commit而commit代码*,最后就放弃了。
|
||||
在连击20的时候,有这样的问题:*为了 commit 而 commit 代码*,最后就放弃了。
|
||||
|
||||
而现在是``为了填坑而commit``,为自己挖了太多的想法。
|
||||
而现在是``为了填坑而 commit``,为自己挖了太多的想法。
|
||||
|
||||
### 40天的提升
|
||||
### 40 天的提升
|
||||
|
||||
当时我需要去印度接受毕业生培训,大概有5周左右,想着总不能空手而归。于是在国庆结束后有了第一次commit,当时旅游归来,想着自己在不同的地方有不同的照片,于是这个repo的名字是 [onmap](https://github.com/phodal/onmap)——将自己的照片显示在地图上的拍摄地点(手机是Lumia 920)。然而,中间因为修改账号的原因,丢失了commit。
|
||||
当时我需要去印度接受毕业生培训,大概有 5 周左右,想着总不能空手而归。于是在国庆结束后有了第一次 commit,当时旅游归来,想着自己在不同的地方有不同的照片,于是这个 repo 的名字是 [onmap](https://github.com/phodal/onmap)——将自己的照片显示在地图上的拍摄地点(手机是 Lumia 920)。然而,中间因为修改账号的原因,丢失了 commit。
|
||||
|
||||
再从印度说起,当时主要维护三个repo:
|
||||
再从印度说起,当时主要维护三个 repo:
|
||||
|
||||
- 物联网的CoAP协议
|
||||
- 物联网的 CoAP 协议
|
||||
- [一步步设计物联网系统](https://github.com/phodal/designiot)的电子书
|
||||
- 一个Node.js + JS的网站
|
||||
- 一个 Node.js + JS 的网站
|
||||
|
||||
说说最后一个,最后一个是练习的项目。因为当时培训比较无聊,业余时间比较多,英语不好,加上听不懂印度人的话。晚上基本上是在住的地方默默地写代码,所以当时的目标有这么几个:
|
||||
|
||||
|
|
@ -41,62 +41,62 @@ GitHub连击
|
|||
- 测试覆盖率
|
||||
- 代码整洁
|
||||
|
||||
这也就是为什么那个repo有这样的一行:
|
||||
这也就是为什么那个 repo 有这样的一行:
|
||||
|
||||

|
||||
|
||||
做到98%的覆盖率也算蛮拼的,当然还有Code Climate也达到了4.0,也有了112个commits。因此也带来了一些提高:
|
||||
做到 98% 的覆盖率也算蛮拼的,当然还有 Code Climate 也达到了 4.0,也有了 112 个 commits。因此也带来了一些提高:
|
||||
|
||||
- 提高了代码的质量(code climate比jslint更注重重复代码等等一些bad smell)。
|
||||
- 对于Mock、Stub、FakesServer等用法有更好的掌握
|
||||
- 提高了代码的质量(code climate 比 jslint 更注重重复代码等等一些 bad smell)。
|
||||
- 对于 Mock、Stub、FakesServer 等用法有更好的掌握
|
||||
- 可以持续地交付软件(版本管理、自动测试、CI、部署等等)
|
||||
|
||||
### 100天的挑战
|
||||
### 100 天的挑战
|
||||
|
||||
(ps:从印度回来之后,由于女朋友在泰国实习,有了更多的时间可以看书、写代码)
|
||||
|
||||
有意思的是越到中间的一些时间,commits的次数上去了,除了一些简单的pull request,还有一些新的轮子出现了。
|
||||
有意思的是越到中间的一些时间,commits 的次数上去了,除了一些简单的 pull request,还有一些新的轮子出现了。
|
||||
|
||||

|
||||
|
||||
这是上一星期的commits,这也就意味着,在一星期里面,我需要在8个repo里切换。而现在我又有了一个新的idea,这时就发现了一堆的问题:
|
||||
这是上一星期的 commits,这也就意味着,在一星期里面,我需要在 8 个 repo 里切换。而现在我又有了一个新的 idea,这时就发现了一堆的问题:
|
||||
|
||||
- 今天工作在这个repo上,突然发现那个repo上有issue,需要去修复,于是就放下了当前的代码。
|
||||
- 在不同的repo间切换容易分散精力
|
||||
- 今天工作在这个 repo 上,突然发现那个 repo 上有 issue,需要去修复,于是就放下了当前的代码。
|
||||
- 在不同的 repo 间切换容易分散精力
|
||||
- 很容易就发现有太多的功能可以实现,但是时间是有限的。
|
||||
- 没有足够的空闲时间,除了周末。
|
||||
- 希望去寻找那些有兴趣的人,然而却发现原来没有那么多时间去找人。
|
||||
|
||||
### 140天的希冀
|
||||
### 140 天的希冀
|
||||
|
||||
在经历了100天之后,似乎整个人都轻松了,毕竟目标是100~200天。似乎到现在,也不会有什么特殊的情怀,除了一些希冀。
|
||||
在经历了 100 天之后,似乎整个人都轻松了,毕竟目标是 100~200 天。似乎到现在,也不会有什么特殊的情怀,除了一些希冀。
|
||||
|
||||
当然,对于一个开源项目的作者来说,最好有下面的情况:
|
||||
|
||||
- 很多人知道了这个项目
|
||||
- 很多人用它的项目。
|
||||
- 在某些可以用这个项目快速解决问题的地方提到了这个项目
|
||||
- 提了bug、issue、问题。
|
||||
- 提了bug,并解决了。(ps:这是最理想的情况)
|
||||
- 提了 bug、issue、问题。
|
||||
- 提了 bug,并解决了。(ps:这是最理想的情况)
|
||||
|
||||
|
||||
## 200天的Showcase
|
||||
## 200 天的 Showcase
|
||||
|
||||
今天是我连续泡在GitHub上的第200天,也是蛮高兴的,终于到达了:
|
||||
今天是我连续泡在 GitHub 上的第200天,也是蛮高兴的,终于到达了:
|
||||
|
||||

|
||||
|
||||
故事的背影是:去年国庆完后要去印度接受毕业生培训——就是那个神奇的国度。但是在去之前已经在项目待了九个多月,项目上的挑战越来越少,在印度的时间又算是比较多。便给自己设定了一个长期的goal,即100~200天的longest streak。
|
||||
故事的背影是:去年国庆完后要去印度接受毕业生培训——就是那个神奇的国度。但是在去之前已经在项目待了九个多月,项目上的挑战越来越少,在印度的时间又算是比较多。便给自己设定了一个长期的 goal,即 100~200 天的 longest streak。
|
||||
|
||||
或许之前你看到过一篇文章[让我们连击](https://github.com/phodal/github-roam/blob/master/chapters/12-streak-your-github.md),那时已然140天,只是还是浑浑噩噩。到了今天,渐渐有了一个更清晰地思路。
|
||||
或许之前你看到过一篇文章[让我们连击](https://github.com/phodal/github-roam/blob/master/chapters/12-streak-your-github.md),那时已然 140 天,只是还是浑浑噩噩。到了今天,渐渐有了一个更清晰地思路。
|
||||
|
||||
先让我们来一下ShowCase,然后再然后,下一篇我们再继续。
|
||||
先让我们来一下 ShowCase,然后再然后,下一篇我们再继续。
|
||||
|
||||
### 一些项目简述
|
||||
|
||||
上面说到的培训一开始是用Java写的一个网站,有自动测试、CI、CD等等。由于是内部组队培训,代码不能公开等等因素,加之做得无聊。顺手,拿Node.js +RESTify 做了Server,Backbone + RequireJS + jQuery 做了前台的逻辑。于是在那个日子里,也在维护一些旧的repo,如[iot-coap](https://github.com/phodal/iot-coap)、[iot](https://github.com/phodal/iot),前者是我拿到WebStorm开源License的Repo,后者则是毕业设计。
|
||||
上面说到的培训一开始是用 Java 写的一个网站,有自动测试、CI、CD 等等。由于是内部组队培训,代码不能公开等等因素,加之做得无聊。顺手,拿 Node.js +RESTify 做了 Server,Backbone + RequireJS + jQuery 做了前台的逻辑。于是在那个日子里,也在维护一些旧的 repo,如 [iot-coap](https://github.com/phodal/iot-coap)、[iot](https://github.com/phodal/iot),前者是我拿到 WebStorm 开源 License 的 Repo,后者则是毕业设计。
|
||||
|
||||
对于这样一个项目也需要有测试、自动化测试、CI等等。CI用的是Travics-CI。总体的技术构架如下:
|
||||
对于这样一个项目也需要有测试、自动化测试、CI 等等。CI 用的是 Travics-CI。总体的技术构架如下:
|
||||
|
||||
#### 技术栈
|
||||
|
||||
|
|
@ -120,7 +120,7 @@ GitHub连击
|
|||
- Mocha
|
||||
- Jasmine-jQuery
|
||||
|
||||
一直写到五星期的培训结束, 只是没有自动部署。想想就觉得可以用github-page的项目多好~~。
|
||||
一直写到五星期的培训结束,只是没有自动部署。想想就觉得可以用 github-page 的项目多好~~。
|
||||
|
||||
过程中还有一些有意思的小项目,如:
|
||||
|
||||
|
|
@ -149,7 +149,7 @@ GitHub连击
|
|||
|
||||
代码:[https://github.com/phodal/skillock](https://github.com/phodal/skillock)
|
||||
|
||||
#### 技能树Sherlock
|
||||
#### 技能树 Sherlock
|
||||
|
||||
- D3.js
|
||||
- Dagre-D3.js
|
||||
|
|
@ -199,17 +199,17 @@ GitHub连击
|
|||
|
||||
#### 其他
|
||||
|
||||
虽然技术栈上主要集中在Python、JavaScript,当然还有一些Ruby、Pig、Shell、Java的代码,只是我还是习惯用Python和JavaScript。一些用到觉得不错的框架:
|
||||
虽然技术栈上主要集中在 Python、JavaScript,当然还有一些 Ruby、Pig、Shell、Java 的代码,只是我还是习惯用 Python 和 JavaScript。一些用到觉得不错的框架:
|
||||
|
||||
- Ionic:开始Hybird移动应用。
|
||||
- Django:Python Web开发利器。
|
||||
- Flask:Python Web开发小刀。
|
||||
- Ionic:开始 Hybird 移动应用。
|
||||
- Django:Python Web 开发利器。
|
||||
- Flask:Python Web 开发小刀。
|
||||
- RequireJS:管理 JS 依赖。
|
||||
- Backbone:Model + View + Router。
|
||||
- Angluar:...。
|
||||
- Knockout:MVV*。
|
||||
- React:据说会火。
|
||||
- Cordova:Hybird应用基础。
|
||||
- Cordova:Hybird 应用基础。
|
||||
|
||||
还应该有
|
||||
|
||||
|
|
@ -220,33 +220,33 @@ GitHub连击
|
|||
- MongoDB
|
||||
- Redis
|
||||
|
||||
## 365天
|
||||
## 365 天
|
||||
|
||||
> 给你一年的时间,你会怎样去提高你的水平???
|
||||
|
||||

|
||||
|
||||
正值这难得的sick leave(万恶的空气),码文一篇来记念一个过去的366天里。尽管想的是在今年里写一个可持续的开源框架,但是到底这依赖于一个好的idea。在我的[GitHub 孵化器](http://github.com/phodal/ideas) 页面上似乎也没有一个特别让我满意的想法,虽然上面有各种不样有意思的ideas。多数都是在过去的一年是完成的,然而有一些也是还没有做到的。
|
||||
正值这难得的 sick leave(万恶的空气),码文一篇来记念一个过去的 366 天里。尽管想的是在今年里写一个可持续的开源框架,但是到底这依赖于一个好的 idea。在我的 [GitHub 孵化器](http://github.com/phodal/ideas) 页面上似乎也没有一个特别让我满意的想法,虽然上面有各种不样有意思的 ideas。多数都是在过去的一年是完成的,然而有一些也是还没有做到的。
|
||||
|
||||
尽管一直在GitHub上连击看上去似乎是没有多大必要的,但是人总得有点追求。如果正是漫无目的,却又想着提高技术的同时,为什么不去试试?毕竟技术非常好、不需要太多练习的人只是少数,似乎这样的人是不存在的。大多数的人都是经过练习之后,才会达到别人口中的“技术好”。
|
||||
尽管一直在 GitHub 上连击看上去似乎是没有多大必要的,但是人总得有点追求。如果正是漫无目的,却又想着提高技术的同时,为什么不去试试?毕竟技术非常好、不需要太多练习的人只是少数,似乎这样的人是不存在的。大多数的人都是经过练习之后,才会达到别人口中的“技术好”。
|
||||
|
||||
这让我想起了充斥着各种气味的知乎上的一些问题,在一些智商被完虐的话题里,无一不是因为那些人学得比别人早——哪来的天才?所谓的天才,应该是未来的智能生命一般,一出生什么都知道。如果并非如此,那只是说明他练习到位了。
|
||||
|
||||
练习不到位便意味着,即使你练习的时候是一万小时的两倍,那也是无济于事的。如果你学得比别人晚,在**很长的一段时间里**(可能直到进棺材)输给别人是必然的——落后就要挨打。就好像我等毕业于一所二本垫底的学校里,如果在过去我一直保持着和别人(各种重点)一样的学习速度,那么我只能一直是Loser。
|
||||
练习不到位便意味着,即使你练习的时候是一万小时的两倍,那也是无济于事的。如果你学得比别人晚,在**很长的一段时间里**(可能直到进棺材)输给别人是必然的——落后就要挨打。就好像我等毕业于一所二本垫底的学校里,如果在过去我一直保持着和别人(各种重点)一样的学习速度,那么我只能一直是 Loser。
|
||||
|
||||
需要注意的是,对你来说考上二本很难,并不是因为你比别人笨。教育资源分配不均的问题,在某种程度上导致了新的阶级制度的出现。如[我的首页](https://www.phodal.com/)说的那样:**THE ONLY FAIR IS NOT FAIR**——唯一公平的是它是不公平的。我们可以做的还有很多——**CREATE & SHARE**。真正的不幸是,因为营养不良导致的教育问题。
|
||||
|
||||
于是在想明白了很多事的时候起,便有了Re-Practise这样的计划,而365天只是中间的一个产物。
|
||||
于是在想明白了很多事的时候起,便有了 Re-Practise 这样的计划,而 365 天只是中间的一个产物。
|
||||
|
||||
### 编程的基础能力
|
||||
|
||||
虽说算法很重要,但是编码才是基础能力。算法与编程在某种程度上是不同的领域,算法编程是在编程上面的一级。算法写得再好,如果别人很难直接拿来复用,在别人眼里就是shit。想出能work的代码一件简单的事,学会对其重构,使之变得更易读就是一件有意义的事。
|
||||
虽说算法很重要,但是编码才是基础能力。算法与编程在某种程度上是不同的领域,算法编程是在编程上面的一级。算法写得再好,如果别人很难直接拿来复用,在别人眼里就是 shit。想出能 work 的代码一件简单的事,学会对其重构,使之变得更易读就是一件有意义的事。
|
||||
|
||||
于是,在某一时刻在GitHub上创建了一个组织,叫[Artisan Stack](https://github.com/artisanstack)。当时想的是在GitHub寻找一些JavaScript项目,对其代码进行重构。但是到底是影响力不够哈,参与的人数比较少。
|
||||
于是,在某一时刻在 GitHub 上创建了一个组织,叫 [Artisan Stack](https://github.com/artisanstack)。当时想的是在 GitHub 寻找一些 JavaScript 项目,对其代码进行重构。但是到底是影响力不够哈,参与的人数比较少。
|
||||
|
||||
#### 重构
|
||||
|
||||
如果你懂得如何写出高可读的代码,那么我想你是不需要这个的,但是这意味着你花了更多的时候在思考上了。当谈论重构的时候,让我想起了TDD(测试驱动开发)。即使不是TDD,那么如果你写着测试,那也是可以重构的。(之前写过一些利用Intellij IDEA重构的文章:[提炼函数](https://www.phodal.com/blog/intellij-idea-refactor-extract-method/)、[以查询取代临时变量](https://www.phodal.com/blog/intellij-idea-refactor-replace-temp-with-query/)、[重构与Intellij Idea初探](https://www.phodal.com/blog/thoughtworks-refactor-and-intellij-idea/)、[内联函数](https://www.phodal.com/blog/intellij-idea-refactor-inline-method/))
|
||||
如果你懂得如何写出高可读的代码,那么我想你是不需要这个的,但是这意味着你花了更多的时候在思考上了。当谈论重构的时候,让我想起了 TDD(测试驱动开发)。即使不是 TDD,那么如果你写着测试,那也是可以重构的。(之前写过一些利用 Intellij IDEA 重构的文章:[提炼函数](https://www.phodal.com/blog/intellij-idea-refactor-extract-method/)、[以查询取代临时变量](https://www.phodal.com/blog/intellij-idea-refactor-replace-temp-with-query/)、[重构与 Intellij Idea 初探](https://www.phodal.com/blog/thoughtworks-refactor-and-intellij-idea/)、[内联函数](https://www.phodal.com/blog/intellij-idea-refactor-inline-method/))
|
||||
|
||||
在各种各样的文章里,我们看到过一些相关的内容,最好的参考莫过于《重构》一书。最基础不过的原则便是函数名,取名字很难,取别人能读懂的名字更难。其他的便有诸如长函数、过大的类、重复代码等等。在我有限的面试别人的经历里,这些问题都是最常见的。
|
||||
|
||||
|
|
@ -254,58 +254,58 @@ GitHub连击
|
|||
|
||||
而如果没有测试,其他都是扯淡。写好测试很难,写个测试算是一件容易的事。只是有些容易我们会为了测试而测试。
|
||||
|
||||
在我写[EchoesWorks](https://github.com/echoesworks/echoesworks)和[Lan](https://github.com/phodal/lan)的过程中,我尽量去保证足够高的测试覆盖率。
|
||||
在我写 [EchoesWorks](https://github.com/echoesworks/echoesworks) 和 [Lan](https://github.com/phodal/lan) 的过程中,我尽量去保证足够高的测试覆盖率。
|
||||
|
||||

|
||||
|
||||

|
||||
|
||||
从测试开始的TDD,会保证方法是可测的。从功能到测试则可以提供工作次效率,但是只会让测试成为测试,而不是代码的一部分。
|
||||
从测试开始的 TDD,会保证方法是可测的。从功能到测试则可以提供工作次效率,但是只会让测试成为测试,而不是代码的一部分。
|
||||
|
||||
测试是代码的最后一公里。所以,尽可能的为你的GitHub上的项目添加测试。
|
||||
测试是代码的最后一公里。所以,尽可能的为你的 GitHub 上的项目添加测试。
|
||||
|
||||
#### 编码的过程
|
||||
|
||||
初到TW时,Pair时候总会有人教我如何开始编码,这应该也是一项基础的能力。结合日常,重新演绎一下这个过程:
|
||||
初到 TW 时,Pair 时候总会有人教我如何开始编码,这应该也是一项基础的能力。结合日常,重新演绎一下这个过程:
|
||||
|
||||
1. 有一个可衡量、可实现、过程可测的目标
|
||||
2. Tasking(即对要实现的目标过程进行分解)
|
||||
3. 一步步实现(如TDD)
|
||||
3. 一步步实现(如 TDD)
|
||||
4. 实现目标
|
||||
|
||||
放到当前的场景就是:
|
||||
|
||||
1. 我想在GitHub上连击365天。对应于每一个时候段的目标都应该是可以衡量、测试的——即每天都会有Contributions。
|
||||
2. 分解就是一个痛苦的过程。理想情况下,我们应该会有每天提交,但是这取决于你的repo的数量,如果没有新的idea出现,那么这个就变成为了Contributions而Commit。
|
||||
1. 我想在 GitHub 上连击 365 天。对应于每一个时候段的目标都应该是可以衡量、测试的——即每天都会有 Contributions。
|
||||
2. 分解就是一个痛苦的过程。理想情况下,我们应该会有每天提交,但是这取决于你的 repo 的数量,如果没有新的 idea 出现,那么这个就变成为了 Contributions 而 Commit。
|
||||
3. 一步步实现
|
||||
|
||||
在我们实际工作中也是如此,接到一个任务,然后分解,一步步完成。不过实现会稍微复杂一些,因为事务总会有抢占和优先级的。
|
||||
|
||||
### 技术与框架设计
|
||||
|
||||
在上上一篇博客中《[After 500:写了第500篇博客,然后呢?](https://www.phodal.com/blog/after-500-blogposts-analytics-after-tech/)》也深刻地讨论了下这个问题,技术向来都是后发者优势。对于技术人员来说,也是如此,后发者占据很大的优势。
|
||||
在上上一篇博客中《[After 500:写了第 500 篇博客,然后呢?](https://www.phodal.com/blog/after-500-blogposts-analytics-after-tech/)》也深刻地讨论了下这个问题,技术向来都是后发者优势。对于技术人员来说,也是如此,后发者占据很大的优势。
|
||||
|
||||
如果我们只是单纯地把我们的关注点仅仅放置于技术上,那么我们就不具有任何的优势。而依赖于我们的编程经验,我们可以在特定的时候创造一些框架。而架构的设计本身就是一件有意思的事,大抵是因为程序员都喜欢创造。(ps:之前曾经写过这样一篇文章,《[对不起,我并不热爱编程,我只喜欢创造](https://www.phodal.com/blog/sorry-i-don't-like-programming/)》)
|
||||
|
||||
**创造是一种知识的再掌握过程。**
|
||||
|
||||
回顾一下写echoesworks的过程,一开始我需要的是一个网页版的PPT,当然这类的东西已经有很多了,如impress.js、bespoke.js等等。分析一下所需要的功能:markdown解析器、键盘事件处理、Ajax、进度条显示、图片处理、Slide。我们可以在GitHub上找到各式各样的模块,我们所要做的就是将之结合在一样。在那之前,我试着用类似的原理写(组合)了[Lettuce](https://github.com/phodal/lettuce)。
|
||||
回顾一下写 echoesworks 的过程,一开始我需要的是一个网页版的 PPT,当然这类的东西已经有很多了,如 impress.js、bespoke.js 等等。分析一下所需要的功能:markdown 解析器、键盘事件处理、Ajax、进度条显示、图片处理、Slide。我们可以在 GitHub 上找到各式各样的模块,我们所要做的就是将之结合在一样。在那之前,我试着用类似的原理写(组合)了 [Lettuce](https://github.com/phodal/lettuce)。
|
||||
|
||||
组合相比于创造过程是一个更有挑战性的过程,我们需要在这过程去设计胶水来粘合这些代码,并在最终可以让他工作。这好比是我们在平时接触到的任务划分,每个人负责相应的模块,最后整合。
|
||||
|
||||
我在写[lan](https://github.com/phodal/lan)的时候,也是类似的,但是不同的是我已经设计了一个清晰的架构图。
|
||||
我在写 [lan](https://github.com/phodal/lan) 的时候,也是类似的,但是不同的是我已经设计了一个清晰的架构图。
|
||||
|
||||

|
||||
|
||||
而在我们实现的编码过程也是如此,使用不同的框架,并且让他们能工作。如早期玩的[moqi.mobi](https://github.com/echoesworks/moqi.mobi),基于Backbone、RequireJS、Underscore、Mustache、Pure CSS。在随后的时间里,用React替换了View层,就有了[backbone-react](https://github.com/phodal/backbone-react)的练习。
|
||||
而在我们实现的编码过程也是如此,使用不同的框架,并且让他们能工作。如早期玩的 [moqi.mobi](https://github.com/echoesworks/moqi.mobi),基于 Backbone、RequireJS、Underscore、Mustache、Pure CSS。在随后的时间里,用 React 替换了 View 层,就有了 [backbone-react](https://github.com/phodal/backbone-react) 的练习。
|
||||
|
||||
技术同人一样,需要不断地往高一级前进。我们只需要不断地Re-Practise。
|
||||
技术同人一样,需要不断地往高一级前进。我们只需要不断地 Re-Practise。
|
||||
|
||||
### 领域与练习
|
||||
|
||||
说业务好像不太适合程序员的口味,那就领域吧。不同行业的人,如百度、阿里、腾讯,他们的领域核心是不一样的。
|
||||
|
||||
而领域本身也是相似的,这可以解释为什么互联网公司都喜欢互相挖人,而一般都不会去华为、中兴等非互联网领域挖人。出了这个领域,你可能连个毕业生都不如。领域、业务同技术一样是不断强化知识的一个过程。Ritchie先实现了BCPL语言,而后设计了C语言,而BCPL语言一开始是基于CPL语言。
|
||||
而领域本身也是相似的,这可以解释为什么互联网公司都喜欢互相挖人,而一般都不会去华为、中兴等非互联网领域挖人。出了这个领域,你可能连个毕业生都不如。领域、业务同技术一样是不断强化知识的一个过程。Ritchie 先实现了 BCPL 语言,而后设计了 C 语言,而 BCPL 语言一开始是基于 CPL 语言。
|
||||
|
||||
领域本身也在不断进化。
|
||||
|
||||
|
|
@ -313,7 +313,7 @@ GitHub连击
|
|||
|
||||
### 其他
|
||||
|
||||
是时候写这个小结了。从不会写代码,到写代码是从0到1的过程,但是要从1到60都不是一件容易的事。无论是刷GitHub也好(不要是自动提交),或者是换工作也好,我们都在不断地练习。
|
||||
是时候写这个小结了。从不会写代码,到写代码是从 0 到 1 的过程,但是要从 1 到 60 都不是一件容易的事。无论是刷 GitHub 也好(不要是自动提交),或者是换工作也好,我们都在不断地练习。
|
||||
|
||||
而练习是要分成不同的几个步骤,不仅仅局限于技术:
|
||||
|
||||
|
|
@ -324,28 +324,28 @@ GitHub连击
|
|||
|
||||
---
|
||||
|
||||
## 500天
|
||||
## 500 天
|
||||
|
||||
尽管之前已经有100天、200天、365天的文章,但是这不是一篇象征性的500天的文章。对这样的一个事物,每个人都会有不同听看法。有的会说这是一件好事,有的则不是。但是别人的看法终究不重要,因为了解你自己的只有你自己。别人都只是以他们的角度来提出观点。
|
||||
尽管之前已经有 100 天、200 天、365 天的文章,但是这不是一篇象征性的 500 天的文章。对这样的一个事物,每个人都会有不同听看法。有的会说这是一件好事,有的则不是。但是别人的看法终究不重要,因为了解你自己的只有你自己。别人都只是以他们的角度来提出观点。
|
||||
|
||||
在这500天里,我发现两点有意思的事,也是总结的时候才意识到的:
|
||||
在这 500 天里,我发现两点有意思的事,也是总结的时候才意识到的:
|
||||
|
||||
1. 编程的情绪周期
|
||||
2. 有意图的练习
|
||||
|
||||
那么,当我们不断地练习的时候,我们就可以写出更好的代码。
|
||||
|
||||
我想你也听过一万小时天才理论的说法:要成为某个领域的专家,需要10000小时。而在这其中最重要的一点是有意图的练习——而不是一直重复性地用不同的语言去写一个相同的算法。如果我们有一天8小时的工作时间 + 2 小时的提高时间,那么我们还是需要1000天才能实现一万小时。
|
||||
我想你也听过一万小时天才理论的说法:要成为某个领域的专家,需要 10000 小时。而在这其中最重要的一点是有意图的练习——而不是一直重复性地用不同的语言去写一个相同的算法。如果我们有一天 8 小时的工作时间 + 2 小时的提高时间,那么我们还是需要 1000 天才能实现一万小时。
|
||||
|
||||
### 500天与10000小时
|
||||
### 500 天与10000 小时
|
||||
|
||||
当然如果你连做梦也在写代码的话,那么我想500天就够了,哈哈~~。
|
||||
当然如果你连做梦也在写代码的话,那么我想 500 天就够了,哈哈~~。
|
||||
|
||||

|
||||
|
||||
虽然不是连击次数最多的,但是根据[Most active GitHub users ](http://git.io/top)的结果来说,好似是大陆提交数最多的人,没有之一。再考虑到提交都是有意义的——不是机器刷出来的,不是有意识的去刷,我觉得还是有很大成就感的。
|
||||
虽然不是连击次数最多的,但是根据 [Most active GitHub users ](http://git.io/top) 的结果来说,好似是大陆提交数最多的人,没有之一。再考虑到提交都是有意义的——不是机器刷出来的,不是有意识的去刷,我觉得还是有很大成就感的。
|
||||
|
||||
而要实现500天连击很重要的两点是:时间和idea。但是我觉得idea并不是非常重要的,我们可以造轮子,这一点就是在早期我做得最多的一件事,不断地造轮子——如《[造轮子与从Github生成轮子](https://www.phodal.com/blog/create-framework-from-github/)》一文中所说。除此,你还可以用《[GitHub去管理你的idea](https://www.phodal.com/blog/use-github-manage-idea/)》,每当你想到一个Idea以及完成一个idea的时间你就会多一次提交。
|
||||
而要实现 500 天连击很重要的两点是:时间和 idea。但是我觉得 idea 并不是非常重要的,我们可以造轮子,这一点就是在早期我做得最多的一件事,不断地造轮子——如《[造轮子与从Github生成轮子](https://www.phodal.com/blog/create-framework-from-github/)》一文中所说。除此,你还可以用《[GitHub去管理你的idea](https://www.phodal.com/blog/use-github-manage-idea/)》,每当你想到一个 Idea 以及完成一个 idea 的时间你就会多一次提交。
|
||||
|
||||
时间则是一件很讽刺的事,因为人们要加班。加班的原因,要么是因为工作的内容很有意思,要么是因为钱。如果不是因为钱的话,为什么不去换个工作呢?比如我司。看似两者间存在很多的对立,但是我总在想技术的提升可以在后期解决收入的问题,而不需要靠加班来解决这个问题。人总是要活着的,钱是必需的,但是程序员的收入都不低。
|
||||
|
||||
|
|
@ -431,9 +431,9 @@ THE ONLY FAIR IS NOT FAIR . ENJOY CREATE & SHARE.
|
|||
|
||||
建议试试我们家的Growth哈,地址:http://growth.ren。
|
||||
|
||||
文章的剩下部分就让我分享一下:在这723天里,我创造出了哪些有意思的东西(ps:让我装逼一下)——其实我不仅仅只是 Markdown 写得好
|
||||
文章的剩下部分就让我分享一下:在这 723 天里,我创造出了哪些有意思的东西(ps:让我装逼一下)——其实我不仅仅只是 Markdown 写得好
|
||||
|
||||
#### 2014年
|
||||
#### 2014 年
|
||||
|
||||
时间:2014.10.08-2014.12.30
|
||||
|
||||
|
|
@ -441,18 +441,18 @@ THE ONLY FAIR IS NOT FAIR . ENJOY CREATE & SHARE.
|
|||
|
||||
在这一段时间里,我创建的项目大部分都是一些物联网项目:
|
||||
|
||||
- [iot-coap](https://github.com/phodal/iot-coap) 一个基于CoAP协议的物联网
|
||||
- [iot-coap](https://github.com/phodal/iot-coap) 一个基于 CoAP 协议的物联网
|
||||
- [designiot](https://github.com/phodal/designiot) 即电子书《教你设计物联网系统》
|
||||
- [iot-document](https://github.com/phodal/awesome-iot-document) 收集一些物联网相关的资料,和Awesome不是一个性质
|
||||
- [iot](https://github.com/phodal/iot) 基于PHP框架Laravel的物联网
|
||||
- iot-android 一个与iot项目相配套的Android程序
|
||||
- [iot-document](https://github.com/phodal/awesome-iot-document) 收集一些物联网相关的资料,和 Awesome 不是一个性质
|
||||
- [iot](https://github.com/phodal/iot) 基于 PHP 框架 Laravel 的物联网
|
||||
- iot-android 一个与 iot 项目相配套的 Android 程序
|
||||
- 等等
|
||||
|
||||
正是这几个IoT项目,让Packt出版社找到了我,才有了后来和国内外出版社打交道的故事。也开始了技术审阅、翻译、写书的各种故事,想想就觉得这个开头真的很好。
|
||||
正是这几个 IoT 项目,让 Packt 出版社找到了我,才有了后来和国内外出版社打交道的故事。也开始了技术审阅、翻译、写书的各种故事,想想就觉得这个开头真的很好。
|
||||
|
||||
期间还创建了一个很有意思的Chrome插件,叫onebuttonapp——没错,就是模仿Amazon的一键下单写的。这个插件的目的就是难证当时在项目上用的Backbone、Require.js的这一套可以在插件上好好玩。
|
||||
期间还创建了一个很有意思的 Chrome 插件,叫 onebuttonapp——没错,就是模仿 Amazon 的一键下单写的。这个插件的目的就是难证当时在项目上用的 Backbone、Require.js 的这一套可以在插件上好好玩。
|
||||
|
||||
OnMap项目是为了让我用Nokia Lumia 920拍照的照片,可以在地图上显示而创建的项目。
|
||||
OnMap 项目是为了让我用 Nokia Lumia 920 拍照的照片,可以在地图上显示而创建的项目。
|
||||
|
||||
当然还有其他的一些小项目啦。
|
||||
|
||||
|
|
@ -462,33 +462,33 @@ OnMap项目是为了让我用Nokia Lumia 920拍照的照片,可以在地图上
|
|||
|
||||
整个区间就是刷各种前端的技术栈,创建了各种有意思的项目:
|
||||
|
||||
- [Lettuce框架](https://github.com/phodal/lettuce),一个基于简单的SPA框架
|
||||
- [echoesworks](https://github.com/phodal/echoesworks),一个支持字幕、Markdown、动画的Slide框架
|
||||
- [diaonan](https://github.com/phodal/diaonan),一个支持CoAP、MQTT、HTTP的物联网项目
|
||||
- [Lettuce框架](https://github.com/phodal/lettuce),一个基于简单的 SPA 框架
|
||||
- [echoesworks](https://github.com/phodal/echoesworks),一个支持字幕、Markdown、动画的 Slide 框架
|
||||
- [diaonan](https://github.com/phodal/diaonan),一个支持 CoAP、MQTT、HTTP 的物联网项目
|
||||
- [developer](https://github.com/phodal/developer),收集各种 Web Developer 成长路线,以及读书图谱
|
||||
|
||||
|
||||
期间还创建了几个混合应用项目:
|
||||
|
||||
- [learning-ionic](https://github.com/phodal/learning-ionic),程序语言答人,各种hello,world的小应用
|
||||
- [learning-ionic](https://github.com/phodal/learning-ionic),程序语言答人,各种 hello, world 的小应用
|
||||
- [ionic-elasticsearch](https://github.com/phodal/ionic-elasticsearch), Django ElasticSearch Ionic 打造 GIS 移动应用
|
||||
- [designiot-app](https://github.com/phodal/designiot-app),教你设计物联网APP版
|
||||
- [designiot-app](https://github.com/phodal/designiot-app),教你设计物联网 APP 版
|
||||
|
||||
更多内容可以见我的Idea列表:[https://github.com/phodal/ideas](https://github.com/phodal/ideas),我实在是不想写了。
|
||||
更多内容可以见我的 Idea 列表:[https://github.com/phodal/ideas](https://github.com/phodal/ideas),我实在是不想写了。
|
||||
|
||||
#### 2016年
|
||||
#### 2016 年
|
||||
|
||||

|
||||
|
||||
我们有了Growth系列的电子书、APP,还有Mole,几个极具代表性的项目就够了。
|
||||
我们有了 Growth 系列的电子书、APP,还有 Mole,几个极具代表性的项目就够了。
|
||||
|
||||
- [Growth](https://github.com/phodal/growth),一款专注于Web开发者成长的应用,涵盖Web开发的流程及技术栈,Web开发的学习路线、成长衡量等各方面。
|
||||
- [Growth](https://github.com/phodal/growth),一款专注于 Web 开发者成长的应用,涵盖 Web 开发的流程及技术栈,Web 开发的学习路线、成长衡量等各方面。
|
||||
- [Growth:全栈增长工程师指南](https://github.com/phodal/growth-ebook),一本关于如何成为全栈增长工程师的指南
|
||||
- [Growth:全栈增长工程师实战](https://github.com/phodal/growth-in-action),在Growth中我们介绍的只是一系列的实践,而Growth实战则会带领读者去履行这些实践
|
||||
- [Growth:全栈增长工程师实战](https://github.com/phodal/growth-in-action),在 Growth 中我们介绍的只是一系列的实践,而 Growth 实战则会带领读者去履行这些实践
|
||||
|
||||
### See you Again
|
||||
|
||||
停止这次连击,只是为了有一个更好的开始。
|
||||
|
||||
如果你也想提高自己,不妨从创建你的 ideas 项目开始,如我的[Ideas](https://github.com/phodal/ideas)项目一样,上面已经有了大量的 Idea。然后,我们还可以依据这一个个的项目,创建出一本电子书,即 [ideabook](https://github.com/phodal/ideabook)。
|
||||
如果你也想提高自己,不妨从创建你的 ideas 项目开始,如我的 [Ideas](https://github.com/phodal/ideas) 项目一样,上面已经有了大量的 Idea。然后,我们还可以依据这一个个的项目,创建出一本电子书,即 [ideabook](https://github.com/phodal/ideabook)。
|
||||
|
||||
|
|
|
|||
|
|
@ -1,7 +1,7 @@
|
|||
GitHub 里程碑
|
||||
===
|
||||
|
||||
写在GitHub 的第 19999 个 Star 时
|
||||
写在 GitHub 的第 19999 个 Star 时
|
||||
---
|
||||
|
||||
> Star 虽好,可不要贪杯哦。
|
||||
|
|
|
|||
|
|
@ -1,7 +1,7 @@
|
|||
FAQ
|
||||
===
|
||||
|
||||
## 如何看待 GitHub 项目刷Star行为?
|
||||
## 如何看待 GitHub 项目刷 Star 行为?
|
||||
|
||||
我觉得:在作者开源了源码的情况下,求 Star 并没有任何问题。
|
||||
|
||||
|
|
|
|||
Loading…
Reference in a new issue