|
本帖最后由 zorsite 于 2013-9-13 09:47 编辑 / s7 W- r ]9 { ^' Y5 Z
5 f2 Z7 I S# \' N当传送带有多个输出端口,需要指定从哪一个端口输出时,可以直接指定目标端口的序号。
7 a. M7 ~; p* }% q6 @, H. P9 d! n- H以按临时类型来指定输出端口为例,只需在传送带的“发送至端口”代码区录入以下代码:- treenode item = parnode(1);
7 L# \0 y$ e9 T - return getitemtype(item);
复制代码 当临时实体进入传送带后,传送带读取临时实体的类型,然后分配至与类型相同的输出端口。这种机制很好理解。
. m* b2 P* a; D2 T. ?+ p3 ~0 M9 D# |2 x* P
延伸思考:: E2 g- a; }! c+ E
如果return 0;,表示什么意思?第一个可用端口。
! \3 [/ g- m8 B, t( L6 }1 C如果return -1呢?不发送。
$ V' n3 U& p3 Z. A" C( p如果return一个不存在的端口值,比如return 1000000,又会出现什么情况?道理同-1,找不到端口,不发送。# c: d' T* R6 X9 }
& ]1 P% Q. [. f8 [3 ?/ ~% H4 d* _) \# M8 b
但分拣传送带的输出端口分配机制有些不同。# |, G& W" n: o; P+ T& r* v# \3 c2 C
分拣传送带没有“发送至端口”这一选项,取而代之的是“发送条件”。默认的发送条件是“一直发送”。打开“一直发送”的代码编辑窗口,核心代码只有一句:- return 1;
9 e2 D; \& t0 s' e3 A; h3 X. g
复制代码 把return 1改为return 2、return 3、return 0、return -1会是什么情况?7 p7 g+ b1 M/ o- T, T
return 0不发送9 b: R8 R; x4 `- i* h
return 1发送到第一个可用端口,如果没有可用端口则不发送。
. @5 }) O( t& o. M$ d/ Oreturn 2,return 3...return 100000,同return 1
4 B- o/ N5 D, |/ I5 M% sreturn -1,同return1
( V" c2 \/ m" I/ r. W8 A, O
7 T! q1 [$ y6 E$ W/ u也就是说,分拣传送带的发送条件只返回两种值:零和非零。返回零时不发送,返回非零时发送。, \8 H+ U! b( C' C' ~
那么,如何确定发送至哪一个端口呢?" `+ U, Z3 b5 u2 R9 [! _7 u7 x* ?
临时实体进入分拣传送带后,分拣传送带读取临时实体的类型,并依次与现有输出端口对比。1 H* U8 ^) h6 M, D7 _
如果临时实体类型与某一端口号相符,则返回Ture,从此端口发送。6 e8 e: `7 @# R* X0 h2 Z
如果不相符,返回False,继续与下一端口进行对比,直到找到相符的端口。
' `* N! A* i" e/ [9 E2 d如果全部端口都不相符,则不发送。0 O% N/ }- P8 m$ d. X, s7 Q0 D
9 I6 I3 c+ |2 R如果仍然由临时实体的类型决定的话,应该用以下代码实现:- , S/ G) X, c& ^* x2 Z
- return (getitemtype(item)==port);
9 Q& r$ n( H2 c& f. Z1 G5 A
复制代码 上述代码比较临时实体的类型和端口号,0 g0 n, k$ @. f
如果两者相符,则返回TURE,发送,, o* m$ w# m; S( P- e5 x
如果不相符,则返回FALSE,不发送,继续对比下一端口,直到两者相符为止。如果没有任何端口相符,则不发送。
/ h7 ^- K9 T0 I* k2 O% D% _" B q: m9 B
至于一句代码就实现了所有端口的循环对比,我认为可能此对比机制内建于分拣传送带的底层。 |
|