未定义的行为或可能是memset的东西

时间:2015-06-22 03:45:59

标签: c++ undefined-behavior

我试图在数组A中保存32位数字的二进制等价物。为了测试我的showbits()函数,当我遇到这个东西时,我选择了8,9:

当我在函数showbits()中放置memset时,我在代码中面临一个不合理的事情,我正在考虑荒谬的整数,而我期望输出为

  

00000000000000000000000000001000

这是2的二进制等价物。当我将memset放在main()方法中时,它正常工作并给我正确的输出。我走出界限(我看不到它!)。

我的代码: 的 SHOWBITS:

void showbits(int A[32],int num)
{
    int k=0;
    memset(A,0,sizeof(A));
    while(num>0)
    {
        A[k] = num&1;
        k++;
        num>>=1;
    }
    return ;
}

注意:我已将memset放在showbits中,我得到的答案不正确! 主要

int main()
{
    int A[32],i;
    showbits(A,8);
    for(i=31;i>=0;i--)
        printf("%d",A[i]);
    return 0;
}

整个测试程序:

#include<stdio.h>
#include<algorithm>
#include<cstring>
using namespace std;
void showbits(int A[32],int num)
{
    int k=0;
    memset(A,0,sizeof(A));
    while(num>0)
    {
        A[k] = num&1;
        k++;
        num>>=1;
    }
    return ;
}
int main()
{
    int A[32],i;
    showbits(A,8);
    for(i=31;i>=0;i--)
        printf("%d",A[i]);
    return 0;
}

当我在showbits()之前将该memset语句放在Main方法中时,我得到了正确的输出!

修改 如果有人对我得到的东西感兴趣

  

398420075242008462686872420075219611920941961187434-2205336646196127610926869242   68672826866724200752000202903316219611874341961187478819611565142686716196182637   61961141748268665201000

3 个答案:

答案 0 :(得分:5)

方法中的A[32]实际上只是指向A的指针。因此,sizeof的大小为*int。请使用以下测试代码:

void szof(int A[32])
{
    std::cout << "From method: " << sizeof(A) << "\n";
}
int main(int argc, char *argv[])
{
    int B[32];
    std::cout << "From main: " << sizeof(B) << "\n";
    szof(B);
    return 0;
}

给出以下输出:

From main: 128
From method: 8

因此,memset设置的位数比你想象的少。

答案 1 :(得分:4)

Avi已经解释了代码中的问题。另一种可能的解决方案是使用C ++风格的数组,而不是C风格的数组和memset。然后不可能出现memset长度错误。也没有性能损失。

#include <array>

void showbits(std::array<int, 32> &A, int num)
{
    A = {};     // set all entries to 0
    // ...
}

int main()
{
    std::array<int, 32> A;
    // ...
}

答案 2 :(得分:3)

您必须通过引用传递A

void showbits(int (&A)[32],int num)

请点击此处了解详情:C++ pass an array by reference