|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑 + W1 c i5 D9 J$ A
) ~8 w6 `% M a+ k' N当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。( D5 T7 { r- s; S' o0 t0 ?# v
以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);. y/ R# G1 ~) g7 Z
- return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。: z9 U, R: \' ]9 Z2 S+ k( v
5 z2 ?$ l) n( w( n7 Z延伸思考:
' J0 A! P i# M! B' M如果return 0;,表示什么意思?第一个可用端口。
9 f8 b. k. a K: Z6 T, w如果return -1呢?不发送。
+ ]& ~: ?# Y3 ]6 O& _1 T: t如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。
% T; P6 M5 r6 T
* m: e5 y9 g" h# ? a& q) b5 p0 K8 V! n
但分拣传送带的输出端口分配机制有些不同。
' a* P: s1 ^6 |. G1 c. }分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;' Q6 S% R2 ~! B7 Q
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?
( ]4 N" Q7 b5 q6 P2 Treturn 0不发送/ d3 G. d" @9 k( \" @5 r0 X
return 1发送到第一个可用端口,如果没有可用端口则不发送。
) [/ m7 f2 M! I& |% G+ Areturn 2,return 3...return 100000,同return 1
( a: R: w) n) Q" a) hreturn -1,同return1
9 a) ?! n ?# `, L# S$ C1 I. L, e9 ?0 j3 _) i/ W e* w* t
也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。
9 e) L: b2 l5 h( ~! q9 j那么,如何确定发送至哪一个端口呢?
* f1 X$ t; D) z. [8 x, @; D( F' p临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。! ~5 P+ T( D1 T8 R
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。
; z. j& W5 j4 \! d8 I1 g如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。/ @2 O' E; ?2 w$ w) C* E: ~
如果全部端口都不相符,则不发送。
; b, a' z! Z2 q5 T! |7 V1 n2 l b9 z" S9 V* t5 F7 E9 G
如果仍然由临时实体的类型决定的话,应该用以下代码实现:- " s8 E- y! e& ]; _! I
- return (getitemtype(item)==port);' ` R/ | v9 ~9 b ~7 u
复制代码 上述代码比较临时实体的类型和端口号,
; c: O( H& b8 q0 ~如果两者相符,则返回TURE,发送,2 B0 k: f# n- |7 b& I6 ^9 I
如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。# f h7 U1 k9 s7 H! I& z5 u2 A- s
2 j8 ~! k) }9 q至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|