重新读我自己的帖子,我感觉有可能我把问题搞复杂了。
& [: u, h, B" \( |% ~- x2 X8 O6 C* E8 @3 O7 L' @; B0 y+ [/ s
我说的方法是当需要非常精确的调度每个货位时的方法,这样,每个货位都有一个数组单元对应。
4 _+ h" x. Q+ a: a, u s0 d" R9 T8 b: q" A
但如果仅仅是按照 X, Y,Z 大类而言,也许并不需要建立这样的数组。, d. [/ O& ]$ E% h/ O p+ ]+ K
) w1 q& m: X3 t0 W(1)如果XYZ 有各自单独的库存,那么仅仅需要三个 Queue 模块,一个模块代表一个货物类型,并且容量是有上限的,凡是 X 的货物直进入到第一个 Queue 模块,Y 进入到第二个模块,Z进入到第三个模块。
# C6 e: g/ H6 l( n+ a7 ?. w/ e: r
$ M! G' [* Z1 f4 l7 V+ J(2)如果 XYZ 共享同一的库存,那么仅仅需要一个 Queue, Equation 模块(请注意不是 Queue 模块,单一的 Queue 模块没有办法区分 XYZ不同货物类型)。 不管什么货物都进入到这个模块,然后按照需要从中抽取出不同类型的货物。
7 z8 |( Y+ J2 \
9 s3 s9 V N& G2 I+ R- G& W. Z节省了全局数组,也可以节省大量的数据更新和编写程序的需要。
, \8 k0 Z2 w* W. @ A7 q
" Z, \, O- W9 M# S4 V& r仅供参考。 |