首頁 >後端開發 >php教程 >这样写为啥不对

这样写为啥不对

WBOY
WBOY原創
2016-06-23 13:33:031054瀏覽

下图是我写的一个类中的方法,试图在同类中,在方法indexOp中调用同类的另一个方法reverse
但结果提示错误: 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)); 就可以了 应该


正解!!!!!!!!!!!!!!!!
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn