|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
: R P8 `# F3 I3 E; I1 A. W& Y1 X( W, M% Z! q
当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
3 D" c+ x+ J, q. I5 a" {0 F& r以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
- y& {/ V0 u6 H* o# e, e+ Y! }+ P - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
' o7 ]6 x, V% g: v( }/ K, M3 t7 c/ b& \. m% I" }
延伸思考:
2 q9 m, A8 R K% g: M5 s1 b3 a* e如果return 0;,表示什么意思?第一个可用端口。' @% ~( v% R' P
如果return -1呢?不发送。0 s' [; b# y v9 q6 i6 b/ q. j
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。+ @( w u9 P: q2 F, b) K$ [
$ B: z1 @, @& g: E5 e
: ~! {9 L+ k' I4 F但分拣传送带的输出端口分配机制有些不同。
: V1 |& m: L0 C4 o" V分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;- R# ^. r$ A- `" B% e) ]0 |
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?( a: b4 d# X: a! d
return 0不发送0 v! o9 d7 L5 a0 ]" m# a$ _% J
return 1发送到第一个可用端口,如果没有可用端口则不发送。7 J- [- ]& m; o i/ x/ e" X J* Y
return 2,return 3...return 100000,同return 1
) j7 n* `7 i; H) E; a2 w$ Q2 Sreturn -1,同return1. U& `1 U9 @7 ?
9 C! ~1 Z, r2 E* h4 a3 e' A% n- W$ N
也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。8 M) M2 T' F! c; r# T: h
那么,如何确定发送至哪一个端口呢?7 ^9 p9 P) p D0 Z' z# {
临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。) P" ?5 F2 G F! C, v
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。: z5 L# T0 [1 B! R7 `4 K+ t
如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。
1 X: u2 R& I6 U8 [$ }8 w! u, g/ i如果全部端口都不相符,则不发送。
# ?: q4 b9 ^/ Y* q- }
% c/ {2 g& a1 Y9 x- U( T& Y& x1 J2 j如果仍然由临时实体的类型决定的话,应该用以下代码实现:- ) Z, z* i# l2 T ^3 g0 s. `
- return (getitemtype(item)==port);
# i6 K& U- q+ |/ F% w" J. X! m
复制代码 上述代码比较临时实体的类型和端口号,
% ~! s$ [- o$ V. y6 ]如果两者相符,则返回TURE,发送,
. B! M$ B3 i5 A! @0 A# |6 {& ?如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。
* J: T4 i7 n3 g+ T( X% p, _
. b4 H8 l, v) X# _至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|