我正在实现MPI代码而我正在使用MPI_Bcast
函数。函数的一个组件是发送的数据的数量,这里是一个名为l_nMinplacesPos
的向量的大小。我想分享这个向量的大小。我尝试了sizeof l_nMinplacesPos
一次返回32,当我使用l_nMinplacesPos.size()
时,我得到了2作为矢量的大小!我很困惑哪一个显示矢量的实际大小?两者之间有什么区别?
void ParaStochSimulator::broad_casting(long j){
std::cout << "i'm broad_casting" << std::endl;
l_nMinplacesPos = (*m_pcTransitionsInfo)[j]->GetManipulatedPlaces();
double val;
l_anMarking.reserve(l_nMinplacesPos.size());
for (auto lnpos : l_nMinplacesPos)
{
val = m_anCurrentMarking[lnpos];
l_anMarking.push_back(val);
}
for (auto marking : l_anMarking)
{
std::cout << marking << std::endl;
}
MPI_Bcast(&l_anMarking, sizeof l_nMinplacesPos, MPI_DOUBLE, 0, MPI_COMM_WORLD); //->here i used l_nMinplacesPos.size() instead.
}
void ParaStochSimulator::SimulateSingleRun()
{
//prepare a run
PrepareRun();
while ((m_nCurrentTime < m_nOutputEndPoint) && IsSimulationRunning())
{
deterMinTau();
if (mnprocess_id == 0)
{
SimulateSingleStep1();
std::cout << "current time:*****" << m_nCurrentTime << std::endl;
broad_casting(m_nMinTransPos);
std::cout << "size of mani place :" << sizeof l_nMinplacesPos << std::endl;
}
}
PostProcessRun();
MPI_Bcast(&l_anMarking, sizeof l_nMinplacesPos, MPI_DOUBLE, 0, MPI_COMM_WORLD); //->here i used l_nMinplacesPos.size() instead.
std::cout << "size of mani place :" << sizeof l_nMinplacesPos << std::endl;
}
答案 0 :(得分:6)
.size()
返回向量中的元素数。这就是你应该使用的东西。
sizeof
为您提供对象定义使用的 bytes 的数量,不包括通过使用指针分配的任何其他存储。它是编译器在编译时根据vector
类的声明生成的静态常量。
答案 1 :(得分:0)
值得一提的是sizeof()
也是事实,当你直接在阵列的电池上工作时。内容(尤其是字符串),它可能会将特定单元格的长度切断为8个字节。在我的实际考试中,我有一个创建C / C ++程序的任务,它定位插入到数组中的每个单词的第一个字母。使用sizeof()
后,它只返回该数组的前8个字符,其余的已被抛出内存,所以要小心。