程序员需要SOA吗?----SOA业务开发平台(二)_几年的程序员涉及到soa-程序员宅基地

技术标签: delphi  soa  平台  编程  游戏  api  

我93年开始学习编程,当时求伯君,朱崇君,吴晓军已经名满天下的,估计不少新一代的程序员,除了求伯君和金山在,其他的两位,许多人都已经不认识了。我还用过五寸盘,但当时三寸盘已经流行了。WIN3.1让人羡慕。

当时,显卡,CPU,内存都极为简陋。写程序必须对这些资源都吹毛求疵,想尽各种脑汁对付这个一穷二白的机器。也没有现成的图形库和算法库,现在对DirectX的进化尤其羡慕。

当时,面向对象,我还不知道为何物。目的,就是想写个游戏软件,省得我老给游戏厅老板送钱。

一直在乱写代码,代码多了,自己都if..else的绕的头疼,于是把代码分段,分成函数。对于客户来说,当然没啥感觉,反正他又不认识代码,他也不想看代码,用功能就是了。但是对于自己维护代码,修改代码,增加新功能却好很多,因为阅读容易了,所以写的就快了。但过去也是瞎分函数,其实就是感觉太长,理解起来脑子不够使了,就分成函数了,其实函数之间还是用公共变量连在一起,后来才发现了问题严重性,公共变量被函数赋值来赋值去,把我自己都搞晕了,都弄不清楚目前这个变量是什么值,当然程序的稳定性就没有了,为了调试错误花了我大量时间,客户也不满意,给收入带来了影响。想,怎么能解决这个问题呢,怎么不让函数间纠缠不清呢,于是下功夫冥思苦想函数的发源,用意。过去认为自己写个function就是函数了,其实只有函数的形,没有函数的神,函数根本没有起到函数的全部作用,只是让阅读看起来容易了一些,但是由于函数间用公共变量联系在一起(没办法啊,函数之间肯定有逻辑关系,当时想到的自然是公共变量的方法,但居然现在还有不少程序员在犯我93年的问题)。

过去也没有互联网,也没有现在发达的图书出版业,也没有现在众多的程序员,只能自己苦想,最后才在计算机课本上看到真正的函数描述。唉~~,平时觉得课本无用,到了要讲真功夫的时候,发现自己苦找的原来就在身边就在课本上(现在不少计算机专业的学生都说学校课程无用,让人叹息呀)。琢磨课本,于是才真正开始使用函数。函数,就要封装,自我封闭。有输入,有输出,才叫函数。函数对外是黑盒子,只要安心调用就是了,函数内部怎么申明变量,怎么给变量改变值,是函数自己内部的事情,函数自己负责自己,别的函数根本不用操心自己调用的其他函数的内存创建呀释放呀什么的,让函数之间尽量关联越少越好,就是通过函数的参数入口来联系彼此。

这下,修改代码,只修改某几个函数,增加功能,也是增加几个函数,函数之间耦合低,所以代码写的也稳定,写的也快了,阅读也快了。对于客户来说,他不知道我发生了什么变化,但是他能感觉得到我的软件稳定,修改的也快了,客户的满意度又回来了。这就是面向函数的好处(虽然没有人提面向函数这个词)。

函数是用的美不滋儿了。但问题又来了,函数太多也闹心啊。没封装函数前,是代码大流水让人脑子想不清楚了缺氧了。现在封装了函数,函数多的这个函数调那个,那个又调另一个,照样缺氧了。尤其要维护的时候,打开源代码,一片片的函数,都不知道这么多函数是个什么关系,到底要重点看哪些函数,哪些函数从属哪些函数?现在都是平辈儿,谁都分辨不出来。又闹心了。

96年,开始学习DELPHI,人家都面向组件了,自己的思维还不知道。自己连面向对象的概念都没有。但类啊什么的,倒是有耳闻了。但和过去用函数之前一样,只知道形,不知道神。用了很久DELPHI,也是只用人家的类和人家的组件,自己写点东西,还是函数。知道函数闹心,但也没想到用类去解决。

最后开始安心读DELPHI的类库源代码的时候(当时是自己也想做个组件,呵呵,连面向对象都没用过,就自己想面向组件?但当时自己根本没想到面向组件这一说法),越读越深,越读越感觉人家这代码写的好。但仍然愚蠢的不知道人家使用的是面向对象的妙处,只是自己立志也要写这样的代码。于是照猫画虎学着人家的样子写。这就是我开始面向对象的第一步,其实自己都不知道自己已经在面向对象了。

不知道是学人家DELPHI的类库作者高手的源代码的原因,还是自己应用面向对象的原因,反正过去函数扎堆成群的问题缓解了,我的软件稳定性又回来了,修改的也快了,客户的满意度又回来了。唉~~,每一次代码规模的扩大(没办法不成规模扩大呀,现在业务越来越复杂,当然代码越来越多),都需要一种方法解决问题。

写着写着,就自己开始琢磨了,为什么这样写会代码好维护,过去写了成群的函数就不好维护了。就开始自己对比自己写的过去的函数代码和现在照猫画虎的面向对象的的代码。哦,原来是把一些函数都分级了,有私有,有公共,有这个类,有那个类。原来是把过去200个函数,又切割分块了,就如同过去把1000行代码分割一样。

当然,各位看官又想到了,面向对象也不灵了,代码太多了,类太多了,又需要一种新的方法解决问题啦。不好意思,确实想说这句话。

自己回想,还是函数太多,还需要封装。阅读人家DELPHI源代码,人家用了一个新关键字,叫属性。这个属性有两种,一种是事件,我理解它是一种切入式编程,一种是正宗的属性。原来,人家用属性隐藏了函数。一个属性,可以有读的函数,也可以有写的函数。我过去是暴露了两个函数,人家只用了一个简单的属性就搞定,把函数都藏起来了。代码简单多了,调用也简单多了,容易理解多了,自己阅读代码也不需要关注那么多函数了,代码之间的关系关联性也更容易可见了。看来,还是需要继续多写代码,不多写代码,就遇不到问题,不多写代码,就琢磨不透现在这些技术到底是解决什么问题的,就无法深刻理解现在这些技术的精妙之处。还要继续多写代码,多琢磨代码。谁理解不透,就说明谁写的代码还是少。

??真是奇怪,面向函数,面向对象,面向组件,居然这样?每次都是增加一点点新的东西,就换个名字?就这么简单?但确实挺管用,解决了自己头疼的代码多的问题。代码一多,脑子就不够使,就不容易阅读理解,不容易下手修改,当然改了也是不知道能不能稳定(能稳定才怪,自己都看不懂代码,还想稳定?)

从面向函数,面向对象,面向组件,发现自己的代码被越封装越高了。就如同过去写程序,我们需要调用各种WINDOWS API,最后DELPHI把API封装成各个类库,有的更封装成了组件,如ADO组件和IP组件,就简单多了。写代码快多了。

但是,还有人不满足(当然也包括我)。大家不知道有没有这样的感受,组件拖拽,确实开发进度比过去是快了许多,但是现在的组件是越做越复杂,N多的属性,N多的方法,N多的事件,我要干某个工作,我不知道哪几个属性互相配合才能有效达到目的,一拉开属性查看器,看见滚动条和折叠起来的更多的属性配置就头大,心想怎么现在的东西这么复杂。

没办法,吃了馒头还要吃蛋糕,人的欲望是无穷的,这都还嫌不好。心想,如果我做某件事,传几个参数,OK,就能达到我的效果那该多好。别让我再配置这个属性那个属性,让我调用这个方法那个事件的。

看来,需求越来越复杂了,代码规模越来越大了,程序员必须加快工作效率才能应付的上,现在组件变的越来越复杂,程序员的编写代码速度与客户的变化速度不匹配了,唯有封装的更高。一个函数就搞定的。

嗯。面向服务出现了,一个函数就搞定,内部组件的属性如何改变,方法如何调用,那是组件内部的事情了。
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/david_lv/article/details/2972124

智能推荐

使用nginx解决浏览器跨域问题_nginx不停的xhr-程序员宅基地

文章浏览阅读1k次。通过使用ajax方法跨域请求是浏览器所不允许的,浏览器出于安全考虑是禁止的。警告信息如下:不过jQuery对跨域问题也有解决方案,使用jsonp的方式解决,方法如下:$.ajax({ async:false, url: 'http://www.mysite.com/demo.do', // 跨域URL ty..._nginx不停的xhr

在 Oracle 中配置 extproc 以访问 ST_Geometry-程序员宅基地

文章浏览阅读2k次。关于在 Oracle 中配置 extproc 以访问 ST_Geometry,也就是我们所说的 使用空间SQL 的方法,官方文档链接如下。http://desktop.arcgis.com/zh-cn/arcmap/latest/manage-data/gdbs-in-oracle/configure-oracle-extproc.htm其实简单总结一下,主要就分为以下几个步骤。..._extproc

Linux C++ gbk转为utf-8_linux c++ gbk->utf8-程序员宅基地

文章浏览阅读1.5w次。linux下没有上面的两个函数,需要使用函数 mbstowcs和wcstombsmbstowcs将多字节编码转换为宽字节编码wcstombs将宽字节编码转换为多字节编码这两个函数,转换过程中受到系统编码类型的影响,需要通过设置来设定转换前和转换后的编码类型。通过函数setlocale进行系统编码的设置。linux下输入命名locale -a查看系统支持的编码_linux c++ gbk->utf8

IMP-00009: 导出文件异常结束-程序员宅基地

文章浏览阅读750次。今天准备从生产库向测试库进行数据导入,结果在imp导入的时候遇到“ IMP-00009:导出文件异常结束” 错误,google一下,发现可能有如下原因导致imp的数据太大,没有写buffer和commit两个数据库字符集不同从低版本exp的dmp文件,向高版本imp导出的dmp文件出错传输dmp文件时,文件损坏解决办法:imp时指定..._imp-00009导出文件异常结束

python程序员需要深入掌握的技能_Python用数据说明程序员需要掌握的技能-程序员宅基地

文章浏览阅读143次。当下是一个大数据的时代,各个行业都离不开数据的支持。因此,网络爬虫就应运而生。网络爬虫当下最为火热的是Python,Python开发爬虫相对简单,而且功能库相当完善,力压众多开发语言。本次教程我们爬取前程无忧的招聘信息来分析Python程序员需要掌握那些编程技术。首先在谷歌浏览器打开前程无忧的首页,按F12打开浏览器的开发者工具。浏览器开发者工具是用于捕捉网站的请求信息,通过分析请求信息可以了解请..._初级python程序员能力要求

Spring @Service生成bean名称的规则(当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致)_@service beanname-程序员宅基地

文章浏览阅读7.6k次,点赞2次,收藏6次。@Service标注的bean,类名:ABDemoService查看源码后发现,原来是经过一个特殊处理:当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致public class AnnotationBeanNameGenerator implements BeanNameGenerator { private static final String C..._@service beanname

随便推点

二叉树的各种创建方法_二叉树的建立-程序员宅基地

文章浏览阅读6.9w次,点赞73次,收藏463次。1.前序创建#include<stdio.h>#include<string.h>#include<stdlib.h>#include<malloc.h>#include<iostream>#include<stack>#include<queue>using namespace std;typed_二叉树的建立

解决asp.net导出excel时中文文件名乱码_asp.net utf8 导出中文字符乱码-程序员宅基地

文章浏览阅读7.1k次。在Asp.net上使用Excel导出功能,如果文件名出现中文,便会以乱码视之。 解决方法: fileName = HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8);_asp.net utf8 导出中文字符乱码

笔记-编译原理-实验一-词法分析器设计_对pl/0作以下修改扩充。增加单词-程序员宅基地

文章浏览阅读2.1k次,点赞4次,收藏23次。第一次实验 词法分析实验报告设计思想词法分析的主要任务是根据文法的词汇表以及对应约定的编码进行一定的识别,找出文件中所有的合法的单词,并给出一定的信息作为最后的结果,用于后续语法分析程序的使用;本实验针对 PL/0 语言 的文法、词汇表编写一个词法分析程序,对于每个单词根据词汇表输出: (单词种类, 单词的值) 二元对。词汇表:种别编码单词符号助记符0beginb..._对pl/0作以下修改扩充。增加单词

android adb shell 权限,android adb shell权限被拒绝-程序员宅基地

文章浏览阅读773次。我在使用adb.exe时遇到了麻烦.我想使用与bash相同的adb.exe shell提示符,所以我决定更改默认的bash二进制文件(当然二进制文件是交叉编译的,一切都很完美)更改bash二进制文件遵循以下顺序> adb remount> adb push bash / system / bin /> adb shell> cd / system / bin> chm..._adb shell mv 权限

投影仪-相机标定_相机-投影仪标定-程序员宅基地

文章浏览阅读6.8k次,点赞12次,收藏125次。1. 单目相机标定引言相机标定已经研究多年,标定的算法可以分为基于摄影测量的标定和自标定。其中,应用最为广泛的还是张正友标定法。这是一种简单灵活、高鲁棒性、低成本的相机标定算法。仅需要一台相机和一块平面标定板构建相机标定系统,在标定过程中,相机拍摄多个角度下(至少两个角度,推荐10~20个角度)的标定板图像(相机和标定板都可以移动),即可对相机的内外参数进行标定。下面介绍张氏标定法(以下也这么称呼)的原理。原理相机模型和单应矩阵相机标定,就是对相机的内外参数进行计算的过程,从而得到物体到图像的投影_相机-投影仪标定

Wayland架构、渲染、硬件支持-程序员宅基地

文章浏览阅读2.2k次。文章目录Wayland 架构Wayland 渲染Wayland的 硬件支持简 述: 翻译一篇关于和 wayland 有关的技术文章, 其英文标题为Wayland Architecture .Wayland 架构若是想要更好的理解 Wayland 架构及其与 X (X11 or X Window System) 结构;一种很好的方法是将事件从输入设备就开始跟踪, 查看期间所有的屏幕上出现的变化。这就是我们现在对 X 的理解。 内核是从一个输入设备中获取一个事件,并通过 evdev 输入_wayland

推荐文章

热门文章

相关标签