【原创】大公司为什么还在采用过时的技术

背景

本文出自一朋友给我的提问,于是博主呕心沥血给他花式洗脑了几个小时。忽然发现,应该还有许多朋友有同样的疑问。所以整理成文。
许多刚毕业的程序员朋友,都有一个执念,想要进那种规模大一点的公司、上市的、业内有名的最好。
为什么大家都想去大公司?
因为很多人觉得,公司大一点,正规一点。开发技术应该不错,应该与时俱进,流程应该会规范一些。说到这里,依然有这种想法的朋友,请握个爪。
然而,当他刷完什么《剑指OFFER》《编程之美》,废了好大一番功夫进去以后,却发现完全和自己想的不一样。他发现他所在的大公司:

(1)代码混乱

I、比如一个发送Http请求的Util类,竟然出现了三四种。开发人员A封装了一种,开发人员B封装了一种,公司框架自带了一种。
II、到处充斥着Ctrl+CCtrl+V的味道,更有甚者,居然连author都不改,原样复制过去。
III、日志风格千奇百怪,缺乏统一规范。每个人都有一套自己的日志风格。重点是,一些关键步骤,居然不写日志。
IV、一些几千行的类、关键步骤不加注释、一个方法几十个参数都是随处可见。

(2)开发流程混乱

I、一个项目组IDEJDK都不统一,比如用Idea,eclipse,myeclipse的都有。然而重点是,把idea、eclipse独有的配置文件都上传到了服务器。
II、完全没有文档。比如要改一个需求了,OK,去Debug代码,根据断点去反推原来的逻辑是怎么实现的。反正不改出问题就行。
III、程序员白天大部分时间在处理BUG,以一种混日子的态度在工作。反正能搞得定新需求,搞得定功能测试,项目能如期上线就行。至于代码有多搓,无所谓!

(3)技术落后

I、还在用四五年前的技术,例如还在JSP里头写大量的JAVA代码进行开发等。
II、架构上很多方面欠考虑。比如,采用了消息队列,却完全不做持久化处理,完全不担心数据丢失的问题,也没做可靠性的保证。服务之间传送数据,重要信息完全不加密,明文直接传。
III、性能调优就是拍脑袋做的

以上种种,大家如果深有感触,请再次握个爪。那么,为什么会这样呢?

缘由

人员层次

但凡在大厂工作几年的老员工,有没有这样一个体会,身边的牛逼老员工基本都跑了,剩下来的员工基本都是比较平庸的。
大部分人在工作中,其实都处在一种重复劳动的状态,也就是所谓的拧螺丝工作,技术水平得不到提高。那么在这种工作性质之下,会诞生两类人:
(1)平庸的人
这类人在工作中满足于能完成需求即可,对代码的美丑并不关心。正所谓

码不在烂,能跑就行。

当然,这类人并不是缺乏提升自己技术的能力,而是由于惰性,没有明确的规划,缺乏提升技能的意识,导致时光匆匆流走,想要跳槽却没地方收留,一不小心,这类人就成为了老员工。说到这里,赶紧回忆一下自己,是不是成天拿什么没时间当理由,然后明日复明日,小心成为老员工。
另外,大公司基本不会裁人,而手上的技术水平已经能应付工作。就算努力学了一堆新技术,也没有用武之地,于是这类人就能安然自得的继续过下去。
大家可以对比一下你身边的同事,一个是自毕业的时候就在这家公司熬了十年的,一个是十年间在三四家公司呆过的。请问哪一个水平更高呢?
(2)牛逼的人
这类人在工作中,一般有着较强的责任心,且对代码有着很高的追求,对问题有着独特的见解,回去也会不断的学习,提升自己。然而这类人的所学,通常没有发挥的空间。比如,可能出现下面的对话

程序员A:"老王,你这个地方不能这么写,会出现XXX的BUG的。"
老王:"你懂什么,公司创立的时候,我就在这个项目组了,就该这么写。"

于是这类人的所学,并没有啥发挥空间。就算有发挥的空间,过不了多久,他也会离职。因为在IT圈,只有通过跳槽才能得到高薪。这点,我们必须明白,大厂都有一套严格的薪水涨幅制度,并不会因为你做出了特别牛逼的贡献,给你月薪突然翻了一倍。而且,如果给你涨了薪水,你公司的其他人呢,他们涨还是不涨?所以,很多公司宁愿给一个新员工高薪,却不愿意给老员工提工资,就是这个道理。
因此,这类牛逼的人觉得公司现有的薪资匹配不上自己的能力后,就会跑路的。大家在IT圈会听到一个说法

B级公司就是给A级公司培养人才的,A级公司就是给S级公司培养人才的。

所以,当你发现自己身边没有牛逼的大神,不要惊讶,因为大神都跑路了。

重构成本

当一个系统的代码,成为祖传代码以后,其业务规模和复杂程度,都远远超乎你的想象。我们在开发新需求的时候,都是在原有基础上小心翼翼的修补。比如,可能出现如下对话

老王:"谁让你乱改这个模块代码的,知不知道,你这么改导致了XX模块不能用了。"
程序员A:“我。。。。只是想让代码看起来更好看而已。”
老王:"你以为我不知道这么写很挫么,乱改出问题了,你抗么。赶紧改回去。"

其实你能看到的问题,老员工看的比你更清楚,maybe人家比你还明白应该要如何解决。但是为什么老员工不去做呢?因为,老员工明白,技术上的事情没有100%肯定不出事的。出了事了,谁来背?

再打一个比方,

你一个月薪水10K,你花了5个月的时间,提升了一下10%性能。站在你的角度,你高兴了。但是站在公司的角度,卧槽,我亏了啊。我还不如花20K再买一台机器。在你身上投入了50K,还要担心你会不会跑路。

所以,从重构成本上来看,又提高了。
另外,很多中层的领导,基本都是守着自己的一亩三分地,不求无功,但求无过。所谓祖传代码的出现,其实是整个部门的责任。你一个人重构的开开心心了,后续就可能整个部门一起加班,谁去做这种吃力不讨好的事情。而且最重要的是,在技术leader水平和开发流程没有改变的情况下,你的新代码过不了几个月又会变成所谓的祖传代码。

当然,但是这并不意味着,这些技术项目没救了。比如,某一天你的对手,出了个吊打你们项目的产品。这种时候,只能大改了。反正搏一搏,没准还有出路呢。

公司性质

其实,大部分的公司都是重视业务价值,而看不到技术价值
有些大厂存在一个很有趣的现象,产品经理的薪资比技术人员的薪资还高。因为他们觉得,无外乎是增删改嘛,找点应届生就能作了,没必要花大价钱请牛逼的人来写。
于是呢,很多中层是所谓的没写过代码的业务员,又或者是没撸过一行的代码的产品经理,然后就很搞笑了,会出现如下情形

产品经理:"这个功能,你们看一下要多久才能实现。"
研发人员:"大概下个月十五左右吧。"
产品经理:"什么!要这么久。就初一,下个月初一,一定要上。"
研发人员:"我!!!!这个功能XX地方比较复杂,需要点时间。"
产品经理:"你当我傻么,就是if else。。可以实现的,怎么要这么久!"
研发人员:"我!!!"
产品经理:"就下个月初一了,做不出来,公司的损失你背还是我背!"

于是呢,在重视业务价值的公司,无论你多牛逼,乃至你是码神下凡,你写出的代码也是不堪入目。说到这里,博主的那个朋友不服,他辩解道

"我们可以在前期做好设计和规划后,再开始开发啊,这样就能减少出现渣渣代码的可能性。"

确实,我承认这么做可以减少出现烂代码的可能性。然而,大家都知道,需求是一个善变的小姑娘,一天一个样。你再牛逼的设计,也顶不住需求的频繁变更啊。
其实,在某些时候,没有必要把代码当成一种艺术品,应该要能够接受适当程度的瑕疵。只要到点可以跑,可以追踪BUG,基本能交差就成。我相信,给任何一个人足够的时间,都能把代码变成一个艺术品,但是这有什么用。等你弄好,黄花菜都凉了。迅速上线,能挣到钱才是重点啊,才是你的KPI体现啊。很多优秀的代码,是给了重构的时间的,大牛们都是一边写一边重构的。如果不给时间,大牛们也写不出优秀的代码的。换句话说,你完全可以后面挣到钱以后,再把原来的架构推导重来。
我们要明白,写代码是为了挣钱,而不是为了雕琢一个所谓的艺术品。如果将写优秀代码比作一种情怀,请问

情怀重要,还是金钱重要?情怀能让你买房么。

OK,弄清楚主次,挣钱才是硬道理。

审视自己

这个地方,我希望大家好好审视一下自己,因为重点不是

大公司为什么还在采用过时的技术

而是

你为什么只能进采用过时技术的公司

其实,每一个公司都有一个所谓的标杆部门,这个部门的技术通常是拿的出手的。可是,这样的部门,通常是最难进的。所以啊,你要去拿的出手的部门,好好努力吧,少年们。
OK,到这里,大家好好思考一下吧。大家有什么问题,也可以给我留言。

总结

啰里啰唆的扯了一堆,希望大家看完以后,能有所收获。工作中,不断的提升自己,少一些抱怨吧。

转载于:https://www.cnblogs.com/rjzheng/p/9463577.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/427182.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java 文件上传 配置_SpringMVCMultipartFilefile文件上传及参数接收

一、form表单属性中加上enctype"multipart/form-data"form表单的二、配置文件中配置MultipartResolver文件超出限制会在进入controller前抛出异常,在允许范围内这个配置无影响三、MultipartFile接受文件并通过IO二进制流(MultipartFile.getInputStream())…

list foreach方法_Java集合三兄弟List,Set,Map你分的清楚吗?

前言集合作为Java基础知识的核心部分,不论是在面试还是平时工作中都是经常遇见的。当然面对熟悉的List、Set、Map,面试管的提问一般也都不会从简单的问题出发了,今天就来聊下集合中的高级部分,让你对它们的理解更加清楚。一、List…

centos7.3防火墙配置

Centos7.3防火墙配置 1、查看firewall服务状态 systemctl status firewalld 2、查看firewall的状态 firewall-cmd --state 3、开启、重启、关闭、firewalld.service服务 开启 service firewalld start 重启 service firewalld restart 关闭 service firewalld stop 4、…

SpringBoot使用Jsp

本文是简单总结一下SpringBoot使用Jsp的Demo。 前言 在早期做项目的时候,JSP是我们经常使用的java服务器页面,其实就是一个简化servlet的设计,在本文开始之前,回顾一下jsp的几大对象,如图。 而在现在SpringBoot框架流行…

java 持久_Java持久锁总结 -解道Jdon

并发主题Java与持久相关的锁总结本文总结Java中有关数据库保存持久数据的锁机制,不只是纯粹数据库自身的锁,本文主要就Java持久层三个技术数据库、JPA和Hibernate的锁应用进行了总结。在并发理论中,锁是用于保护可变的共享数据,以…

cacti 监控安装失败

1首先这是基于lnmp模式进行的 2yum安装 yum -y install httpd mysql mysql-server php php-mysql php-json php-pdo 3lib库 yum -y install cairo-devel libxml2-devel pango pango-devel 4 解压rrdtool-1.3.1.tar.gz Cd rrdtool-1.3.1 ./configure --prefix/usr/local/rrdtoo…

project 模板_施工进度横道图不会做?18份计划模板收藏好,输入参数迅速成图...

施工进度横道图不会做?18份计划模板收藏好,输入参数迅速成图作为施工组织设计的关键内容,施工进度计划控制了工程施工进度、工程施工期限等各项施工活动。进度计划是否合理,直接影响施工速度、成本和质量。因此施工中的其他工作必…

JavaScript学习系列3 -- JavaScript arguments对象学习

在实际项目开发中,目前还是很少使用到JavaScript 中的arguments对象,那么它到底是干什么用的呢 arguments是JavaScript中的一个类数组对象,它代表传给一个正在执行的函数function的参数列表。 看完这个定义,需要明白&#xff0c…

二叉树垂直遍历 java_【004】二叉树垂直遍历

二叉树垂直遍历题目描述输入输出示例输入实例输出DFSBFS更简单的方法二叉树垂直遍历题目描述对于一个二叉树,输出它的垂直遍历结果;对于同一列的节点,按照从左向右,从上向下的顺序排列。例如,对于以下二叉树&#xff1…

matlab二元一次方程求解_2-函数的求解计算

一、本期介绍函数的求解有两种(1)已知x求y(2)已知y求x1.1已知x求y回想我们上一期,讲了多项式求解的方法,也是已知x求y。想一下,多项式不也是函数的一种吗,所以本期求解的方法同样适用…

linux lnmp yum版安装

LAMP(linux、apache、mysql、php),是四个套件的合成,简单讲就是要把php运行在linux上,需要依赖apache和mysql数据库。 1 准备好一个linux系统(centos7)   确保selinux、firewall已经关闭   …

面向对象的四大特征

面向对象的四大特征 面向对象的程序设计方法要求语言必须具备抽象、封装、继承和多态性这几个关键要素。 面向对象程序设计,是通过为数据和代码建立分块的内存区域,以便提供对程序进行模块化的一种程序设计方法。对象是计算机内存中的一块区域&#xff0…

python装饰器调用顺序_聊一聊Python装饰器的代码执行顺序

为什么写这篇文章?起因是QQ群里边有人提了一个问题:之前导入模块只需要1~2秒,为什么现在变成需要2~3分钟?我的第一感觉是:是不是导入的模块顶层代码里边,做了什么耗时的事情。隔了一天,他的问题…

centos7 安装cacti

1 cacti运行环境准备   cacti需要phpapachemysqlsnmpRRDTool,以及cacti本身。cacti本体是用php开发的网站,通过snmp对远端设备信息进行采集。apachemysqlphp在以前已经做过了      这里只对剩余的部分进行安装。 2 安装snmp    yum install -y n…

python第三方库-基础

1.python社区 python有一个全球社区,提供了超过十三万个涵盖各种领域应用的第三方库,该社区可通过 http://pypi.org/ 来访问。PyPI(Python Package Index)是python包的索引,学会检索并利用PyPI,找到合适的第…

python折线图matplotlib库_Python如何使用内置库matplotlib绘制折线图

这篇文章主要介绍了Python如何使用内置库matplotlib绘制折线图,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下环境准备:需要安装matplotlib,安装方式:pip install matplotlib…

linux下zabbix安装

1本人用的是apachemysqlphp 2下载zabbix软件包,官网下载 https://sourceforge.net/projects/zabbix/files/ZABBIX Latest Stable/2.2.23/zabbix-2.2.23.tar.gz/download 上传到 var/www/html下 3cd /var/www/html #进入软件包下载目录 tar zxvf zabbix-2.2.23.tar.g…

java cas机制_Java CAS机制详解

CAS目的:在多线程中为了保持数据的准确性,避免多个线程同时操作某个变量,很多情况下利用关键字synchronized实现同步锁,使用synchronized关键字修可以使操作的线程排队等待运行,可以说是一种悲观策略,认为线…

「一本通 4.1 练习 2」简单题

题目描述 题目来源:CQOI 2006 有一个 n 个元素的数组,每个元素初始均为 0。有 m 条指令,要么让其中一段连续序列数字反转——0 变 1,1变 0(操作 1),要么询问某个元素的值(操作 2&…

定时器取数据时实时进来的数据_Redis-数据淘汰策略amp;持久化方式(RDB/AOF)amp;Redis与Memcached区别...

Redis与Memcached区别: 两者都是非关系型数据库。主要有以下不同: 数据类型: Memcached仅支持字符串类型。 redis支持:String,List,set,zset,hash 可以灵活的解决问题。 数据持久化: Memcached不支持持久化。 Redis采…