C&C++   发布时间:2022-04-03  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了c – 为什么在STL中允许使用未定义的行为?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
认情况下,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中允许使用未定义的行为?所遇到的程序开发问题。

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

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。