草庐IT

reading_lists

全部标签

c++ - 数组与 std::initializer_list 作为函数参数

我可以通过两种方式编写一个将临时数组(例如{1,2,3})作为参数的函数://usingarraytemplateautofoo1(constT(&t)[N])->void;//usingstd::initializer_listtemplateautofoo2(std::initializer_listt)->void;是否有任何指南可以告诉您哪个更好? 最佳答案 它们是完全不同的东西。还有2或3个其他选择是合理的。templatevoidfoo_a(std::arrayconst&);templatevoidfoo_b(gsl:

c++ - `List x;` 和 `List x()` 有区别吗

标题来自名站C++FAQ作者:编码(marshal)·克莱恩。作者声称以下两个代码示例之间存在差异。SupposethatLististhenameofsomeclass.Thenfunctionf()declaresalocalListobjectcalledx:voidf(){Listx;//Localobjectnamedx(ofclassList)...}Butfunctiong()declaresafunctioncalledx()thatreturnsaList:voidg(){Listx();//Functionnamedx(thatreturnsaList)...}但是

c++ - 错误 : no instance of overloaded function "std::make_shared" matches the argument list

查看ApreviousstackQuestionstd:make_sharedvsstd::shared_ptr,我试图在一个uni项目中实现它。这是之前的“问题”:Ican'tthinkofanysituationwherestd::shared_ptrobj(newObject("foo",1));wouldbepreferredtoautoobj=std::make_shared("foo",1);因此我采用了这段代码:std::shared_ptrpT1(newTriangle(pCanvas,30,30,30,60,60,30,255,0,0));并将其修改为这段代码:aut

c++ - std::list<int> 的默认构造函数可以抛出吗?

我(快速)查看了C++标准和在线C++引用,但找不到这个简单问题的答案:可以std::list的默认构造函数吗?扔?如果是这样,为什么会抛出? 最佳答案 简短回答:它可以,但它可以以相当安全的方式实现:默认构造函数构造了一个空列表,因此几乎不需要在进程中实际分配内存。大多数列表实现不会为空列表分配任何内存。但是,默认构造函数不是真正默认构造函数,因为它有一个默认参数:explicitlist(constAllocator&=Allocator());Allocator本身是一个模板参数,因此如果Allocator有一个足够笨(或复杂

c++ - 使用 std::stack 而不是 deque、vector 或 list 的优点和缺点是什么

我正在编写一个非常简单的std::stack,使用vector作为其底层容器。我意识到我可以用vector容器的push_back()、pop_back()和back()替换所有的push()、pop()和top()函数。我的问题是:当底层容器的受控使用就足够时,为什么还要使用容器适配器?为什么不只使用双端队列、vector或列表?会不会浪费内存或处理时间? 最佳答案 当您的代码显示std::stack时,读者很清楚他们需要在容器上执行哪些操作……它在强制不使用其他操作的同时进行通信和记录。它可以帮助他们快速形成对代码中算法逻辑的印

c++ - 为什么我不能将此对象推送到我的 std::list 中?

刚开始用C++编程。我创建了一个Point类、一个std::list和一个迭代器,如下所示:classPoint{public:intx,y;Point(intx1,inty1){x=x1;y=y1;}};std::listpointList;std::list::iteratoriter;然后我将新点推送到pointList。现在,我需要遍历pointList中的所有点,所以我需要使用迭代器进行循环。这就是我搞砸的地方。for(iter=pointList.begin();iter!=pointList.end();iter++){PointcurrentPoint=*iter;gl

C++初阶:适合新手的手撕list(模拟实现list)

上次讲了常用的接口:今天就来进行模拟实现啦文章目录1.基本结构与文件规划2.空参构造函数(constructor)3.完善迭代器(iterator)(begin(),end())4.ListCapacity(size(),empty())4.增删改查(push_back,pop_back,pop_front,push_front,insert,erase)6.clear()和swap()7.完善构造函数7.1list(size_typen,constvalue_type&val=value_type());7.2利用迭代器进行构造7.3拷贝构造8.重载=9.析构函数10.反向迭代器1.基本结构

c++ - boost::asio::async_read_until 问题

我正在尝试修改来自boostasio的echo服务器示例,当我尝试使用boost::asio::async_read_until时遇到了问题。这是代码:#include#include#include#includeusingboost::asio::ip::tcp;classsession{public:session(boost::asio::io_service&io_service):socket_(io_service){}tcp::socket&socket(){returnsocket_;}voidstart(){std::coutsocket(),boost::bind

c++ - 由于超时取消async_read

我正在尝试围绕async_read编写一个包装器同步方法,以允许在套接字上进行非阻塞读取。根据互联网上的几个例子,我开发了一个似乎几乎正确但不起作用的解决方案。该类声明了这些相关的属性和方法:classcommunications_client{protected:boost::shared_ptr_io_service;boost::shared_ptr_socket;boost::array_data;boost::mutex_mutex;bool_timeout_triggered;bool_message_received;boost::system::error_code_e

c++ - 仿函数和 initializer_list 的拷贝

我对复制仿函数和/或初始化器时发生的情况感到有点困惑。在下面的代码中,我认为我会一直复制/移动对象,但不管它是否存在段错误。我似乎做错了什么,但还没有弄清楚,我的错误假设是什么。奇怪的是,在cppreference.com我找不到initializer_list的复制或移动构造函数,所以我想知道在这些情况下实际发生了什么。#include#include#include#includestd::initializer_list>getInitializer(){return{[]()->std::string{return"If";}};}intmain(){std::function