Home >Backend Development >PHP Tutorial >这样写为啥不对

这样写为啥不对

WBOY
WBOYOriginal
2016-06-23 13:33:031052browse

下图是我写的一个类中的方法,试图在同类中,在方法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)); 就可以了 应该


正解!!!!!!!!!!!!!!!!
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn