|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
" l9 N' \- t0 |/ g* [& J" w; P* T/ A4 a3 {2 Q; ^
当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
7 z$ }4 a8 K! N* X. W/ w以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);+ p, l6 Y4 a; ]$ R0 } z: b
- return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
0 A+ j9 d" v D8 |! A) o! P6 q4 F6 y& G) I1 S% T
延伸思考:& W0 u- I1 S; y1 z5 J
如果return 0;,表示什么意思?第一个可用端口。
. G/ p2 n% l0 ]) B, f4 }1 Q" F如果return -1呢?不发送。
. p' {* }2 F5 ?& h如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。" ]. p+ b4 M; c+ C! i
8 u5 V& H" x, s! @1 F9 \- X
- r) u( a4 N' z; |4 @/ Z+ s但分拣传送带的输出端口分配机制有些不同。
* g( P! M1 m2 t分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:把return 1改为return 2、return 3、return 0、return -1会是什么情况?0 O% Z- L* u% |
return 0不发送
7 a2 [, j e h; ^4 ^return 1发送到第一个可用端口,如果没有可用端口则不发送。
3 _. E4 l$ b2 ]. e, C* Lreturn 2,return 3...return 100000,同return 1; j3 H# D( F: c$ Z2 K% L; j+ o, L) q* X/ s
return -1,同return19 i. y- b5 L* y* [
; J' @- t& t$ H
也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。
O x8 F' L. v7 U, j那么,如何确定发送至哪一个端口呢?
1 X& B I/ C6 [临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。. D4 v) y" x+ z) F* D! C
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。7 w, y" N# ?& |# e* K
如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。
! X9 X8 X x1 d# H/ X' l, P1 v如果全部端口都不相符,则不发送。
9 D" S1 q; h2 L! S! E4 R
: c- H% E7 H8 t& u) Q如果仍然由临时实体的类型决定的话,应该用以下代码实现:- % l0 n7 x9 G9 B/ Y U8 a3 _# o
- return (getitemtype(item)==port); |( T8 ^. q5 d0 v- C
复制代码 上述代码比较临时实体的类型和端口号,
- C& U, b0 ~9 I; @; }如果两者相符,则返回TURE,发送,
8 ^8 u8 y2 `+ ~% v2 Q如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。' ~/ H$ E5 ` O. d. ?" i: @
. M5 P5 f ]: n- B. V; v至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|