|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
. X0 [" H( e- q: O& M) I# v0 ]8 n0 ]% B) ]: S& W7 J
当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
3 f; w: u! N& l" o以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
$ a! b+ f5 D) A, n7 A0 H; v8 r - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。; }9 |( c, E2 r X( q7 [ g# A/ B
3 w2 o. h6 K6 V r- M7 q3 U
延伸思考:
4 j) x1 |3 F6 T4 m, W) k% g如果return 0;,表示什么意思?第一个可用端口。5 N1 ?9 A* |& k
如果return -1呢?不发送。) p: ^1 t! ^, L/ X
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。' @) g$ Y9 {1 j% t8 h4 U
: {+ r# V( ~; m
5 M* d* ~6 V: i; W' @1 n
但分拣传送带的输出端口分配机制有些不同。$ {% v% j$ b5 x4 M
分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;
; i6 M# O. y7 l3 n4 a" u
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?
* \9 y. z, x/ B- hreturn 0不发送6 o- l/ Z( u! T# j7 u; N' d
return 1发送到第一个可用端口,如果没有可用端口则不发送。, R5 J$ G- b; \
return 2,return 3...return 100000,同return 1
/ r/ W1 e; J$ u q2 oreturn -1,同return1' n) j; h, @! Y/ [; W1 H
& D3 P: c% Y# B" S
也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。
; L; e/ ]: |# M: O$ o1 r那么,如何确定发送至哪一个端口呢?
`# m6 ?, N# P( K& g) {临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。' f; K3 \9 w. E7 \1 Q; L* q
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。
9 X" `! Z& A& I如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。3 _ }4 F) T( O C$ O1 H2 L
如果全部端口都不相符,则不发送。
5 h% w4 D' u, U0 V* {3 T4 q! o+ g, t; ^5 G2 p% l! } R, ~
如果仍然由临时实体的类型决定的话,应该用以下代码实现:
" p) W0 Z0 {7 Q- return (getitemtype(item)==port);2 y, y K( [3 v
复制代码 上述代码比较临时实体的类型和端口号,
, r' D: \- t( a如果两者相符,则返回TURE,发送,
9 P5 K" h% @9 |- G6 k4 @+ r: L, _( o如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。
. ^6 p5 [8 j* { A8 ?& V
* F( r% a& h0 Z4 B, i; ?; \至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|