|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑 : [6 M: G5 Y( V6 R
$ _: S' V0 T9 P0 J2 O当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
( I. x$ f) z% Z9 T; b5 p* i6 V以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);( x; q4 L2 l4 j3 s3 F/ F/ Y. a
- return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。- u% q* y" r7 o4 t+ @, \/ E% Z+ R) D
/ j' M$ u; ~8 V- W; q8 S
延伸思考:
1 h2 O; V/ W7 O' B8 |如果return 0;,表示什么意思?第一个可用端口。$ }/ d, J0 C! n5 z$ |
如果return -1呢?不发送。, X2 i5 T9 e6 e5 L& o
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。
, T, G! Q4 s* {3 V" e% z7 Y* \; {1 _) L" C
E) R3 y3 V9 i7 B4 H但分拣传送带的输出端口分配机制有些不同。7 f( n& U b/ I" K& m, b
分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;5 T0 t$ t6 b7 o: M. t4 l
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?
% T2 Q6 E2 m0 w; c9 y9 E" ^5 n( h- Sreturn 0不发送
" k; y$ T3 B- }& _/ p4 b/ x' ]% r' Wreturn 1发送到第一个可用端口,如果没有可用端口则不发送。/ G7 [9 f" y. Y% G" V
return 2,return 3...return 100000,同return 1, J2 [) Z% P' X- _ W% h1 Q3 C
return -1,同return1
6 @! n" d( R- T/ W6 u, z' G3 ~- S r- p# i2 }
也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。* u5 @' e5 I$ o& w# Q4 f
那么,如何确定发送至哪一个端口呢?
2 P2 H0 t0 G5 ~6 X0 E临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。
5 T6 O8 ~2 l7 c; U2 s' g如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。
: S6 X% Q& p% e t# g: Q如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。+ D o* c+ C% T( J
如果全部端口都不相符,则不发送。
) F% w: g) ~9 j3 q5 t1 O7 U) {# k5 R" I. i
如果仍然由临时实体的类型决定的话,应该用以下代码实现:
* [3 o8 R6 ^- j3 J6 C1 w& M9 u6 |& V; L- return (getitemtype(item)==port);; C/ P! V/ H; B0 u( p# V* V% |
复制代码 上述代码比较临时实体的类型和端口号,# j; e: X$ z0 y" e; l8 L$ P$ C8 a
如果两者相符,则返回TURE,发送,
Z/ }. D; l2 y9 W ]0 J/ ?如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。
: c& B# ^" U9 D9 f
' j) |; R) Z! d% ]至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|