草庐IT

unnamed-namespace

全部标签

c++ - 记录跨越多个文件的 namespace doxygen

假设我有2个头文件。//HEADER1/***DocforFoohere?*/namespaceFoo{classThis{...};}&&//HEADER2/***DocforFoohere?*/namespaceFoo{classThat{...};}在使用Doxygen记录时我应该如何处理这个问题? 最佳答案 也许两者都不是。例如,假设您有"/utility/header1.hpp"其内容在namespaceutility中和"/utility/header2.hpp"这也是。您可以添加一个文件:"/utility.hpp"其

c++ - namespace std 在哪里定义的?

我想看一下命名空间std的内部,但是我无法在我的计算机上真正找到定义它的文件。我试着用谷歌搜索这个但是,我没有太多运气。 最佳答案 在大多数Unix系统上,C++header通常存储在/usr/include/c++//中,其中是GCC/libstdc++版本(即4.9或4.9.2),或者是libc++版本即v1.该目录中包含所有(或大部分?)标准规定的header,它们大多只是普通的C++代码。对于libstdc++,请特别注意大多数较旧的header仅包含bits/中的内容。;很少有特定于C++11的header执行此操作。

C++11/g++:lambda 中需要 std::qualifier,尽管给出了 "using namespace std"

我试图发现新的C++11标准(使用g++4.6.2)的一些优点。在“all_of”算法函数中使用lambda时,我遇到了一个关于std::限定符的奇怪问题。我正在“使用”代码片段开头所示的std命名空间。这使得for循环中pair变量的声明定义明确。但是,我在“all_of”算法中使用的lambda参数中尝试了相同的方法。在我意识到完整的std::合格的std::pair可以在那里工作,但只有pair不行之前,我遇到了几个难以理解的错误消息。我是否遗漏了重要的一点?lambda的声明发生在这个文件中,所以命名空间在这里应该仍然有效,对吧?或者所需的std::限定符是否依赖于不同文件中的

c++ - 编译错误error C2039 : 'clock_t' : is not a member of '` global namespace''

我在VS2010中使用boost1_53进行编译。我也在使用boost的线程。在编译过程中我遇到了一堆这样的错误c:\programfiles(x86)\microsoftvisualstudio10.0\vc\include\ctime(18):errorC2039:'clock_t':isnotamemberof'`globalnamespace''所有错误都是关于ctime和c_time.hpp。我四处寻找解决方案但没有成功。谁能帮忙吗?这里是部分代码。#defineBOOST_THREAD_USE_DLL#include#include#include#include#incl

c++ - 当内部范围不起作用时,为什么编译器不采用 namespace 名称?

我认为我非常了解名称查找(在观看了几个有关它的视频并阅读了大量内容之后)但我只是遇到了这种情况:#includenamespacetest{structId{};voiddo_something(constId&){std::cout尖线不编译(在GCC4.8和VC11U2上)因为它试图使用成员函数test::Test::do_something()而不是命名空间作用域的test::do_something(constId&)这似乎是唯一可能的候选对象。显然,成员函数名称隐藏了命名空间范围内的名称,这让我感到惊讶,因为我记得在其他上下文中使用了几乎相似的代码而没有产生这个问题(但最终情

c++ - 氧气/C++ : how to link to anonymous namespace variables

我正在使用Doxygen来记录我的代码。许多代码在定义常量的cpp文件中都有匿名namespace。我已经设置:EXTRACT_ANON_NSPACES=YES在我的Doxygen文件中,所有匿名命名空间都按需要进行了记录。我的问题是我想引用匿名命名空间中的变量。例如,假设其中一个命名空间在我的Doxygen文档中定义在MyClass::anonymous_namespace{MyFile.cpp}::kMyConstant下。我认为另一个注释block(例如,一个函数)可以链接到该常量,例如:@seeMyClass::anonymous_namespace{MyFile.cpp}::

c++ - boost 是否使用 C++11 "inline namespaces"来避免运行时出现 ABI 不兼容错误?

C++11具有称为“内联命名空间”的功能,它允许作者在链接时强制执行ABI兼容性,而无需篡改API。例如,来自@HowardHinnant的这些有用的答案解释了libc++如何使用内联命名空间:Usinglibstdc++compiledlibrarieswithclang++-stdlib=libc++Whycan'tclangwithlibc++inc++0xmodelinkthisboost::program_optionsexample?我的问题是:boost是否利用了这个C++11特性?看起来一些boost开发者至少是thinking最终一次使用它。但是那个线程很旧。它曾经发

c++ - 声明 `using namespace C;` 对于证明 [namespace.udir]/3 中示例中显示的结果至关重要

据我所知,usingnamespaceC;下面在namespaceD中的声明对于编译器提示歧义是必要的qualified-idsB::C::i和A::i在下面的代码中,这是一个例子[namespace.udir]/3中的C++标准:namespaceA{inti;namespaceB{namespaceC{inti;}usingnamespaceA::B::C;voidf1(){i=5;//OK,C​::​ivisibleinBandhidesA​::​i}}namespaceD{usingnamespaceB;//usingnamespaceC;voidf2(){i=5;//ambi

c++ - 全局范围内的匿名 namespace 内的名称可以有前导下划线吗?

根据规范,不允许使用前导下划线的全局名称:17.4.3.1.2Globalnames—Eachnamethatbeginswithanunderscoreisreservedtotheimplementationforuseasanameintheglobalnamespace.这是否也适用于在顶级匿名命名空间中定义的名称? 最佳答案 以前导下划线开头,后跟非大写字母数字字符且不包括双下划线的名称仅在全局命名空间中保留。这样做的原因是在某些系统上某些名称需要有一个前导下划线或者已经被底层操作系统和/或其C库使用。匿名命名空间中的名称

c++ - 为什么类型特征不适用于 namespace 范围内的类型?

我正在为我的C++序列化库设计类型注册功能。但是我遇到了一个关于类型特征的奇怪问题。我正在使用VisualStudio2017和/std:c++latest。#includeintreg(...);templateconstexprboolis_known=!std::is_same_v;//-----fortype1inglobalscope------structtype1{};voidreg(type1*);static_assert(is_known);//success//-----fortype2innamespacescope----namespacens{structt