草庐IT

malloc_ptr_t

全部标签

c++ - shared_from_this 导致 bad_weak_ptr

我正在尝试在asio中保留已连接客户端的列表。我已经从文档(http://www.boost.org/doc/libs/1_57_0/doc/html/boost_asio/example/cpp03/chat/chat_server.cpp)中改编了聊天服务器示例,这是我最终得到的重要部分:#include#include#include#include#include#includeusingboost::asio::ip::tcp;classtcp_connection;std::set>clients;voidadd_client(boost::shared_ptrclient

c++ - 为什么 C++ 需要对 malloc() 进行强制转换,而 C 不需要?

我一直对此感到好奇——为什么在C++中我必须从malloc中转换返回值,而不是在C中?以下是C++中有效的示例:int*int_ptr=(int*)malloc(sizeof(int*));这是C++中不起作用的示例(无强制转换):int*int_ptr=malloc(sizeof(int*));我听说在C中,实际上,从malloc()转换输出是一个错误。谁能评论这个话题? 最佳答案 几点:C允许将void指针隐式转换为任何其他对象指针类型。C++没有。如果您忘记包含stdlib.h或没有malloc()的声明,则在C中转换mall

c++ - 为什么 C++ 需要对 malloc() 进行强制转换,而 C 不需要?

我一直对此感到好奇——为什么在C++中我必须从malloc中转换返回值,而不是在C中?以下是C++中有效的示例:int*int_ptr=(int*)malloc(sizeof(int*));这是C++中不起作用的示例(无强制转换):int*int_ptr=malloc(sizeof(int*));我听说在C中,实际上,从malloc()转换输出是一个错误。谁能评论这个话题? 最佳答案 几点:C允许将void指针隐式转换为任何其他对象指针类型。C++没有。如果您忘记包含stdlib.h或没有malloc()的声明,则在C中转换mall

C++ std::unique_ptr:为什么 lambda 没有任何尺寸费用?

我正在阅读“有效的现代C++”。在std::unique_ptr相关的条目中声明如果自定义删除器是无状态对象,则不会产生大小费用,但如果它是函数指针或std::function尺寸费用发生。你能解释一下为什么吗?假设我们有以下代码:autodeleter_=[](int*p){doSth(p);deletep;};std::unique_ptrup(newint,deleter_);据我了解,unique_ptr应该有一个decltype(deleter_)类型的对象,并将deleter_分配给该内部对象。但显然这不是正在发生的事情。你能用尽可能小的代码示例解释这背后的机制吗?

C++ std::unique_ptr:为什么 lambda 没有任何尺寸费用?

我正在阅读“有效的现代C++”。在std::unique_ptr相关的条目中声明如果自定义删除器是无状态对象,则不会产生大小费用,但如果它是函数指针或std::function尺寸费用发生。你能解释一下为什么吗?假设我们有以下代码:autodeleter_=[](int*p){doSth(p);deletep;};std::unique_ptrup(newint,deleter_);据我了解,unique_ptr应该有一个decltype(deleter_)类型的对象,并将deleter_分配给该内部对象。但显然这不是正在发生的事情。你能用尽可能小的代码示例解释这背后的机制吗?

c++ - 如何从 boost::shared_ptr 释放指针?

boost::shared_ptr可以释放存储的指针而不删除它吗?我可以看到文档中不存在释放功能,在FAQ中也解释了为什么它不提供释放功能,例如不能对不​​唯一的指针进行释放。我的指针是独一无二的。我怎样才能释放我的指针?或者使用哪个boost智能指针类可以让我释放指针?我希望你不要说使用auto_ptr:) 最佳答案 不要。Boost的常见问题解答条目:Q.Whydoesn'tshared_ptrprovidearelease()function?A.shared_ptrcannotgiveawayownershipunlessi

c++ - 如何从 boost::shared_ptr 释放指针?

boost::shared_ptr可以释放存储的指针而不删除它吗?我可以看到文档中不存在释放功能,在FAQ中也解释了为什么它不提供释放功能,例如不能对不​​唯一的指针进行释放。我的指针是独一无二的。我怎样才能释放我的指针?或者使用哪个boost智能指针类可以让我释放指针?我希望你不要说使用auto_ptr:) 最佳答案 不要。Boost的常见问题解答条目:Q.Whydoesn'tshared_ptrprovidearelease()function?A.shared_ptrcannotgiveawayownershipunlessi

c++ - shared_ptr 的别名构造函数是干什么用的?

在此页面(http://www.cplusplus.com/reference/memory/shared_ptr/)的第5段中,它说:Additionally,shared_ptrobjectscanshareownershipoverapointerwhileatthesametimepointingtoanotherobject.Thisabilityisknownasaliasing(seeconstructors),andiscommonlyusedtopointtomemberobjectswhileowningtheobjecttheybelongto.Becauseof

c++ - shared_ptr 的别名构造函数是干什么用的?

在此页面(http://www.cplusplus.com/reference/memory/shared_ptr/)的第5段中,它说:Additionally,shared_ptrobjectscanshareownershipoverapointerwhileatthesametimepointingtoanotherobject.Thisabilityisknownasaliasing(seeconstructors),andiscommonlyusedtopointtomemberobjectswhileowningtheobjecttheybelongto.Becauseof

c++ - 为什么 unique_ptr 实例化编译为比原始指针更大的二进制文件?

我一直认为std::unique_ptr与使用原始指针相比没有开销。但是,编译如下代码#includevoidraw_pointer(){int*p=newint[100];delete[]p;}voidsmart_pointer(){autop=std::make_unique(100);}使用g++-std=c++14-O3生成以下程序集:raw_pointer():subrsp,8movedi,400calloperatornew[](unsignedlong)addrsp,8movrdi,raxjmpoperatordelete[](void*)smart_pointer():