當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Stack::size方法代碼示例

本文整理匯總了PHP中Stack::size方法的典型用法代碼示例。如果您正苦於以下問題:PHP Stack::size方法的具體用法?PHP Stack::size怎麽用?PHP Stack::size使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Stack的用法示例。


在下文中一共展示了Stack::size方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: testInsertAndRemove

 public function testInsertAndRemove()
 {
     $Stack = new Stack();
     $Stack->push('Radig');
     $this->assertIdentical($Stack->size(), 1);
     $this->assertIdentical($Stack->nth(), 'Radig');
     $Stack->push('CakePHP');
     $this->assertIdentical($Stack->size(), 2);
     // testa com 1-lookahead
     $this->assertIdentical($Stack->nth(), 'CakePHP');
     // teste com 2-lookahead
     $this->assertIdentical($Stack->nth(2), 'Radig');
     $this->assertIdentical($Stack->pop(), 'CakePHP');
     $this->assertIdentical($Stack->pop(), 'Radig');
     $this->assertIdentical($Stack->pop(), null);
     unset($Stack);
 }
開發者ID:schnauss,項目名稱:rutils,代碼行數:17,代碼來源:stack.test.php

示例2: pfx

 /**
  * Evaluate postfix notation
  *
  * @param array $tokens
  * @param array $vars
  *
  * @return mixed boolean *false* in failures and *numeric* value in success
  */
 protected function pfx($tokens, $vars = array())
 {
     bcscale($this->precision);
     if ($tokens === false) {
         return false;
     }
     $stack = new Stack();
     foreach ($tokens as $token) {
         // if the token is a binary operator, pop two values off the stack, do the operation, and push the result back on
         if (in_array($token, array('+', '-', '*', '/', '^'))) {
             if (is_null($op2 = $stack->pop()) || is_null($op1 = $stack->pop())) {
                 return $this->error("Internal error");
             }
             switch ($token) {
                 case '+':
                     $stack->push(bcadd($op1, $op2));
                     break;
                 case '-':
                     $stack->push(bcsub($op1, $op2));
                     break;
                 case '*':
                     $stack->push(bcmul($op1, $op2));
                     break;
                 case '/':
                     if ($op2 == 0) {
                         return $this->error("Division by zero");
                     }
                     $stack->push(bcdiv($op1, $op2));
                     break;
                 case '^':
                     $stack->push(bcpow($op1, $op2));
                     break;
             }
             // if the token is a unary operator, pop one value off the stack, do the operation, and push it back on
         } elseif ($token == "_") {
             // if the token is a function, pop arguments off the stack, hand them to the function, and push the result back on
             $stack->push(-1 * $stack->pop());
         } elseif (preg_match("/^([a-z]\\w*)\\(\$/", $token, $matches)) {
             // it's a function!
             $fnn = $matches[1];
             // built-in function:
             if (in_array($fnn, $this->fb)) {
                 if (is_null($op1 = $stack->pop())) {
                     return $this->error("Internal error");
                 }
                 // for the 'arc' trig synonyms
                 $fnn = preg_replace("/^arc/", "a", $fnn);
                 if ($fnn == 'ln') {
                     $fnn = 'log';
                 }
                 if ($fnn == 'sqrt') {
                     $fnn = 'bcsqrt';
                 }
                 $val = $this->strictPrecision(call_user_func($fnn, $op1));
                 $stack->push($val);
             } elseif (array_key_exists($fnn, $this->f)) {
                 // get args
                 $args = array();
                 for ($i = count($this->f[$fnn]['args']) - 1; $i >= 0; $i--) {
                     if (is_null($args[$this->f[$fnn]['args'][$i]] = $stack->pop())) {
                         return $this->error("Internal error");
                     }
                 }
                 $stack->push($this->pfx($this->f[$fnn]['func'], $args));
                 // yay... recursion!!!!
             }
         } else {
             if (is_numeric($token)) {
                 $stack->push($this->strictPrecision($token));
             } elseif (array_key_exists($token, $this->v)) {
                 $stack->push($this->strictPrecision($this->v[$token]));
             } elseif (array_key_exists($token, $vars)) {
                 $stack->push($this->strictPrecision($vars[$token]));
             } else {
                 return $this->error("Undefined variable '{$token}'");
             }
         }
     }
     // when we're out of tokens, the stack should have a single element, the final result
     if ($stack->size() != 1) {
         return $this->error("Internal error");
     }
     return $stack->pop();
 }
開發者ID:schnauss,項目名稱:rutils,代碼行數:92,代碼來源:eval_math.php


注:本文中的Stack::size方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。