草庐IT

c++ - 扩展编译器以在编译时评估 "complicated"函数(具有已知输入值),超出 `constexpr` 范围

请看thisexample.尝试使用constexpr获得编译时评估将是极其困难的,如果不是不可能的话。但是,在调用函数的地方,所有参数在编译时都是已知的。理论上,(存在一些优化属性?),编译器可以暂停解析,创建一个带有函数的小程序,编译它,运行它,并得到结果以创建一个char常量以用于主程序编译.我知道其中一个问题是交叉编译:如果编译器可以构建一个可以在正在构建的机器上运行的程序,那么你只能从编译器运行一个程序。但这似乎并非无法克服。毫无疑问:我不是第一个想到它的人。但我尝试搜索,但只能找到constexpr和template东西。将来有没有计划在任何编译器中实现这样的功能?该功能也

c++ - 当使用静态成员将共享库静态链接到可执行文件时,我在 UNIX 和 WIN 上收到不同的结果。请解释为什么?

请考虑以下代码和平://1.Singleheaderfile.Imaginethatitissomestaticlibrary.//Counter.h#pragmaoncestructCounter{Counter(){++getCount();}staticint&getCount(){staticintcounter=0;returncounter;}};//2.Sharedlibrary(!)://main_DLL.cpp#include#include"counter.h"extern"C"{__declspec(dllexport)//forWINvoidmain_DLL()

c++ - 与外部库链接时出现 GCC "multiple definition"错误

我正在尝试使用一个库(Watt-32,如果相关),但由于某种原因无法链接。我已经编译了这个库,作为一个快速的“helloworld”测试,我正在尝试编译以下文件:#includeintmain(){sock_init();}这会导致GCC在库自己的源文件中生成长多重定义错误列表:D:\projects\test-tcp>c++-Iincludetest-tcp.cpp-Llib-lwattlib\libwatt.a(rs232.o):Infunction`_ntohl':D:\msys64\home\JW\watt32\src/../inc/sys/swap.h:63:multiple

c++ - 用于 Arduino IDE (xtensa-lx106-elf-gcc) 和 std::map 链接错误的 ESP8266

是否可以将ESP8266的map用于Arduino包?这是我的代码:#includetypedefstd::mapItems;voidsetup(){Itemsitems;items[2]=5;//items.emplace(4,5);}voidloop(){}这是编译/链接错误:Arduino:1.6.5(Windows8.1),Board:"GenericESP8266Module,Serial,80MHz,40MHz,DIO,115200,512K(64KSPIFFS)"sketch_oct31a.cpp.o:Infunction`loop':C:\ProgramFiles(x8

c++ - Gtest : Expected Class-Name Before '{'

我正在尝试将Gtest下的测试用例转换为使用测试夹具,以便在添加更多测试时可以使用通用设置。但是,这会导致错误:test_integrate.cc:4:47:error:expectedclass-namebefore'{'tokenclassIntegratorTest:public::testing::test{这种失败是我无法理解的,因为根据我的经验,它通常是由循环导入引起的,并且导入与工作代码相比没有变化。完整代码如下:#include"gtest/gtest.h"#include"utils/integrate.hpp"classIntegratorTest:public::

c++ - 什么是 C/C++ 中的魔术函数(关于 OpenMP)

目前正在查看this将OpenMP与C/C++程序结合使用的指南,并想知道下面引述中的creatingamagicfunction是什么意思:Internally,GCCimplementsthisbycreatingamagicfunctionandmovingtheassociatedcodeintothatfunction,sothatallthevariablesdeclaredwithinthatblockbecomelocalvariablesofthatfunction(andthus,localstoeachthread).ICC,ontheotherhand,uses

c++ - std::set 迭代器的返回类型冲突

这是今天让我感到困惑的第二个编译器错误。对于下面的代码,gcc以某种方式提示该代码具有返回迭代器的函数return_iter返回冲突类型std::_Rb_tree_iterator然后std::_Rb_tree_const_iterator,但它们都不应该是const迭代器,因为集合不是const。谁能解释为什么std::end()方法在非const左值上调用时返回const_iterator?下面粘贴了完整的代码。注意我只在使用gcc编译时出现此错误.当我用clang(AppleLLVMversion8.0.0(clang-800.0.38))编译时,这个错误没有出现。我使用的gcc

c++ - g++ 编译器是否以不同方式查看字符串数组和整数数组?

我似乎无法获得在函数内部声明的字符串数组。voidfoo(stringarr[],intarrSize){stringtemp[arrSize];//Resultsinerrorshownbelowinttemp2[arrSize];//Compilesfine}我收到一个编译时错误,指出:非POD元素类型“string”的可变长度数组(又名“basic_string,分配器>”)...[a...我尝试使用voidfoo(stringarr[],constintarrSize);将arrSize参数声明为常量,甚至在函数内部声明一个新的常量整数并将其初始化为arrSize但两者仍然导致

c++ - 显式特化中不允许存储类

我在不属于类的头文件中有以下代码:templatestaticconstCompl*foobar(constFBTYPE&x);templatestaticconstCompl*foobar(constFBTYPE&x){returnx.funcA();}templatestaticconstCompl*foobar(constFBTYPE&x){returnx.funcB();}代码在较旧的GCC版本中编译得很好,但在较新的版本中我收到此错误消息:rsvt.h(672):error#3503:astorageclassisnotallowedinanexplicitspecializ

c++ - 目标文件 "Version References"来自哪里?

目前我所在的目录中有一个文件libshared-object.so(为通用起见更改了名称)。当我运行时$objdump-plibshared-object.so我收到以下输出:libshared-object.so:fileformatelf64-x86-64ProgramHeader:LOADoff0x0000000000000000vaddr0x0000000000000000paddr0x0000000000000000align2**21filesz0x00000000000828eememsz0x00000000000828eeflagsr-xLOADoff0x0000000