设为首页收藏本站

爱吱声

 找回密码
 注册
搜索
查看: 12632|回复: 47
打印 上一主题 下一主题

[信息技术] Best Practice

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

    [LV.Master]无

    跳转到指定楼层
    楼主
    发表于 2011-9-27 22:11:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    这里干软件开发,经常会遇到迷信Best Practice的家伙,一说起来什么都要遵循这个,否则就要不依不饶跟你扯,实在是烦人啊。. D1 q9 O+ g4 N2 r) `5 I, ^1 _- \/ }
    2 `" }, C7 {7 C( T
    举个例子,一个web应用,给分成了presentation layer, business layer, data access layer等等。这个分法倒是很合理,问题是人家认为数据的校验也是每层都要做的,理由是各层都有可能被替换,你如果不做如何保证数据是符合要求的?很对,但是实践中就有很多问题不好办了,问题出在了测试上。. N7 Y% Z& {/ `. h$ c1 }
    8 ?: X$ ^7 i, e8 Z
    具体说来是这样的,presentation layer包括浏览器部分和服务器的对应接口部分,前者的校验用javascript而后者用java,这就是两层测试了,再加上business layer的那层,起码就是三层了。这三层测试所做的工作,或者说所依据的规则一般是一样的,因为就是一个java bean在那里传输数据嘛。可是问题是如果第一层已经做的完善了,第二层又怎么可能检测出问题来呢,因为可能的错误已经都在第一层被发现了嘛,于是为了让第二层检测能够工作,你必须关掉第一层检测,这意味着修改代码,而任何修改都意味着可能带来新的bug,这个怎么检测?第二层和第三层之间的问题跟前面是一样的,也就是你必须关掉第二层的检测来让第三层的检测有机会干活,这里同样存在前述的可能带来新的bug问题,同时这三层检测在交付以后需要同时存在重复检测,这开销怎么算?
    - v% g9 l' u" D* a* l  y6 h. m
    9 l* i3 o1 R# [" K& s& ]% C有人可能会说,那是必要的代价,因为各层都有可能被替换,因此各层自己的检测是必不可少的。理论上这话完全对,可是现实中几乎不存在替换的可能,因为那意味着整体结构的大修改,即使出现这样的情况,交付以后的其他各层检测还是没机会干活的。于是一个看起来完美的方案,现实中只是在浪费资源而已,因为同样的数据要被检测三次,而只有第一次有可能被检测出问题来,后面那两个都是白忙乎。' d% J/ B! x! q4 m, |, f2 z6 d6 E
    2 w, c; `8 f: p' m4 E1 O: D
    这方面的另外一个例子就是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
    $ R8 b5 O3 r' X% @隔行如隔山,对我而言基本看不懂

    . V' z/ M4 F, Y! t" k' S没关系,重在参与嘛

    该用户从未签到

    地板
    发表于 2011-9-27 23:32:49 | 只看该作者
    同意一楼意见。。。
    ' s; q" }  v, ]6 B+ N! i# y! @囧,什么都没看懂。。哈哈
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

    5#
     楼主| 发表于 2011-9-27 23:33:51 | 只看该作者
    旅途愉快 发表于 2011-9-27 10:32 : z8 K3 N) A/ g9 ~8 w/ c- ~! B8 [  F
    同意一楼意见。。。1 U8 R8 I! x3 f
    囧,什么都没看懂。。哈哈

    . M+ `) @( ]% {. F1 g4 N又是一个重在参与地
  • TA的每日心情
    开心
    2024-11-19 08:25
  • 签到天数: 516 天

    [LV.9]渡劫

    6#
    发表于 2011-9-27 23:49:47 | 只看该作者
    我家倒是有本书,Thinking in JAVA,是LD的,不过她现在在搞ORACLE。。。
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

    7#
     楼主| 发表于 2011-9-27 23:51:11 | 只看该作者
    tonyxu 发表于 2011-9-27 10:49
    * N8 ^; T0 [, k& {  B- d$ [5 _我家倒是有本书,Thinking in JAVA,是LD的,不过她现在在搞ORACLE。。。

    * {# M" H( B$ B; o! e2 n3 d2 v还是个重在参与地
  • TA的每日心情
    开心
    2024-11-19 08:25
  • 签到天数: 516 天

    [LV.9]渡劫

    8#
    发表于 2011-9-27 23:53:00 | 只看该作者
    老兵帅客 发表于 2011-9-27 23:51 # T+ C: g. \2 S4 S& G3 v
    还是个重在参与地
    : K; k0 ~* u  S) ~
    absolutely...
  • TA的每日心情
    开心
    2018-12-31 23:52
  • 签到天数: 4 天

    [LV.2]筑基

    9#
    发表于 2011-9-27 23:54:17 | 只看该作者
    不懂,坐等懂的人来谈。
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

    10#
     楼主| 发表于 2011-9-28 00:00:50 | 只看该作者
    飞翔的芦苇 发表于 2011-9-27 10:54 , ~2 z; K8 g3 J' M- A0 @7 L
    不懂,坐等懂的人来谈。
    7 H% ^7 p4 d1 C2 W
    怎么就剩下重在参与的了,干这行的都哪里去了?

    点评

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

    该用户从未签到

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

    [LV.Master]无

    12#
     楼主| 发表于 2011-9-28 07:58:30 | 只看该作者
    fareast 发表于 2011-9-27 18:11
    1 S6 m% A% T; h' z, y! c1 q软件中检测部门大部分都是女性吧,华为的软件研发我很清楚,全球采购便宜的,再加上核心数据集成。 ...
    & }& Q$ ?  N& T
    你说的是做QA的,我说的是软件开发过程中写的检测程序,两回事。
  • TA的每日心情
    难过
    2025-12-23 14:18
  • 签到天数: 1669 天

    [LV.Master]无

    13#
    发表于 2011-9-28 11:32:07 | 只看该作者
    esb那个如果不是全是自己搞,不好这么算,用效率和实效的角度考虑防止扯皮是想不透的。6 c9 @/ Z# j6 z- z. D
    第一个问题其实也是两说,就是不知道这么提倡的家伙是从哪个角度考虑了。
  • TA的每日心情

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

    [LV.8]合体

    14#
    发表于 2011-9-28 11:50:29 | 只看该作者
    个人认为, 每一层的检验是必要的,但是,重点应该在于本层所生成的数据,而不是检查前一层送来的数据.$ o6 u  @# I1 ~) r. f+ r7 q. E
    也就是说,需要假设,前一layer/flow送来的数据都是准确的.& q" y8 q5 S7 d0 s4 k* H  W
    当然,必要的入口参数exception还是需要设一下的.如果真的发生了exception,那么可以推论是前一layer/flow出错了,让前一层自己去查吧.
  • TA的每日心情

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

    [LV.7]分神

    15#
    发表于 2011-9-28 12:09:28 | 只看该作者
    老兵说得很有道理的。不过这个还是要看放在什么应用环境下。; w2 H' k  X' ]/ Z

    2 v# S$ b1 H+ T: A0 H- `( w对每层数据都校验,有个应用的地方就是中间层和数据层的复用。从复用的角度来说,如果中间层有校验,那么在写表现层时排查错误,处理异常就会相对比较方便。不过我遇到的这种场景情况很少。# C$ z4 o; [2 o

    ! P% e2 r0 e: ~" U) z一般的应用我觉得数据库的内生校验加上表现层的校验,应该基本上足够了。程序能卖钱是因为程序能WORK,而不是因为检测的代码写得多。* B4 F5 ^) z- C
    - q/ A" h$ ~" @2 J" C$ H6 m

    5 _( U, E4 c% l7 M) a- J
    # r4 h: g6 R! p# E: t3 _/ c. J, {; `7 X7 \. P5 f
  • TA的每日心情

    2025-8-7 11:56
  • 签到天数: 1132 天

    [LV.10]大乘

    16#
    发表于 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]出窍

    17#
    发表于 2011-9-28 12:56:28 | 只看该作者
    。。。6 W: u5 t$ a6 s; i9 `# Q6 {
    我是来重在参乎的! R+ _8 N$ J8 s# i
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

    18#
     楼主| 发表于 2011-9-28 17:13:09 | 只看该作者
    本帖最后由 老兵帅客 于 2011-9-28 04:13 编辑
    $ n6 u- a5 ?6 _- }! G
    四处张望 发表于 2011-9-27 22:32 - ~* V6 v8 @# |( H5 H( O# c
    esb那个如果不是全是自己搞,不好这么算,用效率和实效的角度考虑防止扯皮是想不透的。
    2 A3 ^* a7 f2 z; Y# Y, H7 K第一个问题其实也是 ...
    1 h  b: K  ~2 F8 a

    1 D1 T5 \3 D) P( E- v3 pesb那个全是自己搞的,而且预先知道就放在自己的内部机器上。" s9 c: F, v4 x; _8 H: g& l
    7 p7 F1 O, F0 ^9 K' R
  • TA的每日心情
    开心
    2023-1-5 00:48
  • 签到天数: 2591 天

    [LV.Master]无

    19#
     楼主| 发表于 2011-9-28 17:18:13 | 只看该作者
    空气精灵 发表于 2011-9-27 22:50   U7 m, m# F0 q& r0 p) d1 D
    个人认为, 每一层的检验是必要的,但是,重点应该在于本层所生成的数据,而不是检查前一层送来的数据.
    % _# c9 e$ c( r, E6 u: [' T也就是 ...

    ) Y2 f3 s: x* S; ?# j3 n- }4 S嘿嘿,你说的是检测自身的数据而不是前层传递来的数据,这是design by contract的概念,也就是pre-condition。我文中所说的是每一层都重复检测前层的数据,这就是另外一种思路了,没有pre-condition而是边界之外是险恶的世界。

    点评

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

    [LV.Master]无

    20#
     楼主| 发表于 2011-9-28 17:21:53 | 只看该作者
    mark 发表于 2011-9-27 23:09 7 l: v- }' _6 x& U( g- Q
    老兵说得很有道理的。不过这个还是要看放在什么应用环境下。
    ( a9 d% B& W. _
    $ k* r2 k5 \: m* C0 J8 D! c- W1 [. H. `对每层数据都校验,有个应用的地方就是中间层 ...
    & U8 ?. h" Z2 U/ a+ d& K% ^
    我的想法是每层有各自的任务,重复检测没有意义。

    点评

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

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

    GMT+8, 2026-1-7 10:01 , Processed in 0.051202 second(s), 18 queries , Gzip On.

    Powered by Discuz! X3.2

    © 2001-2013 Comsenz Inc.

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