|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
* G* D' }1 D9 T' r
" D4 p: v ]' h9 ?! c: I( T当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。) T/ s' a- a0 `
以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
! s. ^8 z1 ^# s, g) O/ E - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。# O3 @* q: K4 r: u, ]% c! G
9 g$ G, X5 y, Y0 R& E+ ~延伸思考:
$ S6 ]9 U/ Z, |5 h# N5 s. H: I如果return 0;,表示什么意思?第一个可用端口。
' J) e( Y7 f X* j( P6 I如果return -1呢?不发送。( D$ g- ?" p2 z! Y) r$ N% |% a
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。
( D" g4 J* E3 E$ q# D% [# |' U
7 F: v. ~5 O5 m. Q* j# i* I6 U" E* \( p0 K. J
但分拣传送带的输出端口分配机制有些不同。
1 D! D8 @9 |. N1 T分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;
0 {% F0 Z1 {4 F5 N
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?
8 D: N9 S3 f. j" |! N( Lreturn 0不发送
6 n: O' w1 u) J ~return 1发送到第一个可用端口,如果没有可用端口则不发送。) k: M) y% M' n1 B
return 2,return 3...return 100000,同return 1
$ q; x* K6 B: _0 L) E; A! ereturn -1,同return1
% @% E" R/ e+ D7 [" d% p# V; O, f3 C8 o. V1 [1 u$ T+ u6 o
也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。) X0 v5 J9 M& m; w; E
那么,如何确定发送至哪一个端口呢?3 k, B/ l8 v* z
临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。0 h; L1 _3 [# M8 E; F9 k
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。% U- c- t$ {; ^8 S
如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。( x: D4 }2 `$ f
如果全部端口都不相符,则不发送。
) G R; f# v/ l
; d0 a {2 Z" {1 t0 L* x* `% J如果仍然由临时实体的类型决定的话,应该用以下代码实现:
% g1 N4 d; v1 T" D, c- return (getitemtype(item)==port);+ }' O, J ^7 {
复制代码 上述代码比较临时实体的类型和端口号,
% r3 f! Z+ K Y+ m4 C0 Y0 V如果两者相符,则返回TURE,发送,4 g D" L1 R# n2 r
如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。$ g# Q8 W, a# T2 D8 O a
. b: Q7 Z) `, s5 [2 v: N
至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|