爱吱声

标题: Best Practice [打印本页]

作者: 老兵帅客    时间: 2011-9-27 22:11
标题: Best Practice
这里干软件开发,经常会遇到迷信Best Practice的家伙,一说起来什么都要遵循这个,否则就要不依不饶跟你扯,实在是烦人啊。
/ S5 G8 j9 D  K6 b3 c: k5 \: x' K8 Z" ~6 i" Z
举个例子,一个web应用,给分成了presentation layer, business layer, data access layer等等。这个分法倒是很合理,问题是人家认为数据的校验也是每层都要做的,理由是各层都有可能被替换,你如果不做如何保证数据是符合要求的?很对,但是实践中就有很多问题不好办了,问题出在了测试上。
8 A' M& ^4 Z% r* C$ d% [9 l1 Z4 @9 W) J5 }/ d
具体说来是这样的,presentation layer包括浏览器部分和服务器的对应接口部分,前者的校验用javascript而后者用java,这就是两层测试了,再加上business layer的那层,起码就是三层了。这三层测试所做的工作,或者说所依据的规则一般是一样的,因为就是一个java bean在那里传输数据嘛。可是问题是如果第一层已经做的完善了,第二层又怎么可能检测出问题来呢,因为可能的错误已经都在第一层被发现了嘛,于是为了让第二层检测能够工作,你必须关掉第一层检测,这意味着修改代码,而任何修改都意味着可能带来新的bug,这个怎么检测?第二层和第三层之间的问题跟前面是一样的,也就是你必须关掉第二层的检测来让第三层的检测有机会干活,这里同样存在前述的可能带来新的bug问题,同时这三层检测在交付以后需要同时存在重复检测,这开销怎么算?
& F3 s- O# T5 f9 q) {/ N! @& y; K' K! k" ~5 s$ C5 e- C
有人可能会说,那是必要的代价,因为各层都有可能被替换,因此各层自己的检测是必不可少的。理论上这话完全对,可是现实中几乎不存在替换的可能,因为那意味着整体结构的大修改,即使出现这样的情况,交付以后的其他各层检测还是没机会干活的。于是一个看起来完美的方案,现实中只是在浪费资源而已,因为同样的数据要被检测三次,而只有第一次有可能被检测出问题来,后面那两个都是白忙乎。
6 Y5 C* Y) G' G% f  {9 F5 z6 X4 I0 S* V, m: x2 i
这方面的另外一个例子就是ESB领域,这个领域的用户普遍都是些大用户,具体实践就是一大堆的web service在那里以workflow的方式运行,这点没问题,问题是每个web service的设置都有着全套的安全规范,例如双向SSL和WS-SECURITY之类的,哪怕是这堆web service都运行在同一台逻辑机器上也一样,于是就是大量的开销却没换来任何安全上改进。
作者: 小绿爷    时间: 2011-9-27 22:17
隔行如隔山,对我而言基本看不懂
作者: 老兵帅客    时间: 2011-9-27 22:43
小绿爷 发表于 2011-9-27 09:17
7 S8 N* D# J1 X& {6 f4 L隔行如隔山,对我而言基本看不懂
1 ^# ^! j+ E: f: q. G" J
没关系,重在参与嘛
作者: 旅途愉快    时间: 2011-9-27 23:32
同意一楼意见。。。
$ A5 j) o; M4 D1 R囧,什么都没看懂。。哈哈
作者: 老兵帅客    时间: 2011-9-27 23:33
旅途愉快 发表于 2011-9-27 10:32   `7 {- {$ b" T: u0 b- ], o" I
同意一楼意见。。。
" @  t0 }1 S7 H$ l$ I囧,什么都没看懂。。哈哈
& C# ^. L8 q& _' R# S
又是一个重在参与地
作者: tonyxu    时间: 2011-9-27 23:49
我家倒是有本书,Thinking in JAVA,是LD的,不过她现在在搞ORACLE。。。
作者: 老兵帅客    时间: 2011-9-27 23:51
tonyxu 发表于 2011-9-27 10:49
0 o2 K5 Y' @$ J2 [* V; f" {我家倒是有本书,Thinking in JAVA,是LD的,不过她现在在搞ORACLE。。。
8 h' n& ]! Q/ @; o( t
还是个重在参与地
作者: tonyxu    时间: 2011-9-27 23:53
老兵帅客 发表于 2011-9-27 23:51 $ F7 p* J7 q/ N3 t. a
还是个重在参与地

& }+ Y# Z* Z' r( Q1 nabsolutely...
作者: 飞翔的芦苇    时间: 2011-9-27 23:54
不懂,坐等懂的人来谈。
作者: 老兵帅客    时间: 2011-9-28 00:00
飞翔的芦苇 发表于 2011-9-27 10:54 * Q0 w9 c; W( t2 s5 y( {7 X
不懂,坐等懂的人来谈。
7 ?& N- L  B4 U6 F: G7 d
怎么就剩下重在参与的了,干这行的都哪里去了?
作者: fareast    时间: 2011-9-28 07:11
软件中检测部门大部分都是女性吧,华为的软件研发我很清楚,全球采购便宜的,再加上核心数据集成。
作者: 老兵帅客    时间: 2011-9-28 07:58
fareast 发表于 2011-9-27 18:11 , o/ R2 H; H# i* L# R5 r
软件中检测部门大部分都是女性吧,华为的软件研发我很清楚,全球采购便宜的,再加上核心数据集成。 ...
5 A9 ]& @& @; D* m& E* Y. P
你说的是做QA的,我说的是软件开发过程中写的检测程序,两回事。
作者: 四处张望    时间: 2011-9-28 11:32
esb那个如果不是全是自己搞,不好这么算,用效率和实效的角度考虑防止扯皮是想不透的。
) d- o' O) u" V第一个问题其实也是两说,就是不知道这么提倡的家伙是从哪个角度考虑了。
作者: 空气精灵    时间: 2011-9-28 11:50
个人认为, 每一层的检验是必要的,但是,重点应该在于本层所生成的数据,而不是检查前一层送来的数据.
/ V) b! \8 {4 T! R也就是说,需要假设,前一layer/flow送来的数据都是准确的.: p/ x3 G% H9 ~3 F1 X; \
当然,必要的入口参数exception还是需要设一下的.如果真的发生了exception,那么可以推论是前一layer/flow出错了,让前一层自己去查吧.
作者: mark    时间: 2011-9-28 12:09
老兵说得很有道理的。不过这个还是要看放在什么应用环境下。4 h3 ~, O" k: _
6 x* B% @/ ~2 V/ p' h! l
对每层数据都校验,有个应用的地方就是中间层和数据层的复用。从复用的角度来说,如果中间层有校验,那么在写表现层时排查错误,处理异常就会相对比较方便。不过我遇到的这种场景情况很少。
; n2 z+ ]2 S+ e/ c* A" o3 n2 w8 Y
6 D0 p4 n6 o: D! S/ Y! q一般的应用我觉得数据库的内生校验加上表现层的校验,应该基本上足够了。程序能卖钱是因为程序能WORK,而不是因为检测的代码写得多。
: |  Y# E  C( J5 A6 {# i( ~* ?5 c0 p7 R2 D2 N  `. g- ?) z
/ G  U6 m" G; z# M6 ^

) A# L! m$ k4 B8 J1 H3 G% M  d% `0 q
- ^8 Z1 T& T# W: Z0 z" z& I% D
作者: 大黑蚊子    时间: 2011-9-28 12:46
前Cobol程序员飘过~
作者: 明月回春    时间: 2011-9-28 12:56
。。。: ^# D) f3 W8 u
我是来重在参乎的
- [% v% g- `+ P/ h/ l- ]4 u
作者: 老兵帅客    时间: 2011-9-28 17:13
本帖最后由 老兵帅客 于 2011-9-28 04:13 编辑
) p' P( Y. ?! }7 G/ m
四处张望 发表于 2011-9-27 22:32
% I2 N4 D2 L  K" a5 Q# Fesb那个如果不是全是自己搞,不好这么算,用效率和实效的角度考虑防止扯皮是想不透的。9 y. {; M8 x& R  ]% k
第一个问题其实也是 ...
8 i8 h; o, t# V$ X1 V! I% g

4 H6 o+ _5 s" s! `esb那个全是自己搞的,而且预先知道就放在自己的内部机器上。
8 l) h* Y4 j: G. P' J- n
1 t0 h* G9 x* ?! }* u8 ?& G
作者: 老兵帅客    时间: 2011-9-28 17:18
空气精灵 发表于 2011-9-27 22:50 " y) Q" v0 b$ s' K9 T
个人认为, 每一层的检验是必要的,但是,重点应该在于本层所生成的数据,而不是检查前一层送来的数据." B0 N: ~- p- P: b  C( f
也就是 ...
- O1 P$ C9 }! X  u, Q/ i  U  M
嘿嘿,你说的是检测自身的数据而不是前层传递来的数据,这是design by contract的概念,也就是pre-condition。我文中所说的是每一层都重复检测前层的数据,这就是另外一种思路了,没有pre-condition而是边界之外是险恶的世界。
作者: 老兵帅客    时间: 2011-9-28 17:21
mark 发表于 2011-9-27 23:09
: d. F7 _0 A( S4 G0 k1 }老兵说得很有道理的。不过这个还是要看放在什么应用环境下。' H0 P/ D5 e9 _3 L+ R
6 D0 o# b  ]/ F! s$ A8 ?
对每层数据都校验,有个应用的地方就是中间层 ...
: s" M0 C. ?4 _: E* M
我的想法是每层有各自的任务,重复检测没有意义。
作者: 胖子    时间: 2011-9-28 17:33
老兵提到的问题,是不是有一个前提:各层校验的对象是一致的?既从逻辑上来说,数据在各层次间流动时,不发生改变。( c8 a3 m; U, W* D0 @; L
7 Z3 o' W: e& ^: O# N) h
如果是这样的话,倒确实不用每层都校验。而应把关注点放在数据传递安全上,也就是防篡改。( s+ z% ?6 C) D+ ~% P8 [& M# K+ D
- N: A6 p! X7 s
如果数据流动过程中会变动,那我同意空气精灵的观点。
作者: 四处张望    时间: 2011-9-28 17:41
老兵帅客 发表于 2011-9-28 17:13
3 B7 Q8 V) x1 O0 c% Resb那个全是自己搞的,而且预先知道就放在自己的内部机器上。
+ k) Y; ?  W" D$ `8 D5 j- `
理解不能,除非ssl这类都是缺省实现,懒得去掉,否则多个ssl多讨厌。
作者: 老兵帅客    时间: 2011-9-28 19:01
胖子 发表于 2011-9-28 04:33
% W, B: m% K* k% F老兵提到的问题,是不是有一个前提:各层校验的对象是一致的?既从逻辑上来说,数据在各层次间流动时,不发 ...

  v) g) J9 ~8 x" Y2 z各层的校验数据是一样的,就是从表示层那里得到的同一个java bean,内容不变。同时因为这是个在同一个java ee server下面运行的web app,不存在数据在中间遭到篡改的可能。
作者: 老兵帅客    时间: 2011-9-28 19:02
四处张望 发表于 2011-9-28 04:41
5 K4 M# G; r# H$ U理解不能,除非ssl这类都是缺省实现,懒得去掉,否则多个ssl多讨厌。

* [* b5 B0 W1 Q不是的,ssl设置都是要单独做的,而且还是双向ssl,也就是双方互相验证再建立ssl。
作者: 四处张望    时间: 2011-9-29 09:52
老兵帅客 发表于 2011-9-28 19:02
1 w( p- Y& V( P% k( G不是的,ssl设置都是要单独做的,而且还是双向ssl,也就是双方互相验证再建立ssl。 ...
% M) j/ w2 U" J+ d% A  x% K6 H
这个不就是等于保险箱里面再加吧锁吗,追求小数点后面的几个0呢?
作者: 老兵帅客    时间: 2011-9-29 09:59
四处张望 发表于 2011-9-28 20:52 4 ?8 \  ]8 T+ F+ X* F2 Y" z
这个不就是等于保险箱里面再加吧锁吗,追求小数点后面的几个0呢?

2 _( e6 ]  p% H没办法,安全这个领域太敏感了,多些安全总比少些强
作者: 四处张望    时间: 2011-9-29 10:14
老兵帅客 发表于 2011-9-29 09:59
/ j. Z. K1 U2 A没办法,安全这个领域太敏感了,多些安全总比少些强

9 T! d; [, [0 V3 S: A不过计算性能开始不值钱了,多点安全拖累性能无所谓,不要多人工就好。
作者: 猫元帅    时间: 2011-9-30 08:47
专业词汇一个不懂,但是意思大概明白了。% A5 q- }9 D  s. J; B0 Q- J

2 A9 ~4 W. b2 |5 o$ U8 j就是帅克同志认为在1-2-3递进的情况下,2和3不会发生超出1的BUG。所以只要1做得完善,检测1就足够了,用同样的方法检测2和3是一种浪费。不能为了检测而人为改变1的设置,因为1-2-3是递进的关系。
, f0 M: x8 {: w% n/ t/ A) W% o
0 f+ u  g" n" N$ j+ `简单说就是不能为了检测而检测。
作者: 老兵帅客    时间: 2011-9-30 09:16
猫元帅 发表于 2011-9-29 19:47
7 j& \: G' ?, d1 i" m$ B" L专业词汇一个不懂,但是意思大概明白了。3 M) N+ I8 f+ b5 y

$ `+ _1 I7 \+ K# Q* c就是帅克同志认为在1-2-3递进的情况下,2和3不会发生超出1的BU ...
4 a4 ?7 Z$ B/ k3 ^; d$ P  Y( j+ Z
对,不应该做多余的事情
作者: ImaNut    时间: 2011-9-30 21:46
小绿爷 发表于 2011-9-27 22:17 ! e4 K5 l3 ^8 ]; p% n- B
隔行如隔山,对我而言基本看不懂

" E" m8 \; a1 n9 J0 y就好比一座办公楼,大门口一把门的,电梯一守卫,你办公室门口又是一位,连厕所那儿也摆一位,进出都查ID。理由是有人能钻窗户进来。
作者: 老兵帅客    时间: 2011-9-30 22:40
ImaNut 发表于 2011-9-30 08:46 - [- n% f/ U' i
就好比一座办公楼,大门口一把门的,电梯一守卫,你办公室门口又是一位,连厕所那儿也摆一位,进出都查ID ...
. ?" [9 j! A- a/ w" I. I6 f1 x1 c
问题是这大楼根本没窗户也要这么干,那就是多此一举了。
作者: 牌牌    时间: 2011-10-1 17:01
作为一个前C++程序员表示理解起来压力不大。
/ m0 j& Q& C" a. d现在的软件工程为了提高代码的重用性和可靠性,要求各个代码模块对所有的输入都进行合法性检查以保证业务逻辑的正确运行,所以CPU内存增长的再快,也不扛不住做总是在做无用功的软件啊。
作者: 老兵帅客    时间: 2011-10-1 20:29
牌牌 发表于 2011-10-1 04:01
* H0 |9 _6 M* b- u/ _! f4 t) ~作为一个前C++程序员表示理解起来压力不大。
. w9 i6 ~! o: G% J% C现在的软件工程为了提高代码的重用性和可靠性,要求各个代码模 ...

) A/ h/ J( I2 i& n3 k, f' q的确如此。
作者: ekid    时间: 2011-10-1 21:10
怎么软件也像协议分层吗?
作者: sky100    时间: 2011-10-1 23:55
看你怎么看这个问题了。现代的软件工程都是多人甚至多团队合作型,万一其中的一个模块外包到印度去,那边的开发人员乱写一气,污染了数据,然后下一级别的模块没有做数据效验怎么办?现实世界中总是有各种意外的。当时觉得没必要的事情,过几年之后可能会觉得是重要的。5 g! t! ]" `; q
/ I- L6 ~: J9 T$ d0 H  ]# V% z& P
从架构设计的角度来说,这样做对于扩展性很有好处。比如,现在你只用一台机器跑所有的web service.可是明天用户忽然增多,一台机器撑不住了,必须多台机器集群作战。这时这样做的好处就出来了,软件层面基本上不用作修改就可以分布到多台机器上用。如果象你想的那样内部通讯不需要安全验证,那么扩展起来还需要重新作安全验证,这样又会从另一个方面来增加工作量。是机器便宜还是开发人员的工资便宜呢?Really depends.5 U9 Z1 t; Q9 A8 b9 y6 |

9 [) d8 C. f+ e很多时候设计决策本身就是一个trade off.
) d& t! f  R# P& h! o
" d* `" a  g: w  N* j# |9 S' n) P$ M' m8 @" H) w9 V

作者: 老兵帅客    时间: 2011-10-2 04:13
ekid 发表于 2011-10-1 08:10
6 D& q2 W1 o# k: o  d怎么软件也像协议分层吗?
% I$ p5 @5 Q& ?+ z
是啊,一直都是这样做的
作者: 老兵帅客    时间: 2011-10-2 04:15
sky100 发表于 2011-10-1 10:55
& ~5 q1 D3 Z7 u  |4 X看你怎么看这个问题了。现代的软件工程都是多人甚至多团队合作型,万一其中的一个模块外包到印度去,那边的 ...
6 A7 U) @+ |2 _, T
第一。测试是干什么的?+ K2 U, d0 c6 ~, M% T! L
9 ?- m, p6 n  @! D1 r6 @% b
第二。如果那堆web service根本不可能被deploy到外网呢?+ ^8 F5 d; u% J, l9 _

, D( a9 p* t& O我明白你的意思,但是这个trade off理论上很合理,现实中则根本没有得益的时候,而成本却肯定在那里。
作者: 一瞬无尽    时间: 2011-10-2 17:53
这种每层都验证数据的做法我觉得没错
/ y( ]7 v3 ~  S( @测试的做法我觉得似乎可以改进:通过修改下层的实际代码进行测试,这似乎过分了些
/ n: j6 A& f' f: {: A我不了解实际情况,觉得似乎可以干脆另写测试代码,模拟下层专门发送错误数据给上层,不然每次测试都修改生产代码,太麻烦太浪费了: B2 U% `' w# r

' n3 z3 W0 m( @我如果是上层写代码的,宁愿自己写这个测试也说不定,当然能安排给下层是最好了
作者: 老兵帅客    时间: 2011-10-2 18:56
一瞬无尽 发表于 2011-10-2 04:53 % e+ B5 f* p5 p! u' a& g9 ~
这种每层都验证数据的做法我觉得没错
0 W7 k$ [7 a0 L) B( w- J测试的做法我觉得似乎可以改进:通过修改下层的实际代码进行测试,这 ...
6 S: L; q$ u0 a
Good, you do that
作者: 老兵帅客    时间: 2011-10-2 20:51
一瞬无尽 发表于 2011-10-2 04:53 " q* Q+ V" P* u/ V7 W) V! s# o! S
这种每层都验证数据的做法我觉得没错
6 M0 Q( `5 U/ h* o7 s6 M' X- m测试的做法我觉得似乎可以改进:通过修改下层的实际代码进行测试,这 ...

7 h; Z# d2 V. r# H4 o: n* T其实说起来,这个就看怎么做了,做得好的话是可以灵活配置的,也就是需要的话enable检测代码,否则disable掉就是。具体说来就是利用framework的能力,例如struts2的interceptor,可以做出几乎不带来额外开销而非常实用的检测程序来。
作者: sky100    时间: 2011-10-3 05:34
本帖最后由 sky100 于 2011-10-3 05:46 编辑
" H1 U, G4 L; `3 K' C7 J
老兵帅客 发表于 2011-10-2 04:15
9 {8 ]; G5 g0 z3 [# o第一。测试是干什么的?
+ p; ^! t8 U7 G/ X
1 T. W- c! N- `+ L  V第二。如果那堆web service根本不可能被deploy到外网呢?

  M! p( t4 l: X5 Z
( u* Z: _, y- v7 I% G第一,绝大多数测试不可能覆盖所有的可能性。如果代码测试后放到生产环境中,结果因为某个特殊的情况,数据效验没有做而导致出了问题。应该是没有听从架构师要求去添加效验的开发人员的错,还是测试人员的错呢?
6 ]7 W% o# f; m! A8 o# P9 G
, Z8 b" |  t* R. R第二,我的看法是,除非公司的ceo拍胸脯给打保票,否则你never know.商业需求总是在不断变化的。从架构设计的角度,假设你是架构师,你是宁肯多加些冗余来保证系统的鲁棒性和可扩展性呢?还是为了减少开发人员的
3 R- o. \: w& h7 i. P( c工作量并给人力资源部制造裁员的借口而不重复校验呢?# Z" i4 c2 D- F

" O# L, }# |  e9 ~4 i- V$ ]6 W3 G老兵兄,你所提到的事情设计者未必没有想到,只不过他可能得到的信息和考虑的可能性要比你多,权衡之下采取的这个决策。而有些信息和可能性不适合公开讨论而已。换句话说,很多问题之所以不可以使用简单直接的方案是因为这个问题不仅仅是技术问题而且也是一个政治问题:)
" s) B: l9 @8 f' t) g
8 O( `, I) e5 Z0 C我个人的一点陋见,搏大家一笑,请轻拍:)3 t6 O  q, U9 y
$ Z9 E' `- Q( T9 m/ C) Y
7 e1 {6 A& T$ `$ ^/ Z" w

/ a7 n2 K8 \- d
: \/ `% K  G: b% r
' _# S; _/ _: h( |5 u) D2 l6 A6 F$ V' Z1 Q! W: ^

作者: 老兵帅客    时间: 2011-10-3 05:40
sky100 发表于 2011-10-2 16:34
4 K7 w: j8 ]" {) x9 ^% F第一,绝大多数测试不可能覆盖所有的可能性。如果代码测试后放到生产环境中,结果因为某个特殊的情况,数 ...

1 E: ]$ e. z& B  i! l- Q说了这么多,其实很简单,决策者在逃避责任而不是保证质量与效率。因为重复的检测不会提高质量而却会增加开销和降低性能,但是在出了问题推诿的时候,那就是个优点了,因此这不是技术人而是政客考虑的事情。: z+ b' g" v" f4 ?0 h

  `# p# m: L# ^. y4 n4 L$ L: a. H这里的关键在于你所说的那些可能性在现实中几乎不可能出现,而成本却是必然而无法减免的,这样有成本而无收益的把戏除了出于政治需要谁会喜欢?; V" X, m$ Q. |) e" z4 W
. q7 c! L. Q+ `# s' |$ l  A. k0 I
再多就变成政治扯淡了,到此为止吧。
作者: wolfsquare    时间: 2011-10-3 08:46
看来楼主并不明白什么叫最佳实践
作者: sharepoint    时间: 2011-10-3 14:11
其实,说到底就是一个权衡的问题% H2 |6 i( P+ n; z* E# M
1:如果一个系统重要到影响到公司的生死存亡,面面俱到,行万全之道不算为过' Y# Y  d* N& L' b: ^6 |
2:如果预算允许,多做一点检查也不错/ n: w( [0 E2 Y2 H0 N, O
3:如果用户需求没有要求,架构师加冗余来保证系统的鲁棒性和可扩展性,就有点画蛇添足。
  B" j: B( `+ M4:Best Practice和Guideline,SOP还是有差别的。
% C" c$ d5 @+ m* M& [1 e5:很多情况,不是技术决策,而是管理决策。
作者: 老兵帅客    时间: 2011-10-3 19:57
sharepoint 发表于 2011-10-3 01:11
1 y$ z/ L% U" U8 y! I其实,说到底就是一个权衡的问题
0 }; O$ L$ S( K1:如果一个系统重要到影响到公司的生死存亡,面面俱到,行万全之道不算为 ...

& j( J, W# J0 Z. }right, right
作者: 老兵帅客    时间: 2011-10-5 06:22
说一下我为什么写这篇东西吧。4 P/ a, \$ t. w; z/ }

% b3 X! H% a# G  }: ]# C各位的回复我都看了,道理上完全对,但是现实中就不一定了,为什么,听我说哈。
& E% Z5 a& ^! ~) U  p
! a8 T1 @+ V- F2 j: e9 R我现在的项目组,来了位高人,动辄Best Practice,一套一套地,什么framework跟什么类库搭配,都说得很清楚。只有一个问题,大家都知道那些东西不能搁在一起滴,否则会有版本不兼容问题,而公司又不允许未经充分测试的修改版投入使用,于是真要用的话就只能是一塌糊涂喽,而这位不知道,还在那里狂侃。可是老板还信他,要求大家听他的,于是大家就难受吧,因为根本就配不通,更不用说具体去用了。
+ @8 W( m) A3 a! ^% [# C+ Q8 v. {  w' Z
我们这里有一位狠主在给他挖坑,我们看着,谁也不说话,就等着开壶那天看热闹。
! Z6 K/ }' C/ y5 D
& D6 o, e3 f+ m" F当然了,这位高人叫嚣的可不是我上面写的那点东西,充分的模块测试、重复的安全设置对他来说太小儿科了,显不出他的水平。那么干的都是些庸人,人家根本看不上滴,人家要干就干大的,或者一家伙把自己臭大街完事。
作者: mark    时间: 2011-10-5 16:44
老兵帅客 发表于 2011-10-5 06:22 . e2 c' u2 G! Z
说一下我为什么写这篇东西吧。' P8 F$ h0 M6 ?/ h8 G7 ~

4 ]" Y+ v4 p2 Q8 ?! f# c各位的回复我都看了,道理上完全对,但是现实中就不一定了,为什么,听我说 ...
7 L& {( p" \9 {# [* s" U% O
最恨这些纸上谈兵的家伙。8 m) f4 B7 D5 k; q% a7 S, q

. [/ l% I  R! l' S' q% {我原来公司有两个家伙忽悠老板引入RATIONAL ROSE做项目,把大家搞得苦不堪言。最后项目没做好,那两个家伙倒是长了经验值,直接跳槽走人。
作者: Radiohead    时间: 2011-10-5 23:40
老兵帅客 发表于 2011-9-28 17:21 5 R7 q4 [2 p4 }+ v0 c
我的想法是每层有各自的任务,重复检测没有意义。

  [% M3 U1 j! D+ c1 Z0 k认同。 讨厌重复的代码,讨厌重复的逻辑。UI层尽量少的biz logic。




欢迎光临 爱吱声 (http://129.226.69.186/bbs/) Powered by Discuz! X3.2