草庐IT

initial_file

全部标签

c++ - 内存屏障 : How to ensure initialization writes are seen by worker threads?

我对使用内存屏障/栅栏进行编程还很陌生,我想知道我们如何才能保证设置写入在随后在其他CPU上运行的辅助函数中可见。例如,请考虑以下内容:intsetup,sheep;voidSetupSheep()://RunonceCPU1:setup=0;...muchlaterCPU1:sheep=9;CPU1:std::atomic_thread_fence(std::memory_order_release);CPU1:setup=1;之后运行(不是并发),很多很多次:voidManipulateSheep():CPU2:intmySetup=setup;CPU2:std::atomic_t

c++ - Python C++ 扩展 : compile only modified source files

我正在开发一个包含C++扩展的python包。当我使用setup.py脚本或使用pip安装包时,C++源文件都被编译和链接以获得单个.so库,然后可以将其导入Python源代码中。在开发过程中,我需要对源代码进行多次更改(测试、调试等)。我发现重新安装包涉及重建所有C++源文件,即使只更改了一个文件的一小部分。显然,这会占用相当多的时间。我知道放置源文件链接的开发模式(pythonsetup.pydevelop或pipinstall-e),以便在重新导入模块时立即看到所做的更改。但是,这仅适用于.py源文件而不适用于C++扩展,每次更改后都必须重新编译。有没有办法让setup.py查看

c++ - VS2013 : How to disable warnings for included header files outside of the project

在我的项目中,我包含了一个由外部库提供的头文件。使用/W3,所有内容都可以在没有警告的情况下编译。但是,我希望我的项目能够使用/W4进行干净地编译。这对我的代码来说没有问题,但外部header会发出大量警告。我知道我可以做这样的事情:#pragmawarning(push)#pragmawarning(disable:####)//includehere#pragmawarning(pop)但是有一长串要禁用的警告。有没有一种方法可以在包含此header时将警告级别设置回/W3,同时仍使用/W4编译我的其余代码?谢谢! 最佳答案 #

c++ - "initializer_list"找不到文件

尝试为Node安装phash-image但出现此错误:>phash-image@3.1.0install/Users/jong/Workspace/mgmtio/phash-image>node-gyprebuildCXX(target)Release/obj.target/pHash/phash.oInfileincludedfrom../phash.cpp:4:Infileincludedfrom/usr/local/Cellar/phash/0.9.6_1/include/pHash.h:50:/usr/local/include/CImg.h:160:10:fatalerror

c++ - LNK1104 : cannot open file 'wxbase28d.lib'

我正在尝试编译使用wxWidgets库创建的现有项目。我成功编译了wxWidgets2.8.12库。现在,我正在尝试编译我的项目。但是我得到错误:fatalerrorLNK1104:cannotopenfile'wxbase28d.lib'之后我在设置中添加了一些变量,例如:C/C++->预处理器定义:WIN32;__WXMSW__;_WINDOWS;_DEBUG;__WXDEBUG__;_CRT_SECURE_NO_WARNINGS;WIN32;_DEBUG;_WINDOWS;%(PreprocessorDefinitions)VC++目录->包含目录:D:\instantclien

c++ - fatal error : 'common.h' file not found under mac osx 10. 10.5

我按照操作系统:三个简单的部分这本书,introductionchapter中的代码,#include#include#include#include#include"common.h"intmain(intargc,char*argv[]){if(argc!=2){fprintf(stderr,"usage:cpu\n");exit(1);}char*str=argv[1];while(1){Spin(1);printf("%s\n",str);}return0;}当我尝试gcc-ocpucpu.c-Wall时,错误出来了:fatalerror:'common.h'filenotfo

c++ - VC++ 警告 C4356 : static data member cannot be initialized via derived class

以下代码发出此警告,但它似乎工作正常,因为A::st和B::st都已初始化并且实际上代表相同的字符串。据我了解,这是格式错误的代码,不应编译(我检查了clang)。我想知道为什么VC++不发出错误而是发出警告?#include#includeclassA{public:staticconststd::stringst;};classB:publicA{};conststd::stringB::st="abcd";//warningC4356:'A::st':staticdatamembercannotbeinitializedviaderivedclassintmain(){std::

c++ - 将 initializer_list 转换为可变参数模板

我使用名为fmt(http://fmtlib.net/latest/)的格式化库。一种可能的用途是:fmt::format("Hello,{name}!Theansweris{number}.Goodbye,{name}.",fmt::arg("name","World"),fmt::arg("number",42));我想将此调用包装在一个函数中,我称之为:myFunction(myString,{"name","World"},{"number",42});对于任何个参数。到目前为止,我只成功地完成了一个可调用的函数:myFunction(myString,std::make_pa

c++ - boost iostream : how to turn ifstream into memory mapped file?

我想要的是简单地打开文件作为内存映射文件进行读取-以便将来以更快的速度访问它(例如:我们打开文件读取它结束,等待并一次又一次地读取它)同时我希望该文件可以被其他程序修改,当他们修改它时,我希望我的ifstream也能修改。如何使用boostiostreams(或boostinterprocess)做这样的事情?我们可以只是tallos-嘿,这个文件应该为所有应用程序进行内存映射?所以我尝试这样的代码:#include#include#includeusingnamespaceboost::iostreams;intmain(intargc,char**argv){streamout;t

C++ LZMA SDK : Uncompress function for LZMA2 compressed file

我正在尝试创建一个解压缩LZAM2压缩数据的函数。我的灵感来自thistutorial这对LZMA非常有效,我尝试将其改编为LZMA2。我成功地为LZMA2创建了压缩函数,但我没有成功创建解压缩函数。这里是压缩函数:staticvoidCompress2Inc(std::vector&outBuf,conststd::vector&inBuf){CLzma2EncHandleenc=Lzma2Enc_Create(&SzAllocForLzma,&SzAllocForLzma2);assert(enc);CLzma2EncPropsprops;Lzma2EncProps_Init(&p