php 递归解析


function test($i){//第一步
	$i  -= 4; 
	if($i<3){ 
		return $i; //第二部
	}else{ 
		test($i); //第三部
	} 
} 
echo test(10); 
</pre><pre code_snippet_id="667672" snippet_file_name="blog_20150515_2_1499735" name="code" class="html">最下面的第一段代码作为例子,写这样代码的人可以没完全理解递推,下面使用test(10)调用,在执行过程中,如果条件成立,则直接返回结果,如果条件不成立则继续调用test(),猛一看这样写没问题,其实,当第一次调用条件不成立时再调用一次时,即使成立也没用返回值,第二段代码是两次调的结果:假如在第二次调用,代码执行到第四步时结果成立,他的动作是return 2;  现在代码成什么样子了呢,看下面
function test($i){//第一步
	$i  -= 4; 
	if($i<3){ 
		return $i; //第二部
	}else{ 
		2;
	} 
} 
echo test(10); 

只有一个单独的2,他要怎么返回到下面呢,前面要加一个return ;

所以完整的代码应该是这样的。

function test($i){//第一步
	$i  -= 4; 
	if($i<3){ 
		return $i; //第二部
	}else{ 
		return test($i);
	} 
} 
echo test(10); 

function test($i){//第一步
<span style="white-space:pre">	</span>$i  -= 4; 
<span style="white-space:pre">	</span>if($i<3){ 
<span style="white-space:pre">		</span>return $i; //第二步
<span style="white-space:pre">	</span>}else{ 
<span style="white-space:pre">		</span>function test($i){//第 3步
<span style="white-space:pre">			</span>$i  -= 4; 
<span style="white-space:pre">			</span>if($i<3){ 
<span style="white-space:pre">				</span>return $i; //第4步
<span style="white-space:pre">			</span>}else{ 
<span style="white-space:pre">				</span>test();//第5步
<span style="white-space:pre">			</span>} 
<span style="white-space:pre">		</span>} 
<span style="white-space:pre">	</span>} 
} 
echo test(10); 







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用PHP递归爬取整个网站,你可以按照以下步骤进行操作: 1. 创建一个爬虫函数,该函数接收一个URL参数,并执行以下操作: - 发送HTTP请求,获取网页的HTML内容。 - 解析HTML内容,提取你感兴趣的数据。 - 处理数据或保存数据到数据库、文件等。 - 查找页面中的其他链接,并将它们添加到一个链接队列中,以便后续处理。 2. 创建一个链接队列,用于存储待爬取的链接。 3. 初始化链接队列,将初始URL添加到队列中。 4. 创建一个已访问的URL集合,用于避免重复访问相同的页面。 5. 使用一个循环来处理链接队列中的链接,直到队列为空: - 从链接队列中取出一个链接。 - 检查该链接是否已经访问过,如果是则跳过。 - 调用爬虫函数,传递该链接作为参数。 - 在爬虫函数中,将页面中提取到的其他链接添加到链接队列中。 - 将当前链接添加到已访问的URL集合中。 这样,你的爬虫将按照深度优先或广度优先的方式递归爬取整个网站。通过不断从链接队列中取出链接,并将新的链接添加到队列中,你可以遍历网站上的所有页面。 请注意,在编写爬虫时要遵守网站的爬虫规则和法律法规,以确保合法和合规的爬取行为。此外,为了避免陷入无限循环或爬取重复页面的问题,你可能需要添加一些去重机制或限制爬取深度的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值