C#初学者们,请离代码生成器远点!!!


在程序开发的世界里,各路前辈们为了提高所谓的编码速度,搞出了各式各样的代码生成器,来避免所谓的重复的人为机械地粘贴和复制代码,以此来提高生产力。

早几年前,我可能会认为这样的做法真得有用,特别是在编码速度上。

是的,有时候代码生成器是可以帮助我们开发者生成模板化的,规范化的,大批量的机器代码。

但许多人就将它当做了程序开发的利器,没有代码生成器完全没法写代码了,也没办法工作了。

觉得自己会用几款代码生成器好像很牛的样子。得意的在老板们,或是不懂技术的技术经理们面前炫耀:“XXX们,你看我的工作效率多高,你们的需求,你们想要的功能我只需要简单的代码生成就可以快速地搞定。”。

这种做法就好比别人把一头宰好并切好的牛肉放到你面前,再问你:“把这些牛肉放进冰箱需要几步?”

答案你也许知道了吧?没错,三步。

1.打开冰箱门;

2.放牛肉进冰箱;

3.关上冰箱门

很简单是吧?

那么,如果别人给你的是一整头牛,而不是切好的牛肉,再问让你把这头牛放进冰箱,你又怎么办呢?

上面的这个案例其实与开发者(特别是初级开发者)使用代码生成器有着同样的道理。

使用代码生成器的时候,这生成器就好比切好的牛肉,开发者在使用时不关心代码生成器的底层是如何封装的,也不知道内部逻辑是如何处理的。就好比不知道也不用关心那头牛是怎样被宰的,如何解剖的一样。

庖丁解牛是怎么来的?是屠夫们经过反复的实践,掌握了牛的结构、经络之后达到的一种境界。

在开发的世界里也是同理。

我见过不少开发者(绝大多数是.NET开发者,因为笔者主要专注.NET的开发)都是习惯并喜欢使用代码生成器来生成项目,甚至整个解决方案都能为他们生成就最完美了。

他们中有些人已经有5,6年或者7,8年的开发经验,不再是初学者了,但却还在用着传统的某某的代码生成器生成着传统的三层架的解决方案,在前端UI代码中充斥着各种DataTable和DataSet,各种if...else...逻辑判断,各种SQL语句拼接。。。

不知道看到此处的你是否正经历着相同的处境或者是经历过相同的场景?

也许你说:”我不是这样的开发者啊。“

那么作为热衷于开发的我感到很欣慰了,但这样的朋友应该不在多数,不然国内的.NET开发环境不会成如今这个要死不活的样。我的观点准确吗?

究其原因,不外乎是这样的:

在早年前,很多接触程序开发(本文主要是C#)的人中,都是看中互联网的高薪而加入到开发者这个大军中的,他们为的是钱途,而不是前途。他们不是真正意义上喜欢,或者说是热爱编程。

他们的骨子里或者根本就只是把程序开发当作多赚点钱的捷径。

他们在想:”我就在程序界里混几年,等资历老了,有个几年的开发经验或者是不停地跳槽,薪水自然就会不断地往上涨。等混到了30岁,就有资格做高级工程师,做项目经理,做项目主管了。有没有过硬的技术都不重要的。“

所以,如你,我,他所见到的如今的国内开发环境,真正热爱编程这份事业的,愿意深入研究技术的人很少,因为他们的目的根本不在于此。

他们只想通过简单的代码生成器来”赚快钱“,他们在编程界里呆了几年之后,还是不知道C#的面向对象编程思想,不知道泛型是什么,更没听说过反射,委托,事件,不知道还有设计模式,领域驱动设计。。。反正他们就知道有个叫“代码生成器”的东东。甚至还惊讶地问:”原来C#还有这么些啊?“

试想一下,如果代码生成器都能搞定我们的编程工作,那像Microsoft,Google,百度,阿里,腾讯等等这样的以技术为驱动的科技公司为什么不直接写一堆代码生成器就好了,何必每年养成千上万的开发者呢?

再说得具体一些,比如我们使用某某代码生成器来生成三层架构(这是很多C#初学者在入门或者开发生涯的前几年中最熟悉的套路),这个架构中包含三层:实体层,BLL,以及DAL。

随着一个项目需求的不断变更,你的数据表结构是不是也会变更。那么,问题是不是来了,每次变更表结构,你是不是需要重新生成这三层的代码,然后把原来的代码替换掉。

如果你在这三层的任意一层中添加了自己的代码,替换时是不是又会遇到问题呢?

那你有没有想过,有没有办法能解决这些问题呢,而不是一味地抱着代码生成器过日子。代码变更完,对应修改UI中的逻辑判断后就万事大吉。

笔者描述了这么多,想表达的是(特别是对于C#初学者来说):刚入门或者初级阶段,更多地要手写代码,多熟悉.NET Framework中的类库,老是想着:“代码生成器能帮我搞定的”是学不到真正的高级编程知识和技术的。

如果你执拗地喜欢利用传统的代码生成器去解决你项目中大部分工作,那么恭喜你,你入错行了,请趁早离开以免被坑得越来越深,因为你不热爱这个事业,你迟早也会走的,这样只会浪费你的宝贵的青春。

结束语

如果选择了.NET这条路,请用心,认真对待,因为这是你的事业,你的付出也会得到回报。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352

推荐阅读更多精彩内容