|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑 4 N, W( w6 j+ e# R1 v
4 Y- L4 Y8 L3 Y4 W
当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
4 f- v6 ^" w# W, G' r# q: W以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
5 D$ y3 w5 [' y# C2 {1 C - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
# ]9 W0 m6 R% z6 E) G! b8 H, e$ J. h9 X6 d. P5 o! t' M
延伸思考:
' Y7 H3 W3 M `: W. ?2 S" y如果return 0;,表示什么意思?第一个可用端口。% ]" v# L% K0 A( ~5 U0 F, P- X& ^
如果return -1呢?不发送。
' b# k) b( R* z4 R8 v% y8 C7 D* X如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。
7 c, }2 c0 B5 I6 ~7 x
' Y3 r; z3 X; T6 ^
+ k8 W7 p: i/ v* x7 x% X但分拣传送带的输出端口分配机制有些不同。+ u8 N4 t, Q* l4 V
分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;3 t/ i% ]& m* C7 n4 f2 x$ y% L
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?" `, y$ q9 l* G" y' s7 J
return 0不发送5 V# {( j5 a8 ?5 s
return 1发送到第一个可用端口,如果没有可用端口则不发送。2 E& g3 D- G0 r! s% J
return 2,return 3...return 100000,同return 1
- ~0 w/ r* T, K4 ^% K1 ]return -1,同return1" y% }/ n* R& M0 M! \+ i, d
! O0 Z( k( h3 d. N; b也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。: I8 t+ g- ?% n* J8 A* V
那么,如何确定发送至哪一个端口呢?& K! Q; }$ v9 O' D1 k' c& L# \$ Q
临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。
$ l+ M3 Z0 Z6 [0 r如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。) \- S( ~3 {) r8 n4 S
如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。& b E; q. }# M$ a8 q2 \+ \, _' W+ b
如果全部端口都不相符,则不发送。7 d8 ]3 H+ J* r& ` S- ^
4 P2 ^5 y& X4 I如果仍然由临时实体的类型决定的话,应该用以下代码实现:- ' t, J3 S$ b2 i' P7 t; {* G1 e
- return (getitemtype(item)==port);5 d8 |$ L$ ]* c) k0 ~* @$ V
复制代码 上述代码比较临时实体的类型和端口号,
" f. T& x6 l1 _& b2 D如果两者相符,则返回TURE,发送,' S- g% C2 }/ N$ z
如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。
$ J! M& y. q) v, g: u0 b
e2 {3 K2 _- Y6 V- y: ^至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|