|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
$ e2 G! i8 O. d; \ J+ ?# E$ A# K0 V q8 ~# |
当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
: K( E5 R, \6 L8 _; z9 F以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);/ a# D6 F- o- _) @
- return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。/ ]" {3 {7 l v% r! D
A) b: r0 t4 S1 A' r. Q6 o$ \
延伸思考:
- _% j, {. W6 v. f+ d, z2 {8 P% e如果return 0;,表示什么意思?第一个可用端口。
& O5 i0 e6 U, u+ U0 u& Z/ ^' E如果return -1呢?不发送。3 z; K6 u! A! C* G! y) g
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。
" m+ F8 Q! `* E1 I _* N; ?
# J0 O* A3 O. }; ]' ]9 b+ n- X, Z& o3 @! z f8 [0 m7 s! S" b
但分拣传送带的输出端口分配机制有些不同。" B$ h1 N) j, |
分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;6 R' z. X, w b: \$ g+ Y J
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?# m) S0 d p# M" s& }( y
return 0不发送# I5 w7 }2 z* D/ f$ B" W
return 1发送到第一个可用端口,如果没有可用端口则不发送。
' U$ B/ r5 D' V6 o- l/ Jreturn 2,return 3...return 100000,同return 1
7 Q/ W, ~0 z5 v" `5 Treturn -1,同return10 l6 j( c, W+ @3 S2 ~" L
5 z8 b2 p+ D2 ?- ]+ }也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。3 X% f' c* y% C9 ?: O
那么,如何确定发送至哪一个端口呢?
3 ]8 @7 w. ~9 F0 O9 d临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。
- I) a" u0 H* U' _' ?如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。
: d: U) Q( p# Z如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。7 X B, Y- T" n, a7 b
如果全部端口都不相符,则不发送。
- a) ]5 ^' |& E' F& D6 F7 l' v: D/ ]1 m
如果仍然由临时实体的类型决定的话,应该用以下代码实现:
+ O* L4 j1 D% w- return (getitemtype(item)==port);
6 ~/ R7 x7 ~$ T4 o1 M% L! m
复制代码 上述代码比较临时实体的类型和端口号,
! E# c9 g5 c, ?, i. |# n8 j如果两者相符,则返回TURE,发送,
& q8 }; r0 G/ W/ E如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。: Z: ]2 W. w9 a" D
/ H; [ K% a' y& m; H至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|