懒加载的一些小问题

懒加载是只有在调用的时候才会初始化,防止资源浪费。

1.重写对象的get方法,且必须写成成员变量的形式,即_hero的形式,这里主要是成员变量_hero与self.hero方法的区别,self会调用get方法,程序会陷入死循环

2.一定要判断是否为空,否则就会每调一次就初始化一次,失去了意义。

3.在需要使用get方法加载数据的时候,一定要使用self.hero调用,原因跟上面的一样,_hero是不会调用get方法的。

- (NSArray *)heros

{

    NSLog(@"wojaofjj");

    if (_heros == nil) {

        NSString *path = [[NSBundle mainBundle] pathForResource:@"heros" ofType:@"plist"];

        

        NSArray *arrayDic =[NSArray arrayWithContentsOfFile:path];

        

        NSLog(@"bb:%@",arrayDic);

        

        NSMutableArray *array = [NSMutableArray array];

        

        for (NSDictionary *dic in arrayDic) {

            GRRHero *hero = [GRRHero heroWithDic:dic];

            [array addObject:hero];

        }

        _heros = array;

    }

    return _heros;

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
selenium是一个自动化测试工具,可以模拟用户在浏览器中的操作。在爬虫中,selenium可以用来解决页面问题是指网页中的某些内容在页面时并不会立即出来,而是在用户滚动页面或者进行其他操作时才会。这样的话,如果我们直接使用传统的爬虫工具来获取网页内容,可能会丢失一些的内容,例如图片等。 使用selenium可以解决这个问题。selenium可以模拟用户的操作,包括滚动页面等。通过模拟用户的操作,我们可以触发页面的,将所有内容都出来,然后再进行爬取。 下面是一个使用selenium解决问题的示例代码: ```python from selenium import webdriver # 创建一个浏览器对象 driver = webdriver.Chrome() # 打开网页 driver.get("http://example.com") # 模拟滚动页面,直到所有内容都出来 while True: # 获取当前页面的高度 height = driver.execute_script("return document.documentElement.scrollHeight") # 模拟滚动到页面底部 driver.execute_script("window.scrollTo(0, document.documentElement.scrollHeight);") # 等待一段时间,让页面 time.sleep(2) # 获取新的页面高度 new_height = driver.execute_script("return document.documentElement.scrollHeight") # 如果新的页面高度和旧的页面高度相等,说明页面已经滚动到底部,退出循环 if new_height == height: break # 现在所有内容都出来了,可以进行爬取操作了 # ... # 关闭浏览器 driver.quit() ``` 通过以上代码,我们可以模拟滚动页面,直到所有内容都出来。然后我们就可以进行爬取操作了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值