|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
- l/ Z6 `" l4 g/ U- S0 [1 P$ l" D& V5 K/ n0 C7 @9 @) |0 v3 u
当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
9 I/ v) d3 \% ?6 c% I以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
$ U5 s1 @/ s0 {/ L' o3 {0 p- ^ - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
/ J I8 @4 j2 {# ]0 |
& A1 E, k+ F6 M5 _9 m延伸思考:: i+ m) T4 A* T7 [
如果return 0;,表示什么意思?第一个可用端口。4 b# z- _/ W& m- t- f0 L
如果return -1呢?不发送。/ z4 V- B9 f+ ?# j9 h* o' R _- f7 h
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。3 A+ T9 E+ z p
8 d# ~, Q, w! z0 |) C. a) b
! j4 x+ L( T2 M5 I0 G# B
但分拣传送带的输出端口分配机制有些不同。
2 g3 c8 k0 L! R5 f1 U+ H. K分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;0 C9 S9 ^0 j6 w4 Z
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?
7 d+ q- k! v, \+ e: e3 p8 D% \# O, Sreturn 0不发送. i; f4 j% K( q6 Q: I! B
return 1发送到第一个可用端口,如果没有可用端口则不发送。' u2 f8 T2 v) `4 B
return 2,return 3...return 100000,同return 1
& [" b4 u, W8 N3 Jreturn -1,同return14 ~% P0 c9 I4 G9 ^+ `; }
6 S4 R+ b- n# B' [也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。
( [' L( R( r! s( i0 t2 T那么,如何确定发送至哪一个端口呢?
' p3 v5 B1 e+ I4 f' X5 |5 s* i临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。
6 _* N/ z" F$ c/ Z5 {如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。' b! ~9 @2 I: h* w
如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。
" u+ O% ~% } I& p( v如果全部端口都不相符,则不发送。7 t2 b* g9 v- s$ K2 ?
9 N1 I* z H( f! E3 v$ ]3 N
如果仍然由临时实体的类型决定的话,应该用以下代码实现:
7 g$ }/ o+ k* T* \* i6 L9 a6 G8 N- return (getitemtype(item)==port);7 w' ?8 M v5 v5 S9 m Y
复制代码 上述代码比较临时实体的类型和端口号,
& _& l% J& ~( X' U( m' T如果两者相符,则返回TURE,发送,
# o" d2 U, z& h% Z4 m2 l" X如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。- v8 P6 F# w" ~( K+ r4 C: J
' K4 ]% X% j! A* _& k8 X* ?+ t" J至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|