|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
; ?* D2 N5 M0 A6 r: M$ ~% h$ ^, k! n# {0 i; |3 S" t7 L* _7 N& [( d
当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。1 w7 b1 k7 W) x d8 T
以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
: i6 E. W# i& | Y; P - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
9 R# [1 u/ K/ N$ o) C5 u; h. T+ R: }2 _$ ]! C) c
延伸思考:
" m6 q1 G- I2 S' \+ ], L如果return 0;,表示什么意思?第一个可用端口。6 ^2 ^' p+ M/ ` m! S* A
如果return -1呢?不发送。
W$ ]2 r, R7 x7 k; b$ Q如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。1 T+ X$ K+ k6 U& P: Q+ j7 A- t- g2 ~
$ J' i3 l; `: E# x* _5 I" J' d: S
! ]9 z- ^8 X+ u# B但分拣传送带的输出端口分配机制有些不同。0 g7 K! k/ w3 |6 D
分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;
& c' \: t* N" G& X6 ?. x
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?. a; |: E# G( X! T4 P7 @' l
return 0不发送) x/ ]2 v1 t& ]* j+ g4 ]' h
return 1发送到第一个可用端口,如果没有可用端口则不发送。
: K7 @7 T& ?# ~6 J9 V. Rreturn 2,return 3...return 100000,同return 1
9 D+ v# I# x% M1 i! b+ oreturn -1,同return1: x: z1 j8 Q5 b6 [% ^1 E
# ?% Y/ T& [1 C7 M
也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。# w; G' A# ^4 d0 i V! b3 c, Y
那么,如何确定发送至哪一个端口呢?
: ]9 X. T% P. K. Q) E临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。
5 ^4 [" z5 U. c; A7 Y' r' J如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。
* h; H9 i5 O. e- k* @) g如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。7 Q# R8 {) W! T' p0 l* Z6 C$ d8 N
如果全部端口都不相符,则不发送。
" E$ w. o$ R U% t. v" ]1 s) v; z( J( c: M1 l* N
如果仍然由临时实体的类型决定的话,应该用以下代码实现:- 7 X2 w) e; n- m( e8 I0 ^* Z
- return (getitemtype(item)==port);
$ Y) z6 M3 k p0 m) n3 Z, d
复制代码 上述代码比较临时实体的类型和端口号,
/ }5 v3 b2 [ k( G n: ]4 h6 m如果两者相符,则返回TURE,发送,4 B6 ]( |- d2 G9 h) p
如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。
' a; _7 c& O0 I: w8 D% k' u3 C5 k3 O2 p* \ I
至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|