我试图在数组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
答案 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)