|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
' |( ^* S" a" y4 q A0 c0 A" x9 v4 }: R2 M
当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。3 z; k0 _! [; W5 G
以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
3 P; c- Z3 }# N% @; p - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
' q- P k# D6 o: r. z
& |. z8 C5 f: M5 a) e延伸思考:" h( I& b9 U) y' e9 k' b7 V% f1 ~
如果return 0;,表示什么意思?第一个可用端口。
# i6 E, x$ x6 ?# |; P9 E9 V: C4 I如果return -1呢?不发送。4 I, `0 f, [: @/ E3 F
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。
0 x2 d$ ^ N2 O7 E6 r/ B7 g7 ]! H2 i) Y' l8 t+ u
4 ^5 D b0 I* m# f, y* {
但分拣传送带的输出端口分配机制有些不同。
! S* ]" n4 i ~3 j; {% K6 }分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;& G+ ]9 b" q! Y# _' }
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?7 J. ]7 x. d% _+ e. w+ }
return 0不发送
; a8 H6 w$ T# O/ w- G* vreturn 1发送到第一个可用端口,如果没有可用端口则不发送。
9 w9 Y2 ?% u6 j% w' Z g, Q9 v& rreturn 2,return 3...return 100000,同return 1* T5 g* Q0 g/ L- |
return -1,同return1
5 A/ i5 U; I6 ^2 Y, H
* B, N1 V$ v R也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。; D, @# g# X! h# T6 ^
那么,如何确定发送至哪一个端口呢?6 @# W; A- k! N/ g* V; r9 ~% v
临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。3 f- G/ C6 o" j1 ?. o, h
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。
$ Q' c9 X1 [9 p' {( G如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。) N% e2 h. n, g/ _
如果全部端口都不相符,则不发送。
& ^5 D1 E+ f5 W& F [% C2 P3 y, Y2 R( z
如果仍然由临时实体的类型决定的话,应该用以下代码实现:
/ Q. q5 y3 |" e) K' V- return (getitemtype(item)==port);" G8 t1 ?$ N7 ^2 d
复制代码 上述代码比较临时实体的类型和端口号,
3 w: A; T8 g! v. ` T | ~% _ }4 F+ j如果两者相符,则返回TURE,发送,+ J6 p H! c5 p
如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。
0 R( e1 O8 y0 W
% P: R1 H; u' |" d* {) T) G! o至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|