2017-10-05 67 views
-2

有一个问题,我想循环trought整个堆栈或停止某处,但不知何故循环抛出的而不是计数...项目值被错误地分配给真正的,该怎么办?运营商优先

php7 

编辑::

好吧...我试图使它抽象...

<?php 
class foo { 
    private static $instance = []; 
    private $stack = []; 
    private $stop; 
    public static function i() { 
     if (!isset(static::$instance[0])) { 
      static::$instance[0] = new static(); 
     } 
     return static::$instance[0]; 
    } 
    public static function destroy() { 
     unset(static::$instance[0]); 
    } 
    public function stop() { 
     $this->stop = true; 
    } 
    private function __construct() { 
     echo '__constructor being called'.PHP_EOL; 
     $this->fillTheVoid(); 
    } 
    public function do() { 
     echo 'BEGIN'.PHP_EOL; 
     $this->work(); 
     echo 'END'.PHP_EOL; 
    } 
    private function fillTheVoid() { 
     $k = 0; 
     for($i = 0; $i < 20 ; $i++) { 
      $this->stack[] = ++$k; 
     } 
    } 
    private function work() { 
     while($item = array_pop($this->stack) && !$this->stop) { 
      echo $item.PHP_EOL; 
     } 
    } 
} 

$foo = foo::i(); 
$foo -> do(); 
function shutdown() { 
    echo 'shutting_down'.PHP_EOL; 
    $foo = foo::i(); 
    $foo -> stop(); 
    for($i = 3; $i > 0; $i--) { 
     sleep(1); 
     echo $i.PHP_EOL; 
    } 
} 

register_shutdown_function('shutdown', null); 

exit; 
?> 

输出是:

__constructor being called 
BEGIN 
1 
1 
1 
1 
1 
1 
1 
1 
1 
1 
1 
1 
1 
1 
1 
1 
1 
1 
1 
1 
END 
shutting_down 
3 
2 
1 

不知怎的,这是循环错误

我们想要数,相反,我们刚刚得到的...

这起源与构造问题,但后来我无意中发现了语法错误,所以我改变一点点......

+0

如果它真的是单身人士,不要担心它会返回相同的对象,你不必担心它 – shashi

+2

你可以发布单身人士代码和关机功能吗? – vincenth

回答

1

据我看到,你的单身按预期工作,构造函数只调用一次。

关于你提到的其他问题(获得的1,而不是从20到1倒计时一布赫),这里是修复:

private function work() { 
    while(($item = array_pop($this->stack)) && !$this->stop) { 
     echo 'item:' . $item.PHP_EOL; 
    } 
} 

你需要围绕它被评价你括号,否则分配如下:

$item = (array_pop($this->stack) && !$this->stop) 

这将返回true并在您输出中显示为“1”。