
从我的理解,为什么它是未定义的行为的原因是为了保持无瑕疵的保证.我的推理是,对于std :: vector的operator []具有无抛出保证,如果容器大小大于N,则为()())具有强大的保证,并且如果n不在,则抛出std :: out_of_range界限.
所以我的问题是,一些可能未定义的行为背后的理由是什么,而不是有一个强有力的保证,而是抛出异常呢?
解决方法 当允许未定义的行为时,通常是为了效率的原因.如果标准规定了当您将数组从边界访问时会发生什么,它将强制执行检查索引是否在边界内.一个向量也是一样,它只是一个动态数组的包装器.
在其他情况下,允许这种行为是未定义的,以便实现自由.但是,这也是真正的效率(因为一些可能的实施策略可能在一些机器上比在其他机器上更有效率,而C将其放在实施者身上,以选择最有效的策略,如果他们愿意的话).
总结以上是内存溢出为你收集整理的c – 为什么在STL中允许使用未定义的行为?全部内容,希望文章能够帮你解决c – 为什么在STL中允许使用未定义的行为?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)