c – 为什么在STL中允许使用未定义的行为?

c – 为什么在STL中允许使用未定义的行为?,第1张

概述默认情况下,std :: stack的“底层容器”是一个std :: deque.因此,对于std :: deque而言,任何未定义的行为都是std :: stack的未定义行为. cppreference和其他站点在描述成员函数的行为时“有效地”使用术语.我认为这是为了所有的意图和目的.因此,调用top()和pop()等效于回调()和pop_back(),并在空容器上调用这些是未定义的行为. 从 默认情况下,std :: stack的“底层容器”是一个std :: deque.因此,对于std :: deque而言,任何未定义的行为都是std :: stack的未定义行为. cppreference和其他站点在描述成员函数的行为时“有效地”使用术语.我认为这是为了所有的意图和目的.因此,调用top()和pop()等效于回调()和pop_back(),并在空容器上调用这些是未定义的行为.

从我的理解,为什么它是未定义的行为的原因是为了保持无瑕疵的保证.我的推理是,对于std :: vector的operator []具有无抛出保证,如果容器大小大于N,则为()())具有强大的保证,并且如果n不在,则抛出std :: out_of_range界限.

所以我的问题是,一些可能未定义的行为背后的理由是什么,而不是有一个强有力的保证,而是抛出异常呢?

解决方法 当允许未定义的行为时,通常是为了效率的原因.

如果标准规定了当您将数组从边界访问时会发生什么,它将强制执行检查索引是否在边界内.一个向量也是一样,它只是一个动态数组的包装器.

在其他情况下,允许这种行为是未定义的,以便实现自由.但是,这也是真正的效率(因为一些可能的实施策略可能在一些机器上比在其他机器上更有效率,而C将其放在实施者身上,以选择最有效的策略,如果他们愿意的话).

总结

以上是内存溢出为你收集整理的c – 为什么在STL中允许使用未定义的行为?全部内容,希望文章能够帮你解决c – 为什么在STL中允许使用未定义的行为?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/1249187.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-07
下一篇2022-06-07

发表评论

登录后才能评论

评论列表(0条)

    保存