草庐IT

C++标准

全部标签

c++ - 用一个线程做一个部分,用多个线程做一个for循环

我正在使用OpenMP,我想生成线程,以便一个线程执行一段代码并完成,与运行并行for循环迭代的N个线程并行。执行应该是这样的:SectionA(onethread)||SectionB(parallel-for,multiplethreads)|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||V||VVVVVVVVVV我不能只用#pragmaomponce编写并行for,因为我不希望执行A部分的线程执行for循环。我试过这个:#pragmaompparallelsections{#pragmaompsec

c++ - C 风格使用现代 C++ 类

我有这样一个类:片段1:structB{intmember;//morecomplexmemberse.g.arraysofstructsetc};假定它是C风格的结构(例如用于memcpy、memset等)作为良好编程原则的一部分,我正在考虑像这样修改B:片段2structB{B(){}intmember;//morecomplexmemberse.g.arraysofstructsetc};这是我的理解。如果我弄错了请更正一种。代码段1定义了B,它是一个POD,而代码段2定义了B,它不是一个POD,并且b.在片段2中,B仍然可以合法地用于C风格的用途,例如memset和memcpy

c++ - libstdc++ 不识别标准库文字

我正在尝试使用std::literals命名空间中的文字来编译一个简单的程序,但是当我尝试编译它时Clang会生成错误。我要编译的代码:#include#includeusingnamespacestd::literals;intmain(){std::cout和编译命令:clang++-stdlib=libstdc++-std=c++1ya.cpp这导致了这个输出:a.cpp:4:22:error:expectednamespacenameusingnamespacestd::literals;~~~~~^a.cpp:8:29:error:nomatchingliteralopera

python - 使用 ctypes 捕获 c++ 共享库日志条目

我有一个带有c接口(interface)的cplusplus共享库,它在标准输出中写入日志条目。我在使用ctypes库的python应用程序中使用它。python应用程序使用logging库来写入日志条目。我需要做的是捕获共享库的标准输出条目以使用logging模块写入日志条目。换句话说,我想将c库的stdout条目重定向到logging模块,这样我就可以使用logging来使用它的处理程序写入文件和控制台。我发现可以捕获标准输出(seethisSOquestion),但我只能在c模块调用结束时访问它,因此它对日志记录没有用。我想要一种无阻塞的方式来访问标准输出条目。一个最小的例子如下

c++ - 如何在 C++ 中使用两个排序标准(对于一组对)创建一个有序集?

我需要订购一组对(一个是int,第二个是char),我需要像这样订购我的套装:12G,11F,10A,10B,10C(从第一个降序,从第二个升序)第一。到目前为止,这是我尝试过的方法,但出现了一些错误:#include#include#include#include#includeusingnamespacestd;set>s;boolmyfunction(constpair&i,constpair&j){if(i.first>::iteratorit;for(it=s.begin();it>n;for(inti=1;ix;intst;charnd;f>>st;f>>nd;x.firs

c++ - 在C/C++中使用stdio文件操作时如何检测磁盘空间不足?

我正在做一个小程序如下:voidreserve_file_space(char*file_path,size_tamount){FILE*fp=fopen(file_path,"w+b");if(!fp){printf("couldnotcreateanewfile\n");return;}intfseek_ret=fseek(fp,amount,SEEK_SET);if(fseek_ret!=0){printf("couldnotseektothedesiredposition\n");fclose(fp);return;}chargarbage=1;size_tret=fwrite

c++ - 将生成的进程标准输出捕获为 unicode

在我的C++/WinAPI代码中,我想运行一些命令并捕获它们的输出。为了测试非ASCII输出,我将我的网络连接重命名为EthérnétאבגБбИгДд并运行ipconfig。在命令提示符下运行时,输出正确(使用CourierNew等支持字体时可见):C:\>ipconfigWindowsIPConfigurationEthernetadapterEthérnétאבגБбГгДд:(...)我尝试将输出重定向到管道,跟随theexampleinthisanswer.但是从ReadFile()返回的字节数组不是unicode-它是在CP_OEMCP(在我的例子中是CP437)中编码的,

c - 使用 strtod strtof atof printf 进行语言环境不变的字符串处理?

是否有任何计划添加在当前语言环境下不变的C标准库字符串处理函数版本?目前有很多脆弱的解决方法,例如,来自jansson/strconv.c:staticvoidto_locale(strbuffer_t*strbuffer){constchar*point;char*pos;point=localeconv()->decimal_point;if(*point=='.'){/*Noconversionneeded*/return;}pos=strchr(strbuffer->value,'.');if(pos)*pos=*point;}staticvoidfrom_locale(cha

c++ - 冲突的不匹配标签与标准库一起编译,但不以其他方式编译

我在看如何std::tuple_size在我系统的标准库中定义。我有一个MacOS,编译器版本是AppleLLVMversion8.1.0(clang-802.0.42).标准库位于InstalledDir中g++--version输出的位置鉴于以下代码无法编译(因为clang不喜欢将之前定义为struct的东西特化/重新声明为class,反之亦然)#include#include#include#include#includeusingstd::cout;usingstd::endl;templateclassSomething;templatestructSomething>;te

c++ - 在 MoveAssignable 的情况下,标准对 self 移动赋值有何看法?

这是C++17的currentdescriptionMoveAssignable的:t=rv;Iftandrvdonotrefertothesameobject,tisequivalenttothevalueofrvbeforetheassignmentrv'sstateisunspecified.[ Note:rvmuststillmeettherequirementsofthelibrarycomponentthatisusingit,whetherornottandrvrefertothesameobject.Theoperationslistedinthoserequireme