为什么从C ++ 11中删除了对范围访问?

如何解决为什么从C ++ 11中删除了对范围访问?

| 我只是发现,在某个时候,C ++ 11草案对
std::pair
具有
std::begin
/
std::end
重载,从而允许将一对迭代器视为适用于基于范围的for循环的范围(N3126,第20.3.5.5节),但这已被删除。 有谁知道为什么要删除它? 我发现删除非常不幸,因为似乎没有其他方法可以将一对迭代器视为一个范围。确实: 在基于范围的for循环中begin / end的查找规则说,begin / end在1)中作为范围对象的成员函数进行查找2)作为“关联名称空间”中的自由函数
std::pair
没有开始/结束成员功能 通常,ѭ4的唯一关联名称空间是名称空间std 不允许我们为
std::pair
超载
std::begin
/
std::end
我们不能将
std::begin
/
std::end
专门化为
std::pair
(因为专业化必须是局部的,而函数则不允许这样做) 还有其他我想念的方式吗?     

解决方法

        我认为,Alisdair Meredith于2009年发表的论文“ Pairs do n't good range”至少是答案的一部分。基本上,许多算法返回实际上不保证为有效范围的迭代器对。因此,似乎他们从for-range循环中删除了对
pair<iterator,iterator>
的支持。但是,建议的解决方案尚未完全采用。 如果确定某些迭代器确实代表一个有效范围,则可以将它们包装到提供begin()/ end()成员函数的自定义类型中:
template<class Iter>
struct iter_pair_range : std::pair<Iter,Iter> {
    iter_pair_range(std::pair<Iter,Iter> const& x)
    : std::pair<Iter,Iter>(x)
    {}
    Iter begin() const {return this->first;}
    Iter end()   const {return this->second;}
};

template<class Iter>
inline iter_pair_range<Iter> as_range(std::pair<Iter,Iter> const& x)
{ return iter_pair_range<Iter>(x); }

int main() {
    multimap<int,int> mm;
    ...
    for (auto& p : as_range(mm.equal_range(42))) {
       ...
    }
}
(未试) 我同意这有点疣。返回有效范围的函数(如equal_range)应使用适当的返回类型声明。我们不得不通过类似于上面的
as_range
进行手动确认,这有点尴尬。     ,        您可以使用
boost::make_iterator_range
。 它使用
begin()
end()
方法构造一个iterator_range。
boost::make_iterator_range
可以接受
std::pair
的迭代器。     ,        使用c ++ 11优化扩展上述答案:
#include <utility>

template<class Iter>
struct range_t : public std::pair<Iter,Iter> {
    using pair_t = std::pair<Iter,Iter>;
    range_t(pair_t&& src)
    : std::pair<Iter,Iter>(std::forward<pair_t>(src))
    {}

    using std::pair<Iter,Iter>::first;
    using std::pair<Iter,Iter>::second;

    Iter begin() const { return first; }
    Iter end() const { return second; }
};

template<class Iter>
range_t<Iter> range(std::pair<Iter,Iter> p) {
    return range_t<Iter>(std::move(p));
}

template<class Iter>
range_t<Iter> range(Iter i1,Iter i2) {
    return range_t<Iter>(std::make_pair(std::move(i1),std::move(i2)));
}


// TEST: 

#include <iostream>
#include <set>
using namespace std;

int main() {

    multiset<int> mySet { 6,4,5,3,67,8,89,7,45,3 };

    cout << \"similar elements: \";
    for (const auto&i : range(mySet.lower_bound(5),mySet.upper_bound(10))) {
        cout << i << \",\";
    }
    cout << \"\\n\";

    int count = 0,sum = 0;
    for (const auto& i: range(mySet.equal_range(5)))
    {
        ++count;
        sum += i;
    }
    cout << \"5 appears \" << count << \" times\\n\"
    << \"the sum is \" << sum << \"\\n\";

return 0;
}
    

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-