草庐IT

make_scoped

全部标签

c++ - std::tie 与 std::make_tuple

Thiscodecompiles但我想知道应该首选哪个版本:#include#includeusingnamespacestd;tuplereturn_tuple1(){inta=33;intb=22;intc=31;returntie(a,b,c);}tuplereturn_tuple2(){inta=33;intb=22;intc=31;returnmake_tuple(a,b,c);}intmain(){autoa=return_tuple1();autob=return_tuple2();return0;}由于该函数按值返回一个元组,因此使用std::tie应该没有任何问题,对

c++ - Lambda 和通过引用局部变量 : Accessing after the scope 捕获

我通过引用两个lambda来传递我的局部变量。我在函数范围之外调用这些lambda。这是undefined吗?std::pair,std::function>addSome(){inta=0,b=0;returnstd::make_pair([&a,&b]{++a;++b;returna+b;},[&a,&b]{returna;});}intmain(){autof=addSome();std::cout如果不是,那么一个lambda的变化不会反射(reflect)在另一个lambda中。我是否误解了lambdas上下文中的传递引用?我正在写入变量,它似乎工作正常,没有输出运行时错误2

c++ - "local variables at the outermost scope of the function may not use the same name as any parameter"是什么意思?

我一直在阅读C++入门第5版。在第6.1章功能参数列表的第三段中。它写道“此外,函数最外层范围内的局部变量不得使用与任何参数相同的名称”。什么意思?我不是以英语为母语的人。我不明白函数的“最外层范围”的实际含义。 最佳答案 函数的最外层是定义函数体的block。您可以将其他(内部)block放入其中,并在该block的本地变量中声明变量。内部block中的变量可以与外部block中的变量或函数参数具有相同的名称;他们将名称隐藏在外部范围内。外部block中的变量不能与函数参数同名。演示:voidf(inta)//functionha

c++ - 综合 gnu make/gcc 教程

已结束。此问题不符合StackOverflowguidelines.它目前不接受答案。要求我们推荐或查找书籍、工具、软件库、教程或其他非现场资源的问题对于StackOverflow来说是题外话,因为它们往往会吸引固执己见的答案和垃圾邮件。相反,请描述问题以及迄今为止为解决该问题所做的工作。关闭8年前。Improvethisquestion我刚开始学习C++,我发现很难找到关于如何使用gnumake/gcc的简短、全面的教程。任何想法(请不要将我指向官方的gnumake教程,它对我的​​目的来说太深入了;-))。 最佳答案 查书Man

c++ - 为什么 Boost scoped_lock 不解锁互斥锁?

我一直在以这种方式使用boost::mutex::scoped_lock:voidClassName::FunctionName(){{boost::mutex::scoped_lockscopedLock(mutex_);//dostuffwaitBoolean=true;}while(waitBoolean==true){sleep(1);}//getonwiththethread'sactivities}基本上它设置waitBoolean,而另一个线程通过将waitBoolean设置为false来表示它已完成;然而,这似乎不起作用,因为其他线程无法锁定mutex_!!我假设通过将

c++ - 这种使用 std::make_unique 会导致非唯一指针吗?

假设我在C++中有以下代码:#include#includestructSome{Some(int_a):a(_a){}inta;};intmain(){Somesome(5);std::unique_ptrp1=std::make_unique(some);std::unique_ptrp2=std::make_unique(some);std::coutaa据我了解,唯一指针用于保证不共享资源。但在这种情况下,p1和p2都指向同一个实例some。请公布情况。 最佳答案 它们不指向相同的资源,它们各自指向不同的拷贝。可以通过删除拷

c++ - 我可以将 std::make_shared 与没有参数构造函数的结构一起使用吗?

假设我有一个像这样的struct:structS{inti;doubled;std::strings;};我可以这样做吗?std::make_shared(1,2.1,"Hello") 最佳答案 不,您不能,您必须定义自己的构造函数才能做到这一点。#include#include#includestructS{S(intii,doubledd):i(ii),d(dd){}inti;doubled;};intmain(){//Ss{1,2.1};autos=std::make_shared(1,2.1);//orwithoutcons

c++ - std::make_unique 导致大幅减速?

我最近开始使用C++14而不是C++11对我的C++代码库进行现代化改造。在用C++14中的std::make_unique替换一次出现的std::unique_ptr.reset(new...)后,我意识到我的测试套件(由大约30个C++测试程序组成)运行速度慢了大约50%。旧的C++11代码(快速):classFoo{public:Foo(size_tsize){array.reset(newchar[size]);}private:std::unique_ptrarray;};新的C++14代码(慢):classFoo{public:Foo(size_tsize){array=s

c++ - 井字游戏 AI : How to Make the Tree?

在制作井字游戏机器人时,我在试图理解“树”时遇到了很大的困难。我理解这个概念,但我不知道如何实现它们。有人可以向我展示一个如何为这种情况生成树的示例吗?还是生成树的好教程?我想困难的部分是生成部分树。我知道如何实现生成一整棵树,但不知道它的一部分。 最佳答案 想象一下,在井字游戏中的任何一点,每一个可能的Action都是一个分支。板的当前状态是根。一个Action是一个分支。现在假设(一次一个),每个分支都成为当前状态。每个可能的移动都成为一个新的分支。树的叶子是当最后一步完成并且棋盘已满时。你需要一棵树的原因是,一旦它建成,你需要

c++ - 为什么这个makefile在 'make clean'上执行一个目标

这是我当前的makefile。CXX=g++CXXFLAGS=-Wall-O3LDFLAGS=TARGET=testcppSRCS=main.cppobject.cppfoo.cppOBJS=$(SRCS:.cpp=.o)DEPS=$(SRCS:.cpp=.d).PHONY:cleanallall:$(TARGET)$(TARGET):$(OBJS)$(CXX)$(CXXFLAGS)$(LDFLAGS)$(OBJS)-o$(TARGET).cpp.o:$(CXX)$(CXXFLAGS)-c$$@clean:rm-f$(OBJS)$(DEPS)$(TARGET)-include$(DEP