程序员别唬我系列之:中间件

4 评论 27086 浏览 40 收藏 5 分钟

关于中间件,你知道多少?

有朋友留言,希望说说啥是「中间件」。

「中间件」英文为middleware,是一个合成词,middle都认识,不解释了,ware表示“器皿”,“物件”的意思,中文翻译过来就是“位于中间的物体”。

在计算机中,简单可以理解为“中间件是这样的软件,它位于两个软件中间,广义的讲,这两个软件一般为应用软件和系统软件之间”。

淘宝,有代办签证这样的业务,但无论互联网还是面签,所有的签证办理机构应该是对你开放的,而且可以省去直接办理和代办的差价,但是这样的业务还是很红火。

房产交易,国家房产交易部门完全对个人开放办理,但是一些中介机构仍然在大量充当陌生人房产交易的枢纽,并赚取佣金。

电子商务,支付宝、理财通充当了人和商家之间的中转和媒介,使交易更有保障和快捷。

这三个事物中,可以抽象出什么共性呢?我试着描述一下几个特点:“专业、安全、快捷、成本低”,它们是我们生活中的「中间件」。

我们把签证中心,房产交易所,商家理解为操作系统的话,我们每个人相当于应用层软件。其中淘宝平台,房产交易中介,还有支付宝、理财通就是“中间的软件”。

让我们回来挨踢(IT)。

如果你比较早的接触过IT工作的话,你一定应该听说过.NET和Java之争,他们就是中间件,他们位于操作系统之上,用来更方便的构建应用程序,他们对操作系统更好的包装,让开发者并不需要深入的了解操作系统,就可以开发应用程序,而且开发效率高,稳定,学习成本低。

这就是中间件的好处和作用,刚才讲的都是广义上的中间件,一般都是TO B或者面向开发者的,不面向普通用户。

那整天程序员嘴里BB的中间件是什么呢?

大概是秉承了「中间件」广义的概念,比如一个项目中有大量对文件读写的操作,不仅正常读写,还有边读边写的需求,还有读一个字节,然后写两个字节的需求,还有从某一位置替换特定的字符个数等等需求,并且都是用在不同的模块中,大家各写各的,用的乱七八糟。

这个时候果果站出来了,装逼的喊了一声,对文件的所有操作都有我来写吧,做“文件读写”操作,我是专业的。果果将所有方法抽象出来,大同小异的方法进行抽象收敛,形成了一套适合于本项目的”关于文件读写的中间件”,后面所有项目成员,都使用我的「中间件」就行了,大大提高了工作效率,领导发现果果同学节省了大量的开发时间,心态又这么积极,承诺一定要给果果一个优秀员工的称号呢~

这种狭义的概念,你会发现和我们以前讲的SDK,接口很像,也就是狭义的中间件,可能就是一个小功能的封装,或者某些特性的抽象表述。程序员经常说:“不要重复造轮子”,这些轮子在狭义上都可以称为「中间件」,一些比较好的开源项目也相当于中间件,另外以前讲的组件,狭义上也可以理解为中间件。

#专栏作家#

给产品经理讲技术,微信公众号(pm_teacher),人人都是产品经理专栏作家。资深程序猿,专注客户端开发若干年,对前端、后台技术略懂,热衷于对新的科技领域的探索。

本文原创发布于人人都是产品经理。未经许可,禁止转载。

题图来自PEXELS,基于CC0协议

更多精彩内容,请关注人人都是产品经理微信公众号或下载App
评论
评论请登录
  1. 具体有哪些?

    回复
  2. 实际工作中很少提这些虚的概念了。一开始曾经做过技术的我一看这标题都被唬住了,进来才知道讲的就是写的一些基础class(面向对象)

    来自福建 回复
    1. 木有技术背景的小pm,表示还是挺受用的😶

      回复
    2. +10086 也许层主不是目标读者吧 小白觉得受益匪浅 谢谢果巨巨 也谢谢善良的小奶汪

      来自四川 回复