|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑 ) f$ o' i4 ], E) J
6 r5 w: c6 M& v+ a2 a- }当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。+ M3 D+ K6 h0 W p$ i/ b
以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
, w$ O9 ^$ y, h. H - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
* r9 G' s+ Z8 v" E8 J4 z3 |" }! u Q
3 ~/ d v5 X" A/ _! i" q延伸思考:7 |0 Y5 E* T" x- X; c9 w2 P
如果return 0;,表示什么意思?第一个可用端口。
& j6 ?/ r+ [% m) w, v如果return -1呢?不发送。3 Y6 K/ S: g9 K0 c/ \1 l; U
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。
' l! V, b K2 o' H, a: M& t8 }3 S V, D& F2 |! B0 b
3 |7 \$ ~/ \1 \ C: i
但分拣传送带的输出端口分配机制有些不同。
& A, I) C0 h7 P" w5 R分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;1 H, h8 q8 O0 T1 K# o
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?) y5 E! y+ |( g
return 0不发送: d/ M$ r- _$ q# J. ?8 e2 F
return 1发送到第一个可用端口,如果没有可用端口则不发送。8 Q* |, q4 K- U5 i+ c' o
return 2,return 3...return 100000,同return 1
1 E8 R/ Q- K0 p+ Y" I* J: Wreturn -1,同return14 F4 _7 {# n2 G* x9 X! I" H
' K+ r2 O& R8 p
也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。
0 S1 b2 U- Q0 r& x0 u3 N1 w那么,如何确定发送至哪一个端口呢?
% ~( D1 ?; c; [ ^1 j临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。
+ S: A" c4 d* T" E如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。
: n# {0 M& M, G6 o8 F" m* L如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。
/ u7 e' Q1 |1 Q! }如果全部端口都不相符,则不发送。, S( F, q3 h1 z8 Z$ U: F! p
\( V; M# y% o, Y% K5 y+ R如果仍然由临时实体的类型决定的话,应该用以下代码实现:- 2 A. x- l0 `% P! ]3 P+ t" |
- return (getitemtype(item)==port);# r9 ~4 Q' O& y8 ^. ~ a
复制代码 上述代码比较临时实体的类型和端口号,
* x0 W4 W5 E1 A. d2 g" }如果两者相符,则返回TURE,发送,# {" m, T7 ^+ z5 D5 O* [
如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。. z# m' J# ^% P- G$ J
3 R+ c; p1 `9 b$ m9 O
至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|