|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
. K7 O5 T" Q8 p: E+ \( y1 }
3 W6 E4 a0 ^/ K当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
l) P9 w2 m0 S% B- c! ?, h& g以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
8 _ H3 P' l. c' h _* T - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
@, }4 D7 O/ ]8 r/ M* O T' ?0 \' W
延伸思考:8 U6 E" G( H2 v: R$ }1 c
如果return 0;,表示什么意思?第一个可用端口。) m& h5 ^* @( H
如果return -1呢?不发送。
' B7 U4 l- _( B% ~如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。2 |1 x# L& q3 z3 L* @! [
2 K1 [, h5 t: R) S5 w4 G6 `5 S$ Y" \& e8 q% ^) p: ~
但分拣传送带的输出端口分配机制有些不同。
( k# O$ Y% T1 \* |( ~0 e" b3 H分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;
0 Q, D7 Q! s+ x+ F
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?
+ y7 A; t b$ r" ?return 0不发送
. M3 k- N- ]$ u& {return 1发送到第一个可用端口,如果没有可用端口则不发送。
7 w; q- u; U$ v1 Kreturn 2,return 3...return 100000,同return 1
' W g5 ]. V9 N9 k5 [return -1,同return1$ Q2 j8 H/ H7 U& y9 v l+ u4 P
! |' L9 I9 r7 K4 R/ C8 M! p/ A" Z也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。/ p0 | A8 P! P3 D9 v
那么,如何确定发送至哪一个端口呢?
& u9 W- X, P1 y( ?临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。3 s- E8 K9 p* [& L7 Z" Z \
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。) J& |# d7 Y* k% g) Q: `' X
如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。2 U% n% @) m+ ]( b" r' n
如果全部端口都不相符,则不发送。
' {/ R+ N( A2 |3 h( H
* G: u0 `5 @' F& N1 J2 C如果仍然由临时实体的类型决定的话,应该用以下代码实现:
" Y3 d5 V& A* u0 V2 I" Y! }) |& E- return (getitemtype(item)==port);
4 j" o" L' K+ G7 D
复制代码 上述代码比较临时实体的类型和端口号,! U0 w9 z9 W, b
如果两者相符,则返回TURE,发送,
4 h1 S# l2 v1 y9 `0 `: e. z) _# m如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。
9 p, h1 ?1 y0 R
5 d# l7 A0 L, D/ b至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|