|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑
- a6 C+ g( w% e4 h) f/ t m- }
2 R# ~3 L% m7 s9 m8 i当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
+ g* g; }6 S& G以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
- R% V* t7 `' V5 g/ X+ G, u, O - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
g6 L: ^$ B9 J1 ^% W6 M# C7 i. s/ n: ~9 p& v4 t) B1 Y
延伸思考:) e: z: o# \# S+ c& c
如果return 0;,表示什么意思?第一个可用端口。+ V( f) ?0 P5 z8 |2 s# h& c
如果return -1呢?不发送。* j- \: I4 U+ A- p0 X" O
如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。7 Q- ]5 r/ X% H* M4 H2 V8 ~2 `
6 o4 p/ i6 H0 w8 R/ W( r" g( x5 R0 y4 m4 L, R! F
但分拣传送带的输出端口分配机制有些不同。
4 E! ]! z( f. z5 n6 u分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;* ?; ]8 t# M; ]$ S8 R7 b2 H7 b* h
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?3 v( K, s4 l4 B7 \
return 0不发送1 W: T0 {5 ~ ]+ E$ D6 Z
return 1发送到第一个可用端口,如果没有可用端口则不发送。' Z) z7 A. L& J4 ?4 X# R6 Q
return 2,return 3...return 100000,同return 1- o% J" U+ \& H' ?/ w" A
return -1,同return1
7 }0 I# m5 F, ]6 ]6 O( }) @& s7 O4 k- \1 `* m
也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。) ]# s0 a! w9 d) l" b
那么,如何确定发送至哪一个端口呢?: j3 o) D9 J2 z' w3 x
临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。. `* _( g1 [& b8 r3 ^
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。+ E; u. J N4 r- @$ l: D
如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。
1 [8 L+ Y6 j% A8 W5 @如果全部端口都不相符,则不发送。" n( _! I; j0 _% g7 M
$ O+ l$ b3 H7 L如果仍然由临时实体的类型决定的话,应该用以下代码实现:- + Q" r0 p4 T- a5 X% l$ I$ ^9 r
- return (getitemtype(item)==port);' A+ y2 M; T1 l* Y5 a @
复制代码 上述代码比较临时实体的类型和端口号,
, U; h+ E9 U0 [% [. F b如果两者相符,则返回TURE,发送,1 Y5 F- y+ @) s' O3 x
如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。% d. ]% S: f; O+ x
4 J: |2 l. N3 y b+ I+ E6 v) p至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|