|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑 8 T9 w4 \$ D$ i7 {
' U% Y1 D4 U s' d% N& ^( n2 S& v0 x
当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。2 ^* f; c* O( r( U6 e6 m; q
以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
. L" }+ b' H) M- y3 i - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
9 t+ p9 ^! [+ B5 X5 I" [. v) N
8 O& K/ M( `- s2 J. c延伸思考:8 ]/ R3 {0 u2 M4 X3 }
如果return 0;,表示什么意思?第一个可用端口。* R0 e4 a7 A) W( j0 \
如果return -1呢?不发送。9 `9 g5 J% z* q
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。
* d: k6 }; v8 x! Z# ?+ D8 b; t0 ~4 |, e8 ]5 Y
2 S; \; q: |3 d& A& u$ [9 z但分拣传送带的输出端口分配机制有些不同。
# C) h# z$ R( s9 h分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;; k9 T8 Z8 Z$ n0 {7 e* K
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?1 m; ~$ c/ u4 J y6 S
return 0不发送
4 F- K4 o/ S4 P' `2 }: g0 freturn 1发送到第一个可用端口,如果没有可用端口则不发送。) u7 Y$ v2 K& Y; L4 h6 L
return 2,return 3...return 100000,同return 1
# C. O' |1 R, j, W) F7 n1 Preturn -1,同return15 M& p- B$ f! n M S
% W8 y5 b$ K7 J7 e7 D也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。
" _4 q$ y: t9 Q$ D那么,如何确定发送至哪一个端口呢?
6 E% Y8 O- J" L& D! S% U f4 n0 p临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。& H# H" l* c9 O+ F! T
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。, f, _! I+ y3 L3 u
如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。0 E. Q# P2 i( x, ^9 U
如果全部端口都不相符,则不发送。) q) G! N; o3 }# X- \" `
$ o/ w; D+ s, N; } o如果仍然由临时实体的类型决定的话,应该用以下代码实现:
. T' N2 ?. }, o" \$ d* B n* p- return (getitemtype(item)==port);
2 N* h+ g3 C' j" E+ y+ y
复制代码 上述代码比较临时实体的类型和端口号,
) H- y1 }! K" H3 V如果两者相符,则返回TURE,发送,
/ {+ @/ J& L. w' {如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。' g' h5 K0 A8 \" C h
, j3 r2 m5 i' V6 V
至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|