草庐IT

construct_at

全部标签

c++ - C++11 中 map 标准的 at() const 访问器是什么?

我试图找出如何在const方法中从map返回一个值,我偶然发现了gcc4.6中map的at()方法。当我查看它时,我意识到它是非标准的:C++mapaccessdiscardsqualifiers(const)但它确实比find()方法要简洁得多。我想知道C++11是否已纠正此问题-at()formap是新标准的一部分吗? 最佳答案 是的。std::map在C++11中有一个at成员函数,其规范如下(23.4.4.3/9):T&at(constkey_type&x);constT&at(constkey_type&x)const;R

c++ - 当 std::map::at 超出范围时返回什么?

在游戏中,我想搜索元素map并返回位于棋盘特定方格上的元素。但是,如果广场是空的呢?(这些项目未存储在板结构中。为了这个问题的目的,不要介意。)我有下面的代码,但是我应该怎么做才能返回“空”引用?map,Item*>_items;Item&itemAt(introw,intcol)const{try{return*_items.at(make_pair(row,col));}catch(out_of_range&e){return//whatgoeshere?}}或者这是错误的方法,我应该只使用find()? 最佳答案 如果在您的程

c++ - 为什么 `at` 和 `operator []` 没有实现异构比较查找?

自C++14(N3657)成员函数模板find,count,lower_bound,upper_bound,关联容器的equal_range支持异构比较查找,但at和operator[]没有那些等效的成员函数模板。为什么会这样?例子:std::map>m;//...autoit=m.find("foo");//doesnotconstructanstd::stringauto&v=m.at("foo");//constructanstd::string 最佳答案 原则上没有合乎逻辑的理由。例如operator[]一个合理的语义可能是

c++ - std::is_constructible<void()>::value 的正确结果是什么?

std::is_constructible::value的结果不一致.我对该标准的解释是它应该是错误的。然而,Clang,同时具有libc++和libstdc++*,给出了true。GCC和MSVC都给出false。哪个结果是正确的?标准语这是标准的N4527[meta.unary.prop]/7:Giventhefollowingfunctiondeclaration:templateadd_rvalue_reference_tcreate()noexcept;thepredicateconditionforatemplatespecializationis_constructibl

c++ - 如何根据 is_nothrow_move_constructible<T> 声明包装类型 X<T> noexcept 的移动构造函数?

假设我有一个包装类型templatestructX{/*..*/};而且我不能只是X(X&&)=default因为我必须在那里做一些重要的事情。但是,我希望它是noexcept但前提是T(T&&)是noexcept。这可以使用::std::is_nothrow_move_constructible进行测试。我不知道如何根据constexpr有条件地启用构造函数的一个版本或另一个版本。我想可能有一种使用SFINAE的方法,但我不知道如何将其应用于ctors。 最佳答案 noexcept说明符接受任何bool常量表达式,因此您可以直接检

c++ - Clang 问题 : implicit type conversion at construction time

概要我正在努力使C++11代码与Clang兼容,并遇到了GCC>=4.6接受代码而Clang>=3.1不接受的情况。Clang认为候选构造函数不可行。详情这里是一个精简的例子来说明这个问题:#includetemplatestructT;templatestructT{typedefTsuper;constexprT(){}templateT(Args&&...){}};templatestructT:T{typedefTsuper;Headhead;T(Headarg):super(),head(std::move(arg)){}};structvoid_type{constexpr

c++ - libc++ is_copy_constructible 对我来说似乎是错误的

is_copy_constructible的libc++实现是这样的:templatestruct_LIBCPP_TYPE_VIS_ONLYis_copy_constructible:publicis_constructible::type>{};is_copy_constructible的C++规范很简单:std::is_copy_constructiblespecification:std::is_constructible::valueistrue.但是,上面的实现不就是实现了T&const而不是constT&吗?将const应用于add_lvalue_reference应该没有

c++ - 检查 string.at(i) 是否为空白 C++

我想检查char(string.at(i))在C++中是否为空白。我怎样才能轻松做到这一点?我得到了这个代码示例,我想用一些东西来改变_____,但不知道是什么。我试过使用'',但没有成功。for(inti=0;i 最佳答案 #includeif(isspace(string.at(i))) 关于c++-检查string.at(i)是否为空白C++,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/qu

c++ - "Looking At"具有四元数的对象

所以我目前正在尝试创建一个函数,它将采用两个3D点A和B,并为我提供代表A点“观察”B点所需的旋转的四元数(这样点A的局部Z轴穿过点B,如果你愿意的话)。我最初找到了thispost,其中的最佳答案似乎为我提供了一个很好的起点。我继续执行以下代码;正如原始答案所暗示的那样,我没有假设默认的(0,0,-1)方向,而是尝试提取表示相机实际方向的单位vector。voidCamera::LookAt(sf::Vector3Target){///Derivedfrompseudocodefoundhere:///https://stackoverflow.com/questions/13014

51单片机定时器。实验(六):定时器实验:使用AT89S51单片机的定时器/计数器T1控制LED每隔3秒点亮一次(即亮3秒,灭3秒,如此反复)

目录题目:proteus仿真:代码:分析题目:定时器:工作方式寄存器TMOD设置:控制寄存器TCON设置:设定计数初值: 定时器四种工作方式:实验过程讲解:配置定时器:设置TMOD寄存器设定定时器初值:THx和TLx(x=0,1)设置IE寄存器:启动定时器:中断检测:题目:使用51单片机的定时器/计数器T1控制LED每隔3秒点亮一次(即亮3秒,灭3秒,如此反复)proteus仿真: 本实验涉及的Proteus文件以及程序源码均在Github上免费下载https://github.com/iceacream/C_CODE.git代码:#includesbitLED1=P1^5;chari=100