|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑 c: q% G3 a' _, D+ d
/ J7 ]) L/ D& d( w( ^+ E) U当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
2 e. Q# ^+ R% C1 H以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);- N0 G9 f- R2 [8 p
- return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。. P' N* g8 M6 L; X
$ M l- D I3 A# L/ p; ]$ G延伸思考:7 S# x* h# ^0 \2 E$ j
如果return 0;,表示什么意思?第一个可用端口。$ y. L$ C0 b8 {1 Q5 s9 P
如果return -1呢?不发送。/ ]6 l: ^& Z1 x& |1 v7 r' f
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。$ N* K# @( ~1 @5 [ j
% T% P- |$ `; [0 D; {, C6 q/ M
$ T8 V1 c' P- \7 j4 m但分拣传送带的输出端口分配机制有些不同。$ Q2 j' a: k/ n& [: F* ]" T% }
分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;
5 K& Q' a' s* Y, U' E) C: P V2 G
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?
6 ~. x( y& r# t; ?return 0不发送4 L9 T- b ^8 }/ s- V3 D' x- j i
return 1发送到第一个可用端口,如果没有可用端口则不发送。
x& F5 A- p. b F9 Sreturn 2,return 3...return 100000,同return 1
4 k: Z. ?. c8 L2 Yreturn -1,同return1
# A3 e7 {9 ]* d9 {0 T: R7 i- q3 |$ m8 W V/ ?3 l2 x0 B5 D. @
也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。
; I% h" g, O& W$ T) ?那么,如何确定发送至哪一个端口呢?
6 c# w8 w0 X/ y3 m临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。' z( q; {' p- |) |4 j9 v' L* h
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。' v3 I7 J1 t/ |
如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。 i( B* X/ g5 N
如果全部端口都不相符,则不发送。
2 v+ l- g4 u2 t; _7 K. W8 B4 k3 i! E* ?& Y5 ?7 M
如果仍然由临时实体的类型决定的话,应该用以下代码实现:- : I4 M! D% \ E, ~% Q" V1 }
- return (getitemtype(item)==port);
2 y. I8 A5 g+ j5 W4 k! ?# Q
复制代码 上述代码比较临时实体的类型和端口号,
$ Y* ~' r! m! ]! ^如果两者相符,则返回TURE,发送,9 Z' N& p/ C1 H: f9 D" V
如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。: r# N3 D+ F" N" F1 ]
6 u* g2 e; u- p; s至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|