草庐IT

c++ - Clang UBSAN 报告类型 'std::_Ios_Fmtflags' 的无效值

以下代码用clangUBSAN编译会崩溃#include#include#include#includetemplateinlinestd::stringfloatToString(Ti){printf("infloatToString\n");std::stringstreamss;ss.precision(6);ss用Clang3.6编译:$>clang++-3.6-fsanitize=undefined-fno-sanitize=float-divide-by-zero,vptr,function-fno-sanitize-recover-otesttest.cpp然后程序崩溃了

c++ - 指向结构的 std::vector 的指针

structStruct_t{intValue1;intValue2;};vectorStruct;Struct.resize(10,Struct_t());for(inti=0;i如何创建指向Struct[i]的指针?我想做的基本上是这样的,但我相信这可以做得更好:intvalue=6;Struct_ttemp=Struct[value],*s;s=&temp;s->Value1=42;s->Value2=6;主要目标是,我可以使用1行/函数轻松创建指向Struct[n]的指针。 最佳答案 到目前为止,提供的答案缺少房间里的大象。

C++ std::ofstream - 移动放置指针

我正在将一些数据写入文件。有时,我想从内存中写入一个数据block,然后将put指针移动1、2或3个字节以保持4字节的数据边界格式。我可以制作一个包含零的新数据block并写入它,但这似乎没有必要且笨拙。如何将put指针移动1、2或3个字节?我不确定该怎么做,因为如果我调用seekp()肯定会将指针移到当前文件大小之外?而我假设ofstream.write()正确地处理了这个问题?即:它在写入数据时以某种方式调整文件大小? 最佳答案 我假设你正在做类似的事情,除了你不想写两个字节的数据,而是想写4个字节并加上一些填充。#includ

c++ - 缩短字符串时 std::string::resize 和 std::string::erase 之间的区别

当缩短std::string时,基本上有两种可能性:string.resize(length)或string.erase(length).既然我们知道字符串会变小,那两者有什么区别呢? 最佳答案 resize必须检查length>current或length-它的行为取决于比较的结果。erase总是减少字符串的长度在异常安全方面存在差异:resize:强保证:如果抛出异常,则字符串没有变化。(来自here)erase:C++98-等于resize;C++14-函数没有抛出版本(来自here)

c++ - 在使用 gdb 检查核心转储时,有没有办法运行函数(如 std::string.size())?

考虑一个产生某些段错误并中止的C++程序。在使用gdb进行常规调试时,我可以执行以下操作并查看结果(gdb)r(gdb)pstr_var.size()其中str_var在文件中定义为std::string。但是,我在使用核心转储进行调试时遇到了一些问题。在我通过在gdb中加载核心转储之后gdbEXECUTABLEcore.pid然后在gdb终端运行以下命令(gdb)pstr_var.size()gdb说“如果没有调试过程,你就不能这样做。”我只能做bt(查看堆栈跟踪)或直接打印std::string变量之类的事情,但是找不到一种简单的方法来检查一些信息,例如打印std::string的

c++ - 为什么std::lock_guard在使用std::adopt_lock之后释放锁?

在下面的示例中,方法foo()被调用,它获得互斥体的所有权,并将其锁定。然后它调用check(),它获得了所有权,但假定互斥体已经被锁定,因此使用std::adopt_lock简单地采用它。但是当check()完成时,互斥锁被解锁。所以当foo()继续时,我试图保护的部分实际上不再受到保护。#includestaticstd::mutexsessionLock;boolcheck();voidfoo(){std::lock_guardguard(sessionLock);if(check()){//Dotransaction//Wait...themutexisunlockedhere

c++ - 带有类参数的 std::thread 初始化导致类对象被多次复制

看起来,如果创建一个类的对象,并将其传递给std::thread初始化构造函数,那么类对象的构造和销毁总共有4次之多。我的问题是:你能一步步解释这个程序的输出吗?为什么这个类在这个过程中被构造、复制构造和销毁了这么多次?示例程序:#include#include#include#includeclasssampleClass{public:intx=rand()%100;sampleClass(){std::cout输出是:constructorcalled,x=92copyconstructorcalled,x=36copyconstructorcalled,x=61destruct

c++ - 我如何定义 map::iterator 列表和 list::iterator 映射

我需要一个Map::iterator列表和List::iterator映射。我该怎么做:typedefstd::listList;typedefstd::mapMap;也许我可以使用迭代器的前向声明之类的东西? 最佳答案 像这样的东西应该可以帮助你:#include#include#include#include#includestructdecl_t{typedefstd::mapmap_t;typedefstd::list>list_t;list_t::iteratorit;};intmain(intargc,constchar

javascript - 在 Node.js 插件中使用 std::thread

想象一下,我使用来self的Node.js插件的同步函数:varcheck_ok=addon.my_function(parameters);varfinal_results=addon.final_function(parameters);但是在方法代码中我有:std::threadt[10];//Global//...voidmy_function(constFunctionCallbackInfo&args){//....t[0]=thread(random_void_function,[parameters])t[1]=thread(random_void_function_2

c++ - 如何从 std::array<T, N>::pointer 成员/依赖类型中推断出数组大小?

我的目标是为strcpy编写安全的替代品对于在编译期间已知目标缓冲区大小的情况,我希望推断出缓冲区大小,因此用户不需要知道它。例如:charxs[2]={0};strcpy(xs,"abc");//bufferoverflow!printf("[%s]\n",xs);此输出(希望)是:[abc]对于简单的情况,当传递C风格的数组时,可以毫不费力地写成:templatechar*safe_strcpy(char(&dst)[N],constchar*src)noexcept{std::snprintf(dst,N,"%s",src);return&dst[0];}推导出数组的大小,snp