|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
- C/ Z, T1 l* c r# ?% H
1 w4 F) N. k6 c当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
! }5 T+ h" p* n0 l以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
$ \2 @! O9 [; f7 j; v9 u - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
7 f. Z. X- u9 g a j5 w
. S2 }4 V( Z- p延伸思考:
& m0 m/ u) q& r `" ?5 s如果return 0;,表示什么意思?第一个可用端口。
- v7 h" ]3 y0 \' \* j- u如果return -1呢?不发送。
: P7 Z P/ r9 t& \& z如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。
. K/ I: i1 ]. L1 @7 h4 E5 A+ h" {' p$ h
$ @* ~# L3 e# N! g9 f, C' U但分拣传送带的输出端口分配机制有些不同。
' [# u6 s; D: E7 F: ~0 s分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;
* O, x& i. e6 H% t0 M2 ?
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?8 I7 G" | n( G
return 0不发送
: Z, X d# I) t& y: ireturn 1发送到第一个可用端口,如果没有可用端口则不发送。
, Z* q! u. i/ @( wreturn 2,return 3...return 100000,同return 1
8 D. R+ |1 u- `* D2 a7 @/ Treturn -1,同return1
+ W* t7 |* k* V% y
* N2 n; d: K! r' ~也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。6 } Z: \# J4 [2 R* p8 c/ e1 \
那么,如何确定发送至哪一个端口呢?
; Z4 a; z/ G3 I) L: T& v' J临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。) `& ^" a* k% d) n$ q
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。
4 ]$ f0 h8 ?. |如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。" q& R0 w7 F# L, @* p
如果全部端口都不相符,则不发送。
! _. k, c( b5 }* l# s
4 P% J0 O! y7 P0 k0 T9 _/ R如果仍然由临时实体的类型决定的话,应该用以下代码实现:
& m8 ]) R- [& ?7 `8 ]' k- return (getitemtype(item)==port);
a3 L! [5 B1 K4 N- r! I+ _
复制代码 上述代码比较临时实体的类型和端口号,
5 v: o; S( ]6 |7 L1 t如果两者相符,则返回TURE,发送,
! {5 P1 Y5 t# ~! H5 ~$ |如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。% O1 B4 q7 h% G/ h9 ]) t0 J
5 o% [ B9 ~4 L# D9 c5 E0 I" n
至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|