当前位置:  开发笔记 > 编程语言 > 正文

这是一个糟糕的模式吗?(切换到/ foreach循环内部)

如何解决《这是一个糟糕的模式吗?(切换到/foreach循环内部)》经验,为你挑选了2个好方法。

我发现自己编写的代码如下:

foreach($array as $key => $value) {
    switch($key) {
        case 'something':
            doSomething($value);
            break;
        case 'somethingelse':
            doSomethingElse($value);
            break;
    }
}

有没有更好的方法来解决这个问题?对我来说似乎很脏,但我可能只是在思考它.

我能想到的唯一另一种选择是每个键的if语句,这似乎没有任何好处.即:

if($array[0] == 'something') {
    doSomething($array[0]);
}
if($array[1] == 'somethingelse') {
    doSomethingElse($array[1]);
}

(或类似的东西)

如果需要,我可以发布确切的代码,但这是发生的事情的大致轮廓.请批评,但请记住我在这里寻求帮助.所以,如果我做了一些非常错误的事情,那就指出来吧.



1> Mark Rushako..:

将函数映射到字典/关联数组中的键是这种情况的常用方法(正如@jldupont所提到的) - 不仅在PHP中,而且在许多具有关联数组的动态语言中.例如,Python和Lua甚至没有 switch语句 - 这几乎是模拟交换机的唯一方法.

考虑这种方法:


输出:

Goodbye.
Hello.

当你只有两个不同的值时,这是过度的,但显然它变得更有价值,因为你必须覆盖的情况数量增加.



2> jheddings..:

这不是一个"坏"的解决方案,但一如既往,还有其他选择.例如,您可以删除switch语句并为字符串使用解释的处理程序.这类似于函数指针列表,但您不必使列表保持最新以添加新行为; 简单地将新函数添加到处理程序将处理它.

$array = array(
  "something" => "itsasecret",
  "somethingelse" => "i can't tell you",
);

class Handler {
  static function something($value) {
    printf("something: %s\n", $value);
  }

  static function somethingelse($value) {
    printf("somethingelse: %s\n", $value);
  }
}

$handler = new Handler();
foreach($array as $key => $value) {
  $handler->$key($value);
}

您可能需要一些代码来清理输入字符串并确保该方法存在于您的处理程序中,但这可能会给您一些想法.

推荐阅读
php
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有