草庐IT

c++ - 将 `_[a-z0-9]`开头的标识符以 `using`导入全局命名空间是否定义明确?

整个问题都符合标题。C++14[global.names]是这样说的Eachnamethatbeginswithanunderscoreisreservedtotheimplementationforuseasanameintheglobalnamespace.但我不太清楚是否遵循namespaceN{void_foo(){}}usingN::_foo;是否违反规则。 最佳答案 这不是很明显吗?您的代码将一个以下划线开头的名称放入全局namespace,这些名称保留供实现使用。不要那样做。如果实现在全局命名空间中有_foo,这将产生

c++ - 海湾合作委员会 : C++11 inline object initialization (using "this") does not work when there is a virtual inheritance in hierarchy

当在初始化中使用此指针并且在层次结构中存在虚拟继承时,C++11内联对象初始化不起作用(在GCC中)。这可能是GCC的错误吗(因为它在CLang中工作)?还是C++11标准本身的差距?示例(可以在here中尝试),当使用GCC编译以下代码时:FieldIndexm_inB{"inB",this};不会被执行。但它会在使用CLang编译时执行。变通方法:从FieldIndexContainer派生A作为虚拟#include#include#includeusingnamespacestd;classFieldIndexContainer{public:classFieldIndex{pu

c++ - 在我的命名空间中公开外部库类时使用 typedef 或 using 关键字

我想将外部库中的类公开给我库的用户。具体来说,我想将类“导入”到我的命名空间中,这样用户就不需要知道我在幕后使用的是什么库。通常,我似乎可以通过使用typedef或简单地通过using类来完成此操作。是否有任何理由选择一种方法而不是另一种方法(或做其他事情)?(我的学历好像有点差距:))例如:我想创建一个使用Boost::Asio的串口管理器。namespaceMySerialManager{//shouldIuseatypedeftypedefboost::asio::serial_port_base::flow_controlflow_control;//orausing...us

c++ - Using Declaration 和 Forward Declaration 之间的冲突

让我们和Bulldog一起去散步:)假设我有一个命名空间Street::House(在命名空间Street内),其中类Bulldog被声明(让它在House/Bulldog.hpp中):namespaceStreet{namespaceHouse{classBulldog{};}}然后,我有Bulldog.hpp:#include"House/Bulldog.hpp"namespaceStreet{usingHouse::Bulldog;}注意正在发生的事情:我将Street::House::Bulldog的声明注入(inject)到命名空间Street作为Street::Bulldo

c++ - 测试 C++ 代码 : Using test libraries

我学习C++有一段时间了,但这是我第一次接触C++项目(宠物配置解析器库)。我正在使用GoogleC++TestingFramework来测试这个。但我不知道我这样做是否正确。目前,我已经剥离了这个Google测试库的一些部分并将其放入我的项目Test/googletest目录中。它工作正常,但我想知道我是否应该这样做。我在我的项目中包含了测试框架的源代码,它将与我的代码一起发布。这让我感到不舒服。我浏览了someC++projectsonGitHub,试图看看其他人如何处理这个问题。有些有自定义框架,大多数根本不测试代码就解决了整个问题。我想知道我是否做对了,或者我怎样才能采用一种测

c++ - 错误 : incomplete type when using HMAC_CTX in C++ project

我正在尝试编译这个库ndn-cxx在我的笔记本电脑里。我已经在另一台计算机上尝试过并且编译成功但现在我收到此错误并且我认为它与openssl相关。我使用sudoapt-cachesearchlibssl|确认我的笔记本电脑中有openssl|grepSSL结果是:libssl-ocaml-OpenSSL的OCaml绑定(bind)(运行时)libssl-ocaml-dev-OpenSSL的OCaml绑定(bind)libssl0.9.8-SSL共享库libsslcommon2-企业消息传递系统-通用SSL库libsslcommon2-dev-企业消息系统-通用SSL开发文件我在尝试编译

c++ - 如何使 exuberant-ctags 解析 "using"样式的 typedef?

如何让ctags解析using类型别名,如下所示?usingFooPtr=std::shared_ptr;它只选取那些用typedef声明的。 最佳答案 从Exuberant-ctags派生的Universal-ctags(https://ctags.io)在C++源文件中处理“使用”:[jet@localhost]/tmp%cat/tmp/foo.cppusingFooPtr=std::shared_ptr;[jet@localhost]/tmp%u-ctags-o-/tmp/foo.cppFooPtr/tmp/foo.cpp/^

c++ - 使用 'using' 关键字获取指向类方法的指针

我使用的是VisualStudio2010。为什么我无法获得指向子类中“升级”为public的类方法的指针?以下代码无法编译:#include#includeclassParent{protected:voidfoo(){std::coutf=std::bind(&Child::foo,&c);f();return0;}它给出了错误:errorC2248:'Parent::foo':cannotaccessprotectedmemberdeclaredinclass'Parent' 最佳答案 编译here.我想你只是忘了在你的编译器

c++ - g++ : Using singleton in an embedded application

我正在使用C++中的GNUARM工具链使用GCC4.8为CortexM3开发嵌入式应用程序。该应用程序使用了一些通过函数局部静态变量实例化的单例,就像这样(真实代码):GlobalDataTypeRegistry&GlobalDataTypeRegistry::instance(){staticGlobalDataTypeRegistryinst;returninst;}这是在C++中实现单例的经典方法。问题是一旦我使用这种实例化,输出代码大小就会激增,这显然意味着编译器/链接器添加了一些服务代码以正确初始化/销毁单例对象。这是允许重现问题的最小示例:这将编译成66k代码(-Os):s

c++ - 地址 sanitizer : "SEGV on unknown adress" when using throw-catch and printf

当我扔东西时,例如一个int或一个charconst*,并使用printf检查错误,我得到一个AddressSanitizerError。我无法在网上找到任何类似的东西,而且我的代码示例非常基础,以至于我真的不明白它怎么可能会产生错误。精简代码示例:#includeintmain(){try{throw42;}catch(intmsg){printf("%d\n",msg);}return0;}运行代码时的控制台输出:ASAN:SIGSEGV===================================================================16533=