Cat*_*kul 10 c++ containers boost iterator stl
因为我找不到我要找的东西,所以我打算自己写一些东西,但我想在潜入之前先问问群众.
虚构的(?)容器类型将运行如下:
const int blobSize = unpackBlobSize( msg );
int * blob = unpackBlobData( msg );
SpecialVector<int> mySpecialIntVector( blob, blobSize );
Run Code Online (Sandbox Code Playgroud)
基本上我将旧库与c风格的原始指针连接到缓冲区,但是想要使用C++样式容器语义而不需要复制步骤.我希望有的是std :: vector plus preallocated&prefilled buffer constructor,减去resize.
Libeigen在他们的Eigen :: Map中具有这种功能,它允许以下内容:
int array[9];
for(int i = 0; i < 9; ++i)
array[i] = i;
stl::cout << Eigen::Map<Eigen::Matrix3i>(array) << stl::endl;
Run Code Online (Sandbox Code Playgroud)
有人知道一个涵盖这些约束的boost或stl模板吗?
根据Dennis Zickenfoose的评论,我抬头看了Boost.range似乎提供了完美的解决方案:
#include <boost/range.hpp>
#include <boost/foreach.hpp>
#include <iostream>
int main()
{
const int blobSize = 100;
int blob[blobSize];
for( int i = 0; i < blobSize; ++i )
blob[i] = i;
boost::iterator_range<int*> blobPsudoContainer( blob, blob + blobSize );
BOOST_FOREACH( int & i, blobPsudoContainer )
i = i + 1;
std::cout << "Size is:" << blobPsudoContainer.size() << "\n";
std::cout << "value at 0 is:" << blobPsudoContainer[0] << "\n";
return 0;
}
Run Code Online (Sandbox Code Playgroud)
谢谢丹尼斯!:)
归档时间: |
|
查看次数: |
567 次 |
最近记录: |