大学毕业后笔者进入一家外企,做企业CRM系统开发,那时候开发效率最高的高级程序语言,毫无疑问是C#。恰逢公司也在扩张,招聘了不少.net程序员,笔者作为应届生,也乐呵呵的加入到.net程序员行列中。

C#.net非常容易上手,之前在大学里,做过winform和webform开发,也曾经在老师那里承接过小项目,赚点外快。于是在工作岗位上驾轻就熟,很容易就上手了企业开发框架,仅一年多,笔者就成为公司的开(jia)发(ban)骨(feng)干(xian)。

C#.net的网评比Java要差,笔者曾经在知乎上看到一个国外华裔程序员的文章,内容主要是国外的悠闲不加班的生活,文末一句:“忘了说 我是做.net的”引发了讨论的高潮。知乎程序员中,写Java、python、go、JavaScript几乎成了政治正确,作为.net程序员的笔者很少在相关讨论中活跃,但对java的印象已经有了改变。那时笔者所在的外企仍在大规模使用C#.net,笔者也就拒绝去接受网上的喧闹的声音,专心写好代码,学习设计模式和前端技术等等。

恰逢互联网行业发展势头正劲,笔者自然顺势而为,加入了一家规模稍大的互联网公司,当然还是写C#。由于之前在外企任劳任怨,什么活都愿意揽过来干,积累到不少很有用的研发知识和经验,于是在跳槽过程中顺风顺水,基本人家问什么,我都能答出来,于是相对轻松地加入了新公司,开启了互联网研发之路。正是亲眼鉴证了互联网研发模式,才让笔者确定了转型Java的决定。

新公司的框架很老旧,那时还在用.net framework2.0,业务代码非常复杂庞大,某个十年业务的项目里的一个方法,居然有一千多行,单是阅读代码,就让笔者心累,更心累的是,这一千行代码的方法名,居然被叫作“外观模式”(facade)……很难想象公司最核心的业务,跑在这么臃肿烦复的代码里。性能和效率都被看重的互联网研发模式,终于开始和C#.net产生了矛盾:.net framework和iis不开源。系统在运行过程中遇到了如下几个问题:

1、接口服务项目的访问效率遇到瓶颈,基本只能上负载均衡加机器。

2、某些大项目要数十台机器去承载日常访问,运维难度加大(后续上了持续集成和平滑发布,运维方便了很多)。

3、较少数情况,系统会出现一些疑难杂症,当产生问题的代码在闭源工具包里,调试人员几乎束手无策。(反编译的代码真难看囧……)

4、不断增加机器,成本增加,这可不只是机器成本,人家不开源,收费也不便宜……

5、可定制化较差。某些极端场景下,我们希望程序能够更大程度的消耗服务器硬件资源,而服务器程序都是别人的,人家为了安全都设定好“最佳阈值”了,很难更进一步压榨服务器资源。

6、缺乏开源社区支撑、大数据相关研发乏力……

7、国内部分互联网公司提供的开放平台工具,居然不提供C#的SDK……(根据http请求自己写SDK)

诸如此类,不胜枚举。

转Java吧。

技术转型的阵痛在所难免。公司内的接口研发和后台管理系统研发是分开由不同人员负责,能够同时开发接口和后台系统的人并不多。笔者技术体系相对完善,在团队中获得不少尊重。也曾亲自带团队做研发,写完接口又带兄弟研究ckeditor源码并做定制化修改,忙的不亦乐乎。然而转Java成了笔者当时的心病:本职工作做得很好,团队不会允许贸然改用Java技术栈这种冒险行为。笔者已经私下学习了许久,却不能直接上项目实际操练,非常可惜。

精诚所至金石为开,笔者终于等来了一个机会:成为公司新项目的主程序员,负责整个项目的后端架构、设计和研发。新项目人员不多,但都是各类技术中的优秀人才,包含ios、Android和H5研发人员,笔者为他们提供接口,并开发后台管理系统提供给产品和运营同事。

独立负责设计和研发,工作量虽大,自由度却大了不少,于是笔者决定用Java来完成整个开发任务。项目leader对笔者的技术功底很是信任,不过仍希望团队用C#.net追求稳健,但看在笔者执着坚持,也就同意了。为了降低技术转型对新项目带来的风险和进度影响,笔者还是做了一定妥协:用Java研发接口服务,后台管理系统仍用C#.net。

接口研发期间笔者着实吃了不少苦头,项目框架搭建问题层出不穷,spring的运用不纯熟,导致经常在框架层面报错。新项目的座位与公司Java开发团队座位不在同一楼层,笔者几乎每天都要爬几次楼梯去Java研发团队取经。好几次遇到问题解决不了,都想放弃然后用回C#.net。项目leader多次看到此情景曾多次施压,笔者跟项目经理坦(zhuang)言(bi):“如果Java搞不定,我会在两天内用C#.net把活干完,不拖项目进度。”靠着这份坚持和韧劲,还有多次对Java研发团队的叨扰,项目框架终于搭建完成,笔者也借着多次的取经,弄清楚框架的原理,完成了对spring的实践。拥有依赖倒置、控制反转的编程思想和设计模式的运用经验,理解Java框架的设计思路是很简单的,在框架搭建结束后,业务代码的输出几乎是行云流水,在项目完成之际,笔者都忘记自己曾是个.net程序员。项目最终顺利上线,并且仅用两台机器就抗住了较高的并发,笔者对Java有了更多的信任和喜爱。

有.net的编程基础,学习Java会相对容易,但必须逃离几个陷进:

1、对基础知识务必要重视:C#是一门非常出色的语言,它提供的语法糖让复杂的业务表达起来也十分优雅,搭配伶俐的lambda表达式和linq,数据结构的基本原理在大部分场景下都被弱化,而数据结构和算法正是编程的精髓。

2、对原理的渴望和求知欲:用C#编程,无法查看大部分程序集内的方法,只能自己上论坛找或反编译,求知欲可能会逐渐弱化。而写Java后,经常会自己ctrl+鼠标进入方法查看源码。这一点Java真是非常性感。

3、懒人思维不可取:C#.net对于链表数组等数据结构的排序和查询都做了高度封装,几个表达式就能得到想要的结果,而Java的表达式则没这么伶俐。在Java世界里,自己弄明白原理,自己写是更高效、更对得起自己的方案。

使用Java完成商用项目的开发,只是技术转型的开始,只能算踏进门,算不得转型成功。笔者仍花了很多时间学习Java的数据结构;学习Apache的公共工具包,偶尔点进去看看实现源码;继续学习设计模式及其应用。在一些评估用C#研发更容易的项目,笔者仍然坚持用Java去完成。为了能有更多Java项目练手,笔者申请进入了搜索引擎研发部门,通过了Java团队架构师的技术面试,加入了渴望已久的团队,最终能专职写Java做搜索引擎服务。当然,离开了当初的部门,也就抛弃了在老团队中的地位和荣誉,但笔者觉得很值。

在多年开发经历中,笔者确实感悟 语言是互通的,万变不离其宗。学习新语言只要下决心并付出努力,基本都能办到。然而后续的挑战则是更大规模的项目的设计思路,设计模式的运用,架构设计策略,代码堆叠方案,甚至是不同功能模块的技术选型。这些都需要仰仗厚重的经验、扎实的功底和日积月累的技术实力。

未来大数据和机器学习的热潮已经如火如荼的展开,手握Java这一门利器,运用storm、elasticsearch、Hadoop、lucene等绝技的Java程序员,必然能更好的适应潮流。

五年.net程序员Java学习之路的更多相关文章

  1. zz 游戏程序员的学习之路(中文版)

    游戏程序员的学习之路(中文版) Milo Yip · 1 天前 感谢 @楚天阔(tkchu)编写脚本及整理中文译本数据,自动从英文版生成中文版,SVG / PDF 版本中的书籍图片现在链接至豆瓣页面. ...

  2. GJM : 游戏程序员的学习之路

    原文作者:miloyip  原帖地址:http://gad.qq.com/article/detail/7180681 原帖备注:版权所有,禁止匿名转载:禁止商业使用:禁止个人使用. 腾讯前端技术总监 ...

  3. .Net程序员安卓学习之路1:登陆界面

    任何编程学习起步均是HelloWorld,作为稍有>net编程经验的我们来说就跳过这步吧,咱们且从简单登录界面开始.先看看效果: 一.准备知识: 1. 安卓环境:安装好JDK,直接去官网下载AD ...

  4. .Net程序员安卓学习之路3:Post数据给网络API

    本例我们实现一次真正的网络交互,将数据POST到API,然后接收服务器的返回值进行处理,同时引入自定义类型和传说中阿里的FastJson. 实现思路如: 1. 在API端接收客户POST的数据还原成对 ...

  5. .Net程序员安卓学习之路2:访问网络API

    做应用型的APP肯定是要和网络交互的,那么本节就来实战一把Android访问网络API,还是使用上节的DEMO: 一.准备API: 一般都采用Json作为数据交换格式,目前各种语言均能输出Json串. ...

  6. .Net程序员安卓学习之路4:使用xutils Get Post数据

    前面使用了一些网络上找来的类进行网络访问,后来发现了安卓开发中有一个国人写的类库xutils比较全面,也比较经典,故后续使用xutils类库进行记录. 本例服务端使用WCF来实现,写好的WCF服务端在 ...

  7. .Net程序员安卓学习之路6:等待条

    一般在需要访问网络或者长时间操作的时候避免界面无响应才使用:等待条 本例将实现一个无框架的等待条,效果如下: 点击后,使线程Sleep5秒,就出现如下效果: 实现代码如: private Progre ...

  8. .Net程序员安卓学习之路5:使用xutils注入View和事件以及图片的显示

    xUtils注入和图片显示 一.xUtils注入 引用官方介绍: ViewUtils模块: •android中的ioc框架,完全注解方式就可以进行UI,资源和事件绑定: •新的事件绑定方式,使用混淆工 ...

  9. 2020年Java程序员应该学习的10大技术

    对于Java开发人员来说,最近几年的时间中,Java生态诞生了很多东西.每6个月更新一次Java版本,以及发布很多流行的框架,如Spring 5.Spring Security 5和Spring Bo ...

随机推荐

  1. 从零自学Java-8.创建第一个对象

    1.创建对象:2.使用属性描述对象:3.确定对象的行为:4.合并对象:5.从其他对象继承:6.转换对象和其他类型的信息. 程序NewRoot2:计算输入数的算数平方根并输出 package com.j ...

  2. python第八十八天----dom js

    DOM操作 1. 找到标签直接查找 document.getElementById 根据ID获取一个标签 document.getElementsByName 根据name属性获取标签集合 docum ...

  3. Django之model模块创建表完整过程

    Django中,与数据库相关的模块是model模块,它提供了一种简单易操作的API方式与数据库交互,它是通过ORM映射的方式来操作数据库,一个类对应数据库一张表,一个类属性,对应该表的一个字段,一个实 ...

  4. SAP ABAP 如何查找SMOD增强

    1.查找程序名 T-CODE:SE93 2.查找开发类 T-code:se38 3.查找SMOD增强 T-CODE:SE16N.表:TADIR 4.查看增强具有哪些功能 T-CODE:SE16N.表: ...

  5. February 4th, 2018 Week 6th Sunday

    Hope clouds observation. 心怀希望会蒙蔽双眼,影响判断. Almost every of us thinks we would be the master of our liv ...

  6. FusionCharts参数说明——3D饼图属性(Pie3D.swf )

    animation 是否显示加载图表时的动画palette 内置的图表样式,共5个paletteColors 自定义图表元素颜色(为多个,如过过少会重复)showAboutMenuItem 右键是否显 ...

  7. MySQL比like语句更高效写法locate position instr find_in_set

    你是否一直在寻找比MySQL的LIKE语句更高效的方法的,下面我就为你介绍几种. LIKE语句 SELECT `column` FROM `table` where `condition` like  ...

  8. jenkins编译jar包 报connection连接错误

    原因是因为编译启动连接了注册中心 eureka.client.service-url.defaultZone=http://localhost:8093/eureka/ eureka.client.r ...

  9. Runloop深入理解

    一.什么是Runloop?为什么需要Runloop? Runloop,顾名思义,即运行循环. 没有Runloop的情况下,一个线程执行完一个任务,就会退出并销毁.等到需要处理下一个任务时,再重新创建一 ...

  10. Objective-C Mach-O文件格式深入理解

    Mach-O(Mach Object),是一种基于Mach内核的文件格式,苹果很多文件都采用这种格式,最常见的就是可执行文件和动态库. 当然,还有.o的目标文件..a和.framework的静态库以及 ...