在过去的三年时间了,作为曾经的研发部经理,我和我的技术总监始终在为一件事而努力着,那就是选择一门合适我们团队的技术语言。

我们研发团队一共有9个人,分为三个小组:移动手机组、后端接口组、web前端组,如果按照大公司的做法,我们完全不必为每组应该选择什么技术语言而担心,我们可以在每组中选择一个组长,由他全权负责即可,公司层面只要最终的结果即可,可事情并没有那么简单。

现实总是残酷的,其中的原因有这么几个:第一:岗位经费不高,想要低成本找一个技术合格的人非常难;第二:知名度有限,一般的技术人才都有更好选择的条件,好的人才当然更倾向于知名度高和前景好的公司,而对于没有知名度且前景一般的公司来说,想要吸引他们加入也是一件极其不易的事;第三:公司的地理位置,即不属于技术人员聚集的地区,有在离市中心比较远的郊区,想要让他们来面试都是一件极其不易的事情。所以凡事还得亲力亲为,加上公司刚开始发展所有的一切都是空白的,选择一门合适的语言就迫在眉睫了。

在这三年的时间里,我们每个组都经历了很多语言和框架的更换,也一直在找寻适合我们的框架,现在回想起来好的语言框架要符合这几个要素:

1、技术语言发展成熟;

2、技术语言统一;

3、技术门槛低;

4、使用人数多;

5、技术匹配目前业务需求;

技术发展成熟:代表了出现问题之后的技术解决方案很多,那么团队处理问题的速度就会很快,相应的成本也就最低,这个是选择语言与框架非常重要的一个指标。

技术语言统一:有这么几个好处,第一:团队之间交流和互动会更紧密,产生问题的处理成本就会很低,同时能够增加成员之间交流的话题,增加彼此的友谊;第二:出现特殊情况,能够很好的使用现有人员替补代替;第三:利于管理,比如接口开发如果使用nodejs,其本质还是js,前端开发使用vuejs,也有很多js的语法,这样对于同时管理两个组的领导技能要求就会降低很多,只需要有很好的js功底即可,而如果接口开发使用的golang、c#、java,那么你就得即会这些后端语言,又要会js才能搞定问题。

技术门槛低:别觉得技术门槛低是什么坏事,技术门槛低并不代表对技术人员的要求低,而是如果是其他语言的人想要中途转学,会容易很多,还有就是技术门槛低,相应的从业人员就会多很多,这样招聘的压力就会小很多,相应的劳务报酬也相对会低一些。

使用人数多:这个比较好理解,让你在紧急的时候能够很轻易的招聘到你需要的人,而不是凑合的用,或者重新培养相应的人才,这样会耽误你开发的进度。

技术匹配目前业务需求:我们在技术开发的时候容易陷入一个误区,就是开发过于庞杂复杂的系统,我们都听过一句话,罗马城不是一天建成的,一口气吃不成一个大胖子等等诸如此类的话,多的数不胜数,而然我们还是容易陷入思维的误区。我们之前花了很长的一段时间按照阿里的框架设计了一个很复杂的系统,把一个交易系统分为4、5个中间系统,前后端分离还不够,中间加了分部署的中间任务调度系统,把所有的系统平行分割注册,以提供给不同的子系统进行调用,为此我们花费了很多的经历,并且不得不为一些新的问题付出很多的努力,比如分部署机器的服务自动注册,怎么维系不同的机器健康心跳检测,怎么分发任务等等,花费具体时间和经历的结果是,前后端开发调试极其困难,调试很繁琐和复杂,要使用排除法,分开测试每个系统之后才能确认问题所在,最主要的是我们把系统花费很大经历初见雏形之后,发现根本用不上,以后的三五年都用不上这么庞大和笨重的系统,而我们却为此花费了太多的经历,这些是很不可取的,我们应该把技术资源用在更多可以创建价值的事情上,完美主义并不适合所有公司,小公司的模式更适合从下往上的快速试错和快速迭代的形式。

掌握了以上“心法”,相信会让你的团队事半功倍。而我总结一下,我们总结一下我们技术衍生的具体方案吧。

我们首先把我们可以用到的主流技术穷举一下:

前端组:vuejs、ag、react

后端组:java、c#、nodejs、go、php

移动开发(混合开发):react native、dcloud、xamarin、apicloud、deviceone、weex

前端框架,从使用人数和学习门槛的角度来分析,最理想的框架vuejs、react次之,非要排出一个的话应该是ag;

从技术统一的角度来看,那么nodejs是我们最好的选择,go次之,java、c#的学习门槛算是在这几个里面比较高的,如果不是要求千万级的负载,那么nodejs完全可以胜任;

移动开发,如果从性能和技术统一的程度,以为前端我们使用vuejs或react那么最理想的就是react native(以下简称rn),rn的性能是无可非议的,它有一个好爸爸facebook使用了虚拟dom重构了它的执行基础,性能是仅此于原生的,同时有主要用的了js的技术,这样就能和接口和前端都统一了,并且rn的技术解决方案非常成熟,各种组件都能很轻易的找到,技术解决成本也更低,使用起来更得心应手。

所以综合以上所述,最理想的框架:

前端:react、vuejs

后端:nodejs、go

移动开发:react native

以上框架都是经过3年的尝试,总结得出了符合中小公司整体框架的最优方案,鄙人拙见,愿抛砖引玉,大家一起讨论。

一个好的技术团队应该怎么选择开发语言相关推荐

  1. 如何打造一个低效能技术团队?

    见字如面,我是军哥! 乔布斯说过:"The only way to do great work is to love what you do. If you haven't found it ...

  2. 如何打造一个“低效能技术团队”?

    乔布斯说过:"The only way to do great work is to love what you do. If you haven't found it yet, keep ...

  3. 区块链需要c语言和linux嘛,区块链技术如何运作?使用什么开发语言?

    区块链技术如何运作?使用什么开发语言?这可能是现在许多区块链程序员的声音.以下是四个区块链技术的主要发展词汇,希望能帮助您. java开发语言(未来币) 定义:Java是一种面向对象的编程语言,不仅吸 ...

  4. 选择开发语言和学习的路径(这个标题可能有点不准确)

    毕业一年多了,现在在一家公司担任网络管理员,事情很少过得很惬意,基本上没有加班.但是渐渐的感觉没有什么前途(钱途).很多一起出来的的大学同学都向软件开发方向发展,很多事java或者php,有些认识的好 ...

  5. 初学者如何选择开发语言

           编程语言(programming language),是用来定义计算机程序的形式语言.它是一种被标准化的交流技巧,用来向计算机发出指令.一种计算机语言让程序员能够准确地定义计算机所需要使 ...

  6. 区块链技术要用到什么开发语言?

    回顾2009年到如今,区块链技术的火热程度是逐年增加.各大行业巨头也在疯狂布局,势必要上演一场"群雄逐鹿"的商业大战.那这场好戏什么时候上演?有人说就在最近这两三年,还有人甚至说就 ...

  7. 【收藏向】谷歌技术团队出品,Android开发入门教程,开源分享

    程序员圈子中,python.java等都是热门领域,网络上相关学习资源也比较多,相较之下Android的学习资料就比较少了,并且大多是碎片化的知识,不够系统和全面. 今天就来整理一下Android开发 ...

  8. 编程新手选择开发语言的注意事项

    前言 如果你从来就没有接触过编程,是否想尽快迈进这个技术园地呢?没错,许多编程爱好者最初共同有着的冲动.但是,请大家不要轻易地闯入这个技术园地.否则,大家将会遇到很多困惑. 首先,你要了解你自己,弄清 ...

  9. 计算机网络需要知道的技术知识(不分开发语言)

    UDP 面向报文 UDP 是一个面向报文(报文可以理解为一段段的数据)的协议.意思就是 UDP 只是报文的搬运工,不会对报文进行任何拆分和拼接操作. 具体来说 在发送端,应用层将数据传递给传输层的 U ...

最新文章

  1. 微软终于想通把Script56文档更新了
  2. 怎么安装python3-Ubuntu16.04怎样安装Python3.6
  3. button常用属性_web阶段常用单词明细表,你值得拥有
  4. BJUI验证后弹窗不显示
  5. topcoder SRM 625 DIV2 IncrementingSequence
  6. about osgeo中国
  7. 排序、翻页、函数计算问题
  8. vue slot的使用
  9. Python 包含\u字符串转中文(\u00)
  10. IDEA设置SQL格式化(关键字大写)
  11. 讯图科技数据网关解决方案
  12. WebStorm改变字体大小以及更换背景颜色
  13. angularjs-大漠穷秋
  14. MES系统对企业而言是必须的吗?
  15. 【代码示例】使用numpy布尔索引过滤二维数组中的行
  16. java 实现图片截取功能
  17. 【Docker系列】Docker Swarm 多节点集群
  18. 微信小程序跳一跳外挂matlab版本
  19. ​ ​c盘满了怎么扩展分区?​c盘太小如何扩展分区 ​
  20. 前端笔试题及面试题(一)

热门文章

  1. Oracle 11g系统自动收集统计信息
  2. C++类型萃取之type_traits和type_info
  3. bootstrap-select动态生成数据,设置默认选项(默认值)
  4. 中缀表达式转换成后缀表达式(只适用于加减乘除运算)
  5. 016 pickle
  6. 类似索引Model套Model之 iOS模型闲聊二
  7. 微信小程序笔记六模块化 —— module.exports
  8. 域名发散--前端优化(三)
  9. 极验验证码流程-3.图片加密处理 图片移位
  10. mysql Error 1045(28000)