|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑 ) c0 d. C" q& e5 |5 _8 P3 T+ i$ |1 @
- }. f" m; D8 R0 H. m当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
; m* j+ ]$ ~' E以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);7 w! f% E" O9 M8 B1 p) [
- return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。1 s I# e6 o8 V9 n3 r* a1 U( c
+ E4 X! {& B# H$ N f" @ f) K
延伸思考:
& C( S7 v) _3 U+ b7 ]如果return 0;,表示什么意思?第一个可用端口。
- e0 U- L9 o" K w+ S4 A9 i如果return -1呢?不发送。! r( V; q b; Z& ?* D( R
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。( K- w' G* X k' y' f. U
5 v" r0 \7 y0 _8 u9 M) h
& F& g# h" ]/ m) N但分拣传送带的输出端口分配机制有些不同。
* K, M7 S3 k+ T5 _ H分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;
0 I1 P$ F% l2 G3 @# _% p+ U
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?* b$ ?- W3 b8 {( v3 _
return 0不发送( j% p# d' |$ j! k& b4 W) Z4 \
return 1发送到第一个可用端口,如果没有可用端口则不发送。
9 ?2 R/ R2 e* E, r) m( k6 qreturn 2,return 3...return 100000,同return 1
+ p/ J6 o) u+ b6 zreturn -1,同return1- w* N4 I, ]) Q9 w6 v3 W
6 C- F: l" M; t6 V& K! R, ~# Y也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。
% W% a& K% `" f9 N- |7 Z# k: J那么,如何确定发送至哪一个端口呢?
+ @) k( z8 J/ Y7 Y临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。
8 @- u3 y' |5 X- f: ?8 J: Y如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。
3 {# | m2 j, v5 m& n如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。
9 E1 T2 ]( P* C5 O; }- x如果全部端口都不相符,则不发送。5 R4 [$ k6 W8 b! i( H
. I5 F; l* U& Y8 f
如果仍然由临时实体的类型决定的话,应该用以下代码实现:
7 {4 z$ `& k0 J- return (getitemtype(item)==port);
5 Z" T8 P( V- V% k
复制代码 上述代码比较临时实体的类型和端口号,4 N) V# F. k* P! K& A; @
如果两者相符,则返回TURE,发送,
' }% S4 F& ]" O% P如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。5 J& c7 o' O3 k& q
$ J* Q2 n7 v3 H* T+ t- ~8 t至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|