Guru of the Week 条款03: 使用标准库

 

GotW #03 Using the Standard Library (or, Temporaries Revisited)

著者:Herb Sutter     

翻译:kingofark

[声明]:本文内容取自www.gotw.ca网站上的Guru of the Week栏目,其著作权归原著者本人所有。译者kingofark在未经原著者本人同意的情况下翻译本文。本翻译内容仅供自学和参考用,请所有阅读过本文的人不要擅自转载、传播本翻译内容;下载本翻译内容的人请在阅读浏览后,立即删除其备份。译者kingofark对违反上述两条原则的人不负任何责任。特此声明。

Revision 1.0

Guru of the Week 条款03: 使用标准库(或者说,再次造访临时对象)

 

难度:3 / 10

 

(使用标准库的算法要比使用自己徒手编写的算法实现好得多。这里我们将重新使用GotW 条款02中的例子,借以说明,通过简单的复用(reuse)那些标准库里面已有的东西,将会避免多少麻烦的问题。)

 

 

[问题]

 

一旦程序员使用标准库算法而不是编写自己的算法版本时,首先就可以避免GotW条款02中的多少个缺陷?(注意:和上次一样,不能改变函数的语义,即使这样做可以改良函数本身。)

 

[版本翻新]

 

原始的错误版本:

 

  string FindAddr( list<Employee> l, string name )
  
  
  {
  
  
    for( list<Employee>::iterator i = l.begin();
  
  
         i != l.end();
  
  
         i++ )
  
  
    {
  
  
      if( *i == name )
  
  
      {
  
  
        return (*i).addr;
  
  
      }
  
  
    }
  
  
    return "";
  
  
  }
  
  

 

修正的版本(仍然存在对l.end()多余的调用):

 

  string FindAddr( const list<Employee>& l,
  
  
                   const string& name )
  
  
  {
  
  
    string addr;
  
  
    for( list<Employee>::const_iterator i = l.begin();
  
  
         i != l.end();
  
  
         ++i )
  
  
    {
  
  
      if( (*i).name == name )
  
  
      {
  
  
        addr = (*i).addr;
  
  
        break;
  
  
      }
  
  
    }
  
  
    return addr;
  
  
  }
  
  

 

 

[解答]

 

不需要什么别的改变,只要简单的使用find()就可以避免产生两个临时对象和原始版本中几乎所有l.end()带来的低效:

 

  string FindAddr( list<Employee> l, string name )
  
  
  {
  
  
    list<Employee>::iterator i =
  
  
      find( l.begin(), l.end(), name );
  
  
 
  
  
    if( *i != l.end() )
  
  
    {
  
  
      return (*i).addr;
  
  
    }
  
  
    return "";
  
  
  }
  
  

 

再进行一些其它的修正,得到:

 

  string FindAddr( const list<Employee>& l,
  
  
                   const string& name )
  
  
  {
  
  
    string addr;
  
  
    list<Employee>::const_iterator i =
  
  
      find( l.begin(), l.end(), name );
  
  
 
  
  
    if( i != l.end() )
  
  
    {
  
  
      addr = (*i).addr;
  
  
    }
  
  
    return addr;
  
  
  }
  
  

 

[学习指导]:请复用标准库的算法,而不要编写自己的算法版本。这样做更快、更容易、更安全!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Guru Meditation Error: Core 1 panic'ed (Interrupt wdt timeout on CPU1).这个错误的原因是中断看门狗在CPU1上超时。中断看门狗是一种用于监视程序运行情况的机制,当程序在规定的时间内没有完成任务时,中断看门狗会触发重启系统。在这种情况下,可能是由于中断函数中的阻塞操作导致了中断看门狗的超时。根据错误信息显示,在中断函数`onTimer()`中使用了阻塞性函数`Serial.println()`,推测是由于中断阻塞导致没有及时喂狗而触发了重启。此外,错误信息中还提到了调试异常的原因是堆栈金丝雀(watchpoint)触发了,这可能是由于任务(task_name)的堆栈溢出导致的。为了解决这个问题,我们可以考虑以下解决方案: 1. 在中断函数中尽量避免使用阻塞性函数,特别是在低优先级的中断服务程序中 2. 确保中断服务程序尽快完成任务,以避免中断看门狗的超时 3. 检查任务的堆栈使用情况,确保没有堆栈溢出的问题 4. 调整中断看门狗的超时时间,使其能够适应程序的运行情况 5. 可以考虑使用RTOS的任务管理机制,以提高系统的稳定性和可靠性 通过以上的解决方案,我们可以尝试修复Guru Meditation Error: Core 1 panic'ed (Interrupt wdt timeout on CPU1)这个错误。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [[esp32] Guru Meditation 错误解析及解决方案](https://blog.csdn.net/weixin_42942530/article/details/103975237)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [【踩坑日记】ESP32触发定时器中断后无限重启](https://blog.csdn.net/Beihai_Van/article/details/125793806)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

kingofark

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值