|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
2 S+ @- B0 l: W9 o7 I+ y h! p, v" Q4 n+ j) l# e. @
当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。; g, j8 j2 O4 Z1 a) T( H" I1 a9 T
以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);( i# L, d. u0 Z! {
- return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。: Y0 G$ q: x& l5 i, E. q& A* Y! D; q
8 Q# [- B, K! o5 b5 @延伸思考:
/ ^& a% S( }$ k2 g如果return 0;,表示什么意思?第一个可用端口。
/ S& r+ [' Y4 W* y& e如果return -1呢?不发送。( a8 @( H7 c- @! }
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。& S. u& E( u- I1 N( d& u. {
) J+ y7 }# m7 o, N/ n2 n! k/ d* @- q. `( T4 G( W
但分拣传送带的输出端口分配机制有些不同。
. a* ~. e V9 _) X N分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;8 k3 Y% S2 X0 f3 W, l3 G
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?
* {* \ i( G& v8 i8 Wreturn 0不发送
# y9 f0 U; E' ?/ s5 ^return 1发送到第一个可用端口,如果没有可用端口则不发送。 o T' X4 ]: k2 ^9 O
return 2,return 3...return 100000,同return 1
- P1 q9 s2 {2 Rreturn -1,同return1+ `/ ]8 s0 x1 u6 @( h7 }2 o
) S& z, ^# d9 T' I) |2 {也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。$ d1 L; ]/ H2 }1 j6 ^
那么,如何确定发送至哪一个端口呢?
( q( k7 R" o: P8 B/ ]0 a临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。" B% b4 s8 w' f6 m+ d+ h
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。
8 {0 L ^! d, z9 L |. S3 c/ Q* E- V; R如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。
+ U. E6 ]# T. n( j7 O: k如果全部端口都不相符,则不发送。
' F4 p6 m0 P/ s0 Z1 @6 b, R3 g& V/ o, K' Y
如果仍然由临时实体的类型决定的话,应该用以下代码实现:
+ I( m# B- N$ e- return (getitemtype(item)==port);
; |( V7 T) Y" _4 w2 ^# k! Q
复制代码 上述代码比较临时实体的类型和端口号,
3 j+ l; u4 |" \0 A- O( r如果两者相符,则返回TURE,发送,
. F3 E6 k+ Y: L* p Z V* A# l如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。6 R" M/ |; `, O7 |" M `1 z
0 K- n, a* v0 w
至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|