草庐IT

header_value

全部标签

c++ - 有没有办法包含 std::filesystem 的转发 header ?

与iostreams具有forward-includeheader的方式相同#include一个只有声明的header,我认为文件系统也会有一个。但是我找不到。我有一个类用filesystem::pathconst&声明了一个成员函数作为论点,把整个#include都带进来似乎有点矫枉过正。只是为了得到path.#include//or#include...structA{...voidsave(std::experimental::filesystem::pathconst&p);} 最佳答案 有这样的标题吗?没有。你能做这样的标

C++ : subtracting unsigned values is unsigned

这个问题在这里已经有了答案:IssubtractinglargerunsignedvaluefromsmallerinC++undefinedbehaviour?(2个答案)关闭3年前。在C++中,编译器提醒我减去无符号值是无符号的,因此调用abs()是没有意义的:uint64_ta,b;if(std::abs(a-b)>10){std::cout好的,我知道减法就是加法,而且我知道在我的实例中数字将小于2^63,所以我将static_cast转换为int64_t。但是调用abs的目的是为了避免写if(a-b>10||b-a>10){std::cout有没有更惯用的方法来做到这一点?

c++ - SCons、Boost::ASIO、Windows 预编译 header 和链接器错误

在为多个平台开发C++时,我正在研究在构建过程中使用SCons。我在构建配置中完成了99%,但我在Windows上遇到了一个非常奇怪的错误,该错误与预编译头文件有关。更奇怪的是,它只发生在一个项目上。在这个项目的SConscript文件中,我有以下内容可以在Windows上编译PCH:ifenv['PLATFORM']=='win32':env['PCH']=env.PCH('MyPCH-LSCommon.pch','Common/src/MyPCH.h')[0]env['PCHSTOP']='"MyPCH.h"'我还设置了编译器标志以强制在项目中的所有文件中包含MyPCH.h:ife

c++ - 有没有一种在 VS 中构建预编译 header 的方法不会使我的代码难以在 GCC 中构建?

过去,我在VC中使用预编译头文件来加快编译时间,但通常只在基本上只是一个小源代码目录的较小项目中使用。由于VC++要求所有文件都包含完全相同的header,而不管路径如何(比如“foo.h”而不是“../foo.h”),当你有不同的源代码嵌套目录时,事情就会变得很棘手。如果我所有的文件只是#include"foo.h"它可以工作,但只有当我打开预编译头文件时。为了在所有情况下都能正常工作,我需要制作虚拟的foo.h文件#include"../foo.h"这很快就会变得荒谬,尤其是当您有多个级别时。尽管我通常更喜欢Microsoft工具,但我不得不说GCC的系统(您可以手动将header

c++ - 具有不完整 Value 参数的 Boost.Iterator Facade

我正在尝试将boost::iterator_facade与不完整的Value一起使用模板参数。这失败了,因为iterator_facade正试图检查类型is_pod。这是预期的行为吗?我可以解决这个限制吗某种方式?我可以编写一个简单地代理foo和为它提供隐式转换,但我宁愿有一个更简单的解决方案。#includeclassiter:publicboost::iterator_facade{private:friendclassboost::iterator_core_access;voidincrement(){}boolequal(iterconst&other)const{retur

c++ - Notepad++ SourceCookifier 插件在大型 C++ header 上非常慢

我喜欢在Notepad++中浏览我的C++项目。我使用SourceCookifier插件以便轻松地在大文件的定义之间跳转。但是,如果我加载一个大的C++头文件(大约30.000行),里面有很多#define和typedef声明,它似乎挂起并需要很长时间加载时间。有谁知道是否可以设置任何选项以使其更快,或者这个插件通常不会加载这么多定义? 最佳答案 您可以通过将项目文件夹放入SourceCookifier面板来加速一切,同时(这是重要但记录不完整的部分)按下修改键(shift、ctrl或alt)。..forimportingINCLU

c++ - boost::spirit ,如何获取占位符的 "value"

我正在尝试构建一个接受格式为“/integer/(/integer/)”的字符串并生成一个std::tuple的解析器现在我有:qi::rule()>parser=(qi::int_>>'('>>qi::int_>>')')[_val=std::make_tuple(qi::_1,qi::_2)]无法编译,因为占位符qi::_i的类型不正确。如何从占位符中“提取”基础值? 最佳答案 嗯,你可以只使用自动属性传播(又名“自动规则”):#include#include#includenamespaceqi=boost::spirit::

c++ - 有效的 header 名称

我无法正确理解它们在以下文章中的含义:http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2004/n1566.htmItisinterestingtonotethatC89explicitlyallowedonlylettersinheaderandincludefilenames.C++addedunderscores,andC99addeddigits.Probablybothstandardsshouldallowboth.我在所有C和C++标准中发现了以下语句:ISO/IEC9899:19906.1.7HeadernamesS

c++ - 为什么这在 C++ 中抛出 "CryptoMaterial: this object contains invalid values",但在 python 中工作正常

我正在与Mega.co.nz的API交互,使用python库作为引用,并且此代码正在抛出。私钥属于临时账户。当我只使用第一个素数时它可以工作,但如果我包含第二个素数它会抛出,但在python代码中一切正常。此代码抛出“CryptoMaterial:此对象包含无效值”//g++test.cpp-otest-lcryptopp#include#include#include#includeusingnamespaceCryptoPP;constIntegerc("1085716632638270376006277952876684336882093057659821322727847155

c++ - 我如何从我的 maybe<> monad 中获取值(value)?

出于教育原因,我正在尝试在C++14中实现一个maybemonad。我(也许过于简单化)对monad的理解是,它们允许您将计算定义为一系列可组合的函数调用。维基百科关于monad的文章称它们为“可编程分号”,因为它们可以让您定义在一组谨慎的函数调用之间发生的事情。maybemonad是一个在发生故障时中断计算的monad。templatestructmaybe{maybe(constT&t):argument(t),valid(true){}maybe():argument(),valid(false){}Targument;boolvalid;};templatemaybejust(