草庐IT

LONG_PTR

全部标签

boost::smart_ptr 的 C++ 非侵入式 boost 序列化

我正在尝试序列化我无法使用boost::serialization修改的自定义类,并且我需要将逻辑/计算代码与序列化部分分开。它有一些我必须序列化的protected和私有(private)字段,其中一些是其他类的boost::shared_ptr。类似于://computationalclassesclassA{public:A(inta):m_val(a){}private:intm_val};classB{public:B(a):m_ptr(newA(a)){}private:boost::shared_ptrm_ptr;};我发现了一个简单的解决方法来序列化A类,只在其定义中添

c++ - 'long long long' 对于使用 log4cpp 的 GCC 来说太长了

我正在开发一个使用日志库log4cpp的QT应用程序。但是现在,在包含log4pp的头文件的地方,我得到了这个编译错误:'longlonglong'对于GCC来说太长了当我找到这个错误的根源时,头文件stdint.h在这一行打开:__MINGW_EXTENSIONtypedeflonglongint64_t;有人能告诉我如何处理吗? 最佳答案 好的,解决了,我只需要在开始时包含stdint.h 关于c++-'longlonglong'对于使用log4cpp的GCC来说太长了,我们在Sta

c++ - 模板别名 shared_ptr 和 unique_ptr 时是否有任何陷阱或限制?

为了减少输入类似内容的简单原因:std::shared_ptr;std::unique_ptr;每次想使用智能指针的时候,我就想到了使用模板别名:templateusingsptr=std::shared_ptr;templateusinguptr=std::unique_ptr;所以我可以像这样使用它们:sptr;uptr;假设我在自己的命名空间中保护它们,以这种方式使用带有shared/unique_ptr的模板别名是否有任何陷阱或限制?我会不会做一些我可以用直接模板语法做而我不能用别名做的事情?由于其他原因,这是一个坏主意吗? 最佳答案

c++ - 在 C++ 中初始化静态 std::map<int, unique_ptr<int>>

这是一个与此post类似的问题.我认为最有前途的答案与模板化静态初始化有关。这是该答案的类(class):templateclasscreate_map{private:std::mapm_map;public:create_map(constT&key,constU&val){m_map[key]=val;}create_map&operator()(constT&key,constU&val){m_map[key]=val;return*this;}operatorstd::map(){returnm_map;}};用法:std::mapmymap=create_map(1,2)(

带有 unique_ptr 的 C++ 嵌套映射

我目前正在学习C++并专注于STL。我没有找到这个问题的答案,所以问题来了:如何在数据结构中设置元素map>>?以下带有一些注释的代码说明了这个问题:#include#include#include#includeusingnamespacestd;//UsedintheexamplestructResource{};intmain(intargc,char**argv){//Iwasabletogetthefollowingmaprunningfine//int->{string->unique_ptr}map>>data;map>toBeInserted;toBeInserted[

c++ - c++ 中的 int(或 long long)溢出如何影响模数?

假设我有两个longlong,a和b,我需要相乘,然后得到一些大k的modk值,这样a、b和k都在longlong的范围内,但不在诠释。为简单起见,a,b因此代码将是:longlonga,b,k;cin>>a>>b>>k;cout但是,因为a和b太大了,如果像上面那样相乘,溢出变成负数,那么modk就是负数,不正确。如何确保modk的值是正确的?编辑:作为奖励,这在Java中是如何工作的?是不是和预想的一样?还是需要BigInteger? 最佳答案 许多编译器提供128位整数类型。例如,使用g++你可以创建一个函数staticinl

c++ - 如何调整 unique_ptr vector 的 vector 大小?

如何在一行中正确调整unique_ptrvector的大小而不gcc给出有关已删除函数的编译错误?vector>>a;a.resize(.....)更新:这是我使用的代码,可以正常工作。intwidth,height;vector>>a;a.resize(width);for(inti=0;i如果可能的话,我想一次调整大小,就像调整vector的vector的大小一样;vector>intObj;intObj.resize(width,vector(height,int()));但每当我尝试使用以下方法调整上述vector的大小时,我都会收到此错误;a.resize(x,vector>

c++ - 计算多个整数的位...有更快的方法吗?

我有一个由4个long组成的数组,我想计算给定范围内设置位的数量。这是我当前正在使用的函数(其中bitcount(uint64_t)是一个内联asm函数,它给出参数中设置的位数):unsignedcount_bits(constuint64_t*long_ptr,size_tbegin,size_tend){uint64_tstart_mask=~((1L=0&&begin=64&&begin=128&&begin我发现这段代码的性能非常好,但我想知道我是否可以做些什么来让它更快,或者重新设计算法是否可以提高性能。 最佳答案 我已经

c++ - `std::shared_ptr` 的智能指针模拟,带有用于将回调绑定(bind)到引用计数修改事件的 API,例如释放/保留……这是一回事吗?

我需要一个智能指针结构-类似于std::shared_ptr-它为我提供了某种带有公开Hook的API,回调到引用计数修改事件(例如释放/保留,又名refcout增量/减量)可以绑定(bind)。我要么想自己实现,要么使用现成的东西,如果它存在的话。比如,我希望在定义这个假定的shared_ptr-ish智能指针(就像delete-expressions和deleterfunctor分别在shared_ptr和unique_ptr定义中使用。编辑(来self下面的评论)——这就是我想要这个的原因:我目前有一个Image类模板,在它的核心,有一个std::shared_ptr持有一个(可

c++ - std::shared_ptr 预分配内存

我想在一个堆请求(如std::make_shared)中为shared_ptr的控制block和value_type预分配内存,但是不要立即在其中构造任何对象。当我实际需要构造对象时,使用放置new。可能吗?std::make_shared或std::allocate_shared似乎都无法解决我的问题。 最佳答案 我建议创建延迟初始化包装类,它本身包含足够的内存供您稍后要初始化的对象使用。这个包装器甚至可以有特殊的方法来在析构函数中调用placementnew和delete初始化对象。