|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
& n4 f2 y+ O' N9 S z& W
" k' ?+ x( ^4 D* {' X当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
7 p. Z6 \1 R; U* `" L以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);7 N8 k, w' b8 P1 t
- return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。7 H% N) Z( `1 r" S
" S/ f8 l) h: y& v延伸思考:
" r" D- t9 z2 a( o8 f+ i P7 r如果return 0;,表示什么意思?第一个可用端口。3 f) f" Y% j+ ?
如果return -1呢?不发送。
( m# M. O& P* f5 H. [9 y! y如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。
3 N F+ n0 E5 B; ^; z5 H5 i3 b* _1 c# G' o
) K) U, t* a; W' N+ O! h
但分拣传送带的输出端口分配机制有些不同。
; E9 u# U1 u6 x# @分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;
+ x! t+ e. h& Y/ y
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?3 U; E0 |/ f- W
return 0不发送! Z! o$ H9 m. _9 Y- Q
return 1发送到第一个可用端口,如果没有可用端口则不发送。
4 j0 H. F1 {& B0 Z. \, z- C* lreturn 2,return 3...return 100000,同return 1; l. p9 [* l$ |9 c! N0 o1 m2 l
return -1,同return12 p7 I, Q0 G5 ]0 U6 U
3 J e5 y) x* S# `8 J0 t
也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。' X5 B1 ^( F$ a
那么,如何确定发送至哪一个端口呢?
1 V% Q- P7 V: m7 O: Q3 n临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。+ O* v4 [% F8 @* [) ~; G; R! k$ D
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。( Z4 a5 ]8 X3 l! V$ i' |: |
如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。
0 y1 U: s2 |* E& c# a# Z" G1 e如果全部端口都不相符,则不发送。0 T5 |7 \6 H% F3 _- ^
, Z$ V3 h+ L" y6 v如果仍然由临时实体的类型决定的话,应该用以下代码实现:- 6 D3 D. N9 M. t8 y5 t V' E& B
- return (getitemtype(item)==port);5 ]8 J9 f w4 T# A) t+ X2 x5 f
复制代码 上述代码比较临时实体的类型和端口号,& [" Q: Q+ U) p$ n; z. \$ w9 {2 D& {
如果两者相符,则返回TURE,发送,; e- M; R' v1 x2 I5 T9 l1 A8 @& J- r r8 I! o
如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。
* ^* W E- s$ f! p1 K" m1 E! e8 Q3 |% @
至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|