草庐IT

some-really-interesting-article

全部标签

c++ - 模板 :Name resolution:Point of instantiation: -->can any one tell some more examples for this statement?

这是来自ISOC++标准14.6.4.1实例化点的声明Forafunctiontemplatespecialization,amemberfunctiontemplatespecialization,oraspecializationforamemberfunctionorstaticdatamemberofaclasstemplate,ifthespecializationisimplicitlyinstantiatedbecauseitisreferencedfromwithinanothertemplatespecializationandthecontextfromwhichi

c++ - 解决 C++ 'target of assignment not really an lvalue' 错误

给定这段代码:voidFrMemCopy(void*to,constvoid*from,size_tsz){size_tsz8=sz>>3;size_tsz1=sz-(sz8我在while循环内的两行收到targetofassignmentnotreallyanlvalue警告。谁能打破这些界限?强制转换然后增量?什么是更简单的写法?错误是什么意思? 最佳答案 它不喜欢*((char*)to)++语句。试试这个:voidFrMemCopy(void*to,constvoid*from,size_tsz){size_tsz8=sz>>

c++ - "typename"和 "template"关键字 : are they really necessary?

编译c++模板代码时,这个站点上有很多问题。此类问题最常见的解决方案之一是在程序代码的正确位置添加typename(以及不太常见的template)关键字:templateclassBase{public:typedefcharSomeType;templatevoidSomeMethod(SomeType&v){//...}};templateclassDerived:publicBase{public:voidMethod(){typenameBase::SomeTypex;//^^^^^^^^this->templateSomeMethod(x);//^^^^^^^^}};是否有

c++ - decltype(some_vector)::size_type 不能用作模板参数

下面的类不编译:template,classAllocator=std::allocator>classMyContainer{public:std::vectordata;std::vector>order;};我收到以下编译器错误:error:type/valuemismatchatargument2intemplateparameterlistfor‘templatestructstd::pair’为什么编译失败,而下面的代码工作正常?template,classAllocator=std::allocator>classMyContainer{public:std::vecto

c++ - write_some 与 write - boost asio

当write_some可能无法将所有数据传输到对等端时,为什么有人要使用它?来自boostwrite_some文档Thewrite_someoperationmaynottransmitallofthedatatothepeer.Considerusingthewritefunctionifyouneedtoensurethatalldataiswrittenbeforetheblockingoperationcompletes.write_some方法在boost中有write方法的相关性是什么?我浏览了boostwrite_some文档,我猜不出什么。

c++ - 类设计与 IDE : Are nonmember nonfriend functions really worth it?

在(否则)优秀的书中C++CodingStandards,第44项,标题为“首选编写非成员非友元函数”,Sutter和Alexandrescu建议只有真正需要访问类成员的函数本身才是该类的成员。所有其他可以仅使用成员函数编写的操作不应该是类的一部分。他们应该是非成员和非friend。论点是:它促进了封装,因为需要访问类内部的代码更少。它使编写函数模板更容易,因为您不必每次都猜测某个函数是否是成员。它使类变小,从而更易于测试和维护。虽然我看到了这些论点的值(value),但我看到了一个巨大的缺点:我的IDE不能帮我找到这些函数!每当我有某种对象,我想看看它有哪些操作可用,我不能再键入“p

c++ - 从 std::tuple<some_types...> 开始创建子元组

让我们假设一个std::tuple给出。我想创建一个新的std::tuple其类型是在[0,sizeof...(some_types)-2]中索引的类型.例如,假设起始元组是std::tuple.我想获得一个定义为std::tuple的子元组.我对可变参数模板很陌生。作为第一步,我尝试写一个struct负责存放不同类型的原件std::tuple目的是创建一个新的同类元组(如std::tuplenew_tuple)。templatestructtype_list;templatestructtype_list:publictype_list{typedefTtype;};template

C++11 基于范围的循环 : How does it really work

我知道这个循环是如何工作的,以及我如何在实际问题中使用它。但我想知道幕后发生了什么。我认为这个循环类似于常规的for循环,例如for(inti=0;i变量i只初始化一次,所以我认为这对于基于范围的循环也是一样的。但是如果我写这段代码:for(constintx:vec){cout编译器允许我这样做,但我不明白这是怎么可能的。如果变量x是const,为什么在每次迭代中x值都不同? 最佳答案 循环的每次迭代都会创建一个局部变量x并将其初始化为vec的下一个元素。当循环迭代结束时,x超出范围。单个x永远不会被修改。参见thislink为了

c++ - boost ASIO async_read_some

我在实现一个简单的TCP服务器时遇到了困难。以下代码摘自boost::asioexamples,准确地说是“Http服务器1”。voidconnection::start(){socket_.async_read_some(boost::asio::buffer(buffer_),boost::bind(&connection::handle_read,shared_from_this(),boost::asio::placeholders::error,boost::asio::placeholders::bytes_transferred));}voidconnection::ha

C++ 虚拟类 : interesting point

请告诉我为什么以下程序的输出如下所示。我没有得到C++中的虚拟类。观察下面的代码:classB{public:B(charc='a'):m_c(c){}public:charget_c()const{returnm_c;}voidset_c(charc){m_c=c;}private:charm_c;};classC:publicB{};classD:publicB{};classE:publicC,publicD{};intmain(){Ee;C&c=e;D&d=e;std::coutO/P:aa我希望输出是ab。获得“aa”的原因是什么?如果我有c.set_c('b')而不是d.s