|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑 , P7 Y+ Q1 ?: |; ]: I
* ^9 a! A9 J8 v# _6 m0 `当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
! N; O+ ^; P! }: w; Q3 J0 G; V Q以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);# g$ R! e& h2 q* B0 v# `
- return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
1 v) P7 d" P4 e Q6 H" g9 V0 }
% t& Q8 i/ B2 e1 N延伸思考:: s6 \+ _7 W; T% w3 y$ g- b
如果return 0;,表示什么意思?第一个可用端口。
/ K4 F, h/ t0 S) o7 S) b: h/ T如果return -1呢?不发送。. \6 l) [4 J$ |8 c
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。
; \4 I, ]" }0 l2 k, }+ x6 ]" K) Y7 k7 F. p5 q7 g
" x5 M" Q2 X2 r8 m9 r
但分拣传送带的输出端口分配机制有些不同。$ [. x# _2 S' ^9 h
分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;' ^. j# S q' e- J
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?6 ]/ Y. U4 C8 x- b3 x; K# ~
return 0不发送
4 D+ y' X- Q s6 J1 Breturn 1发送到第一个可用端口,如果没有可用端口则不发送。
6 N' j$ |" u; |: U/ O: hreturn 2,return 3...return 100000,同return 10 M: a' i; P. ~3 x8 c
return -1,同return1; S7 L. g8 g3 F9 W$ j- m% ]
. X& Z: P: O9 B. D$ K7 @
也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。$ q# R" O# ?# L# U$ a |
那么,如何确定发送至哪一个端口呢?7 `- E$ M& ~* e+ G, R2 z
临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。
; P9 g3 g7 `$ G5 ` H如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。
# n, ^: _/ e- [- z& Y( O' V* P如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。
9 C5 U. D( k$ y$ L! O如果全部端口都不相符,则不发送。
, I( I" E' A* k8 P* s( p* C1 T& o7 D B: S" _4 o
如果仍然由临时实体的类型决定的话,应该用以下代码实现:
* g) y: a6 X8 R- return (getitemtype(item)==port);
% m5 k$ N, h- l& R9 k8 C6 I) R0 j
复制代码 上述代码比较临时实体的类型和端口号,
) L6 L% A8 w. B如果两者相符,则返回TURE,发送,: ]7 r+ P5 _( Q. H- B3 F# }
如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。
. ]' X7 q) D G7 @( ]% y$ v) l5 D. Q( x% }4 u; ?% z
至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|