- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
所以,为了让代码如
auto vect = ...;
auto it = vect.begin(), end = vect.end(); // want const_iterator, getting iterator
选择正确的 begin()
和 end()
重载,即使对于非常量容器,更明确的 cbegin()
/cend()
添加了函数。
为什么到此为止?
关联容器有一个 find()
方法有同样的问题。序列容器有 front()
和 back()
,同样有同样的问题。
这些缺失是明确的 const 版本遗漏,还是设计使然?
最佳答案
更广泛的 API 是有成本的,即使只是在寻找您想要的功能时跳过它也是如此。
template<class T>
T const as_const(T&& t) noexcept(noexcept(T(std::declval<T>())) {
return std::forward<T>(t);
}
template<class T>
T const& as_const(T& t) noexcept {
return t;
}
做你想做的大部分事情。它甚至会使 cbegin
过时。
(基于下面@T.C 提供的 n4380 对上面的代码进行的修改。代码不同,因为我认为 n4380 在 T&&
的情况下略有错误。)
关于c++ - 给定 cbegin()、cend(),为什么没有 cfront()、cback()、cfind()、...?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30455629/
以下代码使静态断言失败: #include #include #include int main() { int theArr[] = { 1, 2, 3, 4, 5, 6, 7, 8,
我已经在映射的键上定义了两个迭代器: template struct MapKeyIterator : MyMap::iterator { using Base = typename MyMa
我想知道为什么在 C++11 中引入了 cbegin 和 cend ? 在哪些情况下调用这些方法与 begin 和 end 的 const 重载有区别? 最佳答案 这很简单。假设我有一个 vector
正如标题所说,我知道cbegin() 到一个unordered_map 具有常数复杂度,但是是常数复杂度的迭代器的迭代。例如:cbegin()++; c开始()+ 10; c开始()+我; cend(
我有一个类,我们称它为 ConstVector,它只定义 cbegin/cend 而不是 begin/end,因为我不想在构造后对其成员进行修改。我尝试像这样使用基于范围的 for 循环: Const
所以我可以这样做: for(const auto i : { 13, 42 }) cout (cout, " ")); 它给我错误: error: no matching function for c
这个问题指的是: When should I use the new ranged-for and can I combine it with the new cbegin/cend? 基于那个问题,
C++11引入了没有constexpr-说明符的std::begin()非成员函数,然后C++14更新为constexpr- std::begin() 用于数组类型 (T (&)[N]) 并附加 co
Qt 5.0 在不同的容器类中引入了迭代器方法cbegin() 和cend(),例如QList。或 QMap . 但是这些类中也有 constBegin() 和 constEnd() 方法。 所有这些
这个问题已经有答案了: What is the difference between cbegin and begin for vector? (2 个回答) 已关闭 5 年前。 虽然当我们遍历beg
我正在尝试计算 vector 中长度大于 6 的字符串的数量。这非常简单,但我正在尝试使用 algorithm 库中的 count_if 来完成。所以这是我的代码: int string_size_c
Scott Mayers 的“Effective Modern C++”中的第 13 条指出,const_iterators 优于迭代器。我同意,但我也想使用非成员函数而不是成员函数。根据这本书,在
如果我取消注释该行,有人可以解释为什么以下内容无法编译吗foo::const_iterator j = f.begin();,但是如果我使用行 foo::const_iterator j = f.cb
哪个版本的 gcc 编译器支持容器的免费 const_iterator 方法,例如:cbegin、cend、crbegin,crend。我使用带有 -std=c++0x 标志启用的 c++0x 功能的
当然,C++11 中新的 ranged-for 将非常简洁和有用。据我了解它是如何工作的,它通过尝试 *Argument-Depending-Lookup"( ADT)。 但另一个补充是,所有容器 现
如果 std::initializer_list 中的元素总是 const 值,为什么我们有像 begin()/end() 这样的模板方法而不是 cbegin()/cend()?这个名称(按照惯例,与
成员(member)begin有两个重载,其中之一是 const_iterator begin() const;。还有cbegin const_iterator cbegin() const noex
我不得不编写 C++11 代码,但我想使用 std::cbegin()。所以,我正在查看 GCC 5.4.0 的实现,在我的系统上的 /usr/include/c++/5/bits/range_acc
所以,为了让代码如 auto vect = ...; auto it = vect.begin(), end = vect.end(); // want const_iterator, getting
cppreference为 std::cbegin 显示此签名: template constexpr auto cbegin( const C& c ) -> decltype(std::begin
我是一名优秀的程序员,十分优秀!