这样写为啥不对
但结果提示错误: Fatal error: Call to undefined function reverse() in D:\WWW\shop\control\index.php on line 12
当然这句话的提示说是发现reverse函数没有定义,
可我明明定义了哈,难道哪里不有不符合规范的地方吗
回复讨论(解决方案)
问题是reverse(substr($str,1));这里没找到吧
self::reverse(substr($str,1));
问题是reverse(substr($str,1));这里没找到吧
self::reverse(substr($str,1));
我试了一下,把reverse函数中全去掉,只剩一个空壳就不报错了,但是问题来了,我这里是想用递归,难道说类中不能写递归的方法吗
把self::换成$this->
#1 已经明确的告诉你了,为什么就视而不见呢?
方法没有作用域就变成函数了
现在原因已明,问题是哪何解决
问题是reverse(substr($str,1));这里没找到吧
self::reverse(substr($str,1));
他不是已经高数你写作 self::reverse(substr($str,1)); 了吗?
问题是reverse(substr($str,1));这里没找到吧
self::reverse(substr($str,1));
他不是已经高数你写作 self::reverse(substr($str,1)); 了吗?
我试了self::还是上面那个提示
贴出你的代码,不要截图
方法 reverse()中存在 递归调用!
照着写了一个没有问题的
class indexControl{ public function reverse($str) { if(strlen($str)>0) { self::reverse(substr($str,1)); echo substr($str,0,1); return; } } public function indexOp() { self::reverse("adfdsfd"); }}indexControl::indexOp();
是不是受你框架的影响呢
另外,如果你只是单纯的想倒置字符串,可以用 strrev 函数,没必要递归
你在reverse方法里面还有一个方法reverse(substr($str,1)); 是这个方法报错了,改成self::reverse(substr($str,1)); 或者$this->reverse(substr($str,1)); 就可以了 应该
你在reverse方法里面还有一个方法reverse(substr($str,1)); 是这个方法报错了,改成self::reverse(substr($str,1)); 或者$this->reverse(substr($str,1)); 就可以了 应该
正解!!!!!!!!!!!!!!!!
上一篇: 长尾理论不是颠覆性的概念
下一篇: [原创]ajax 实现用户注册功能教程二