设为首页收藏本站

爱吱声

 找回密码
 注册
搜索
查看: 8314|回复: 47

[信息技术] Best Practice

  [复制链接]
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

    发表于 2011-9-27 22:11:04 | 显示全部楼层 |阅读模式
    这里干软件开发,经常会遇到迷信Best Practice的家伙,一说起来什么都要遵循这个,否则就要不依不饶跟你扯,实在是烦人啊。! |8 q' _$ G+ \% E) y0 o7 A

    1 |- U9 \$ k1 u( n- Z& r举个例子,一个web应用,给分成了presentation layer, business layer, data access layer等等。这个分法倒是很合理,问题是人家认为数据的校验也是每层都要做的,理由是各层都有可能被替换,你如果不做如何保证数据是符合要求的?很对,但是实践中就有很多问题不好办了,问题出在了测试上。* n- v( G9 H7 e# L. E

    % ?3 U! F& C$ V  m: w8 j具体说来是这样的,presentation layer包括浏览器部分和服务器的对应接口部分,前者的校验用javascript而后者用java,这就是两层测试了,再加上business layer的那层,起码就是三层了。这三层测试所做的工作,或者说所依据的规则一般是一样的,因为就是一个java bean在那里传输数据嘛。可是问题是如果第一层已经做的完善了,第二层又怎么可能检测出问题来呢,因为可能的错误已经都在第一层被发现了嘛,于是为了让第二层检测能够工作,你必须关掉第一层检测,这意味着修改代码,而任何修改都意味着可能带来新的bug,这个怎么检测?第二层和第三层之间的问题跟前面是一样的,也就是你必须关掉第二层的检测来让第三层的检测有机会干活,这里同样存在前述的可能带来新的bug问题,同时这三层检测在交付以后需要同时存在重复检测,这开销怎么算?2 N) a- d$ E8 a5 w% G( Y5 [/ s# m& z
    ; x/ I+ ~0 ^1 R$ S; I0 a' M* ^6 L' x
    有人可能会说,那是必要的代价,因为各层都有可能被替换,因此各层自己的检测是必不可少的。理论上这话完全对,可是现实中几乎不存在替换的可能,因为那意味着整体结构的大修改,即使出现这样的情况,交付以后的其他各层检测还是没机会干活的。于是一个看起来完美的方案,现实中只是在浪费资源而已,因为同样的数据要被检测三次,而只有第一次有可能被检测出问题来,后面那两个都是白忙乎。
    ( H& @$ K/ L0 i8 u, B( w8 e& c+ ^. g: y6 c( z' n
    这方面的另外一个例子就是ESB领域,这个领域的用户普遍都是些大用户,具体实践就是一大堆的web service在那里以workflow的方式运行,这点没问题,问题是每个web service的设置都有着全套的安全规范,例如双向SSL和WS-SECURITY之类的,哪怕是这堆web service都运行在同一台逻辑机器上也一样,于是就是大量的开销却没换来任何安全上改进。
  • TA的每日心情
    慵懒
    2016-4-2 21:31
  • 签到天数: 30 天

    [LV.5]元婴

    发表于 2011-9-27 22:17:30 | 显示全部楼层
    隔行如隔山,对我而言基本看不懂
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

     楼主| 发表于 2011-9-27 22:43:07 | 显示全部楼层
    小绿爷 发表于 2011-9-27 09:17 + }# g9 z& |; t" @( z% n
    隔行如隔山,对我而言基本看不懂

    4 O; a$ p# p8 s9 P7 `5 Q! o没关系,重在参与嘛

    该用户从未签到

    发表于 2011-9-27 23:32:49 | 显示全部楼层
    同意一楼意见。。。
    4 P; q) h$ G# r1 j囧,什么都没看懂。。哈哈
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

     楼主| 发表于 2011-9-27 23:33:51 | 显示全部楼层
    旅途愉快 发表于 2011-9-27 10:32 # J7 |# Q" R" R) M' U
    同意一楼意见。。。( n: c1 k, p2 y- o, R9 l/ p% R: M
    囧,什么都没看懂。。哈哈

    % v9 }8 S. h3 \) q# Z又是一个重在参与地
  • TA的每日心情
    无聊
    2021-8-3 07:02
  • 签到天数: 515 天

    [LV.9]渡劫

    发表于 2011-9-27 23:49:47 | 显示全部楼层
    我家倒是有本书,Thinking in JAVA,是LD的,不过她现在在搞ORACLE。。。
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

     楼主| 发表于 2011-9-27 23:51:11 | 显示全部楼层
    tonyxu 发表于 2011-9-27 10:49 2 ~- r" q, S% w* c8 J: [, \
    我家倒是有本书,Thinking in JAVA,是LD的,不过她现在在搞ORACLE。。。

    ; A4 i  r( _! ?0 Y" f0 v1 Z还是个重在参与地
  • TA的每日心情
    无聊
    2021-8-3 07:02
  • 签到天数: 515 天

    [LV.9]渡劫

    发表于 2011-9-27 23:53:00 | 显示全部楼层
    老兵帅客 发表于 2011-9-27 23:51 ( e1 D! u! J6 x% q9 K/ O" J
    还是个重在参与地

    5 ]. i) R; \( ^( e: h9 @absolutely...
  • TA的每日心情
    开心
    2018-12-31 23:52
  • 签到天数: 4 天

    [LV.2]筑基

    发表于 2011-9-27 23:54:17 | 显示全部楼层
    不懂,坐等懂的人来谈。
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

     楼主| 发表于 2011-9-28 00:00:50 | 显示全部楼层
    飞翔的芦苇 发表于 2011-9-27 10:54
    0 M) h! H4 O4 p2 ]  e不懂,坐等懂的人来谈。
    . s: D5 n; W2 p' ?3 P5 o
    怎么就剩下重在参与的了,干这行的都哪里去了?

    点评

    我懂RT-PCR,:),计算机很小白,要不就去做生物信息学去了,这个方向火得很。  发表于 2011-9-28 09:17

    该用户从未签到

    发表于 2011-9-28 07:11:54 | 显示全部楼层
    软件中检测部门大部分都是女性吧,华为的软件研发我很清楚,全球采购便宜的,再加上核心数据集成。
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

     楼主| 发表于 2011-9-28 07:58:30 | 显示全部楼层
    fareast 发表于 2011-9-27 18:11
    , e: a! {' V& _$ o$ m# N; c) y软件中检测部门大部分都是女性吧,华为的软件研发我很清楚,全球采购便宜的,再加上核心数据集成。 ...
    * C: C: T: S4 B
    你说的是做QA的,我说的是软件开发过程中写的检测程序,两回事。
  • TA的每日心情
    慵懒
    前天 01:53
  • 签到天数: 1476 天

    [LV.10]大乘

    发表于 2011-9-28 11:32:07 | 显示全部楼层
    esb那个如果不是全是自己搞,不好这么算,用效率和实效的角度考虑防止扯皮是想不透的。8 |3 Z/ M+ p- A1 h
    第一个问题其实也是两说,就是不知道这么提倡的家伙是从哪个角度考虑了。
  • TA的每日心情

    2016-9-18 00:11
  • 签到天数: 285 天

    [LV.8]合体

    发表于 2011-9-28 11:50:29 | 显示全部楼层
    个人认为, 每一层的检验是必要的,但是,重点应该在于本层所生成的数据,而不是检查前一层送来的数据.- N  z  @0 `) \/ C2 g  n
    也就是说,需要假设,前一layer/flow送来的数据都是准确的.8 ?* ^% J3 o% |2 W9 }& E
    当然,必要的入口参数exception还是需要设一下的.如果真的发生了exception,那么可以推论是前一layer/flow出错了,让前一层自己去查吧.
  • TA的每日心情

    2024-2-11 13:31
  • 签到天数: 141 天

    [LV.7]分神

    发表于 2011-9-28 12:09:28 | 显示全部楼层
    老兵说得很有道理的。不过这个还是要看放在什么应用环境下。/ [! U0 q8 L: T

    4 ]% z& u0 ~5 P$ e; c对每层数据都校验,有个应用的地方就是中间层和数据层的复用。从复用的角度来说,如果中间层有校验,那么在写表现层时排查错误,处理异常就会相对比较方便。不过我遇到的这种场景情况很少。
    4 p3 |# I& p" }/ D1 k7 }) l* R
    : u! y3 ^9 i8 K7 R+ E# ^$ \  W% X& k一般的应用我觉得数据库的内生校验加上表现层的校验,应该基本上足够了。程序能卖钱是因为程序能WORK,而不是因为检测的代码写得多。$ O3 q! V8 ^' `* _0 S; f; C# k+ S

    5 ^4 _. w) ^3 C' x6 M2 p* W$ I; L5 `; c
    2 K$ _% U4 ?( c% [
    * }8 o: H- R* v- n9 r+ p6 h  {- [. D& ]3 |
  • TA的每日心情
    奋斗
    2024-3-5 21:30
  • 签到天数: 1126 天

    [LV.10]大乘

    发表于 2011-9-28 12:46:46 | 显示全部楼层
    前Cobol程序员飘过~

    点评

    肯定是这样的,电影里面的黑客和银行核心系统开发人员完全是两类人。  发表于 2011-9-28 17:23
    俺离开那行已经很久了,估计现在一行代码都写不出来廖~ 有空写一下银行核心系统开发的事儿,木有电影里写的那么牛掰~  发表于 2011-9-28 15:01
    银行啊,银行啊,这个我都知道的。  发表于 2011-9-28 14:56
    你就没不小心给程序留个后门,每天每人往你家账户上转个0.01.... :P  发表于 2011-9-28 14:42
    啥大钱?那些数字在俺眼前就是浮云~  发表于 2011-9-28 13:08
  • TA的每日心情
    慵懒
    2019-6-5 13:01
  • 签到天数: 115 天

    [LV.6]出窍

    发表于 2011-9-28 12:56:28 | 显示全部楼层
    。。。5 Q( n' U7 a) j! H+ ^
    我是来重在参乎的6 A5 J3 ]' W7 S
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

     楼主| 发表于 2011-9-28 17:13:09 | 显示全部楼层
    本帖最后由 老兵帅客 于 2011-9-28 04:13 编辑 ; m! u, v6 f* e8 O3 ~
    四处张望 发表于 2011-9-27 22:32
    6 m. v- I; f; X1 I9 fesb那个如果不是全是自己搞,不好这么算,用效率和实效的角度考虑防止扯皮是想不透的。% }) {2 P, h, e, }- j8 k+ K
    第一个问题其实也是 ...
    9 L3 V( ?- X6 t  W# l. G
    ( v7 J. V5 I9 j  y
    esb那个全是自己搞的,而且预先知道就放在自己的内部机器上。' s5 r, }- ?1 Y8 ], x

    7 w0 k. O" ^) G/ v8 t$ p
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

     楼主| 发表于 2011-9-28 17:18:13 | 显示全部楼层
    空气精灵 发表于 2011-9-27 22:50 ) K7 G: l6 q5 [1 i. Y1 \+ E
    个人认为, 每一层的检验是必要的,但是,重点应该在于本层所生成的数据,而不是检查前一层送来的数据.2 ]! B8 ~- Y% f; N8 q, U3 V2 Z  [
    也就是 ...

    $ b' {% f6 O4 c  ^: J  D$ Q$ a嘿嘿,你说的是检测自身的数据而不是前层传递来的数据,这是design by contract的概念,也就是pre-condition。我文中所说的是每一层都重复检测前层的数据,这就是另外一种思路了,没有pre-condition而是边界之外是险恶的世界。

    点评

    所以才说没意义啊.疑犯要从无 :)  发表于 2011-9-28 17:30
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

     楼主| 发表于 2011-9-28 17:21:53 | 显示全部楼层
    mark 发表于 2011-9-27 23:09
    ) H- t" W( U5 `& R- ~老兵说得很有道理的。不过这个还是要看放在什么应用环境下。5 V% {2 A% U! w8 c/ u( y
    : C- t7 S9 J0 g
    对每层数据都校验,有个应用的地方就是中间层 ...
    ! G7 k) N. ?: s# J9 f( _, {2 d5 p
    我的想法是每层有各自的任务,重复检测没有意义。

    点评

    谢谢  发表于 2011-10-6 12:06
    赞同  发表于 2011-10-6 11:54

    手机版|小黑屋|Archiver|网站错误报告|爱吱声   

    GMT+8, 2024-4-18 15:33 , Processed in 0.051328 second(s), 19 queries , Gzip On.

    Powered by Discuz! X3.2

    © 2001-2013 Comsenz Inc.

    快速回复 返回顶部 返回列表