C++中对数组指针强制类型转换,由float到unsigned char
float*p;unsignedchar*t;p=newfloat[len];t=newunsignedchar[len];然后我对p中的内容进行了赋值,是浮点型的现在我...
float *p;
unsigned char *t;
p=new float[len];
t=new unsigned char[len];
然后我对p中的内容进行了赋值,是浮点型的
现在我想把p中的内容转换成unsigned char型保存在t里面
==============以下两种方法都尝试过
memcpy(t,p,len*sizeof(unsigned char));
for (int i=0;i<len;i++)
{t[i]=(unsigned char)p[i];
}
这两种方法。。都会中断。。不知道是什么问题。
请大家帮忙解决 展开
unsigned char *t;
p=new float[len];
t=new unsigned char[len];
然后我对p中的内容进行了赋值,是浮点型的
现在我想把p中的内容转换成unsigned char型保存在t里面
==============以下两种方法都尝试过
memcpy(t,p,len*sizeof(unsigned char));
for (int i=0;i<len;i++)
{t[i]=(unsigned char)p[i];
}
这两种方法。。都会中断。。不知道是什么问题。
请大家帮忙解决 展开
2个回答
展开全部
float型的数据比unsigned char型占用更多字节,所以在空间上它们不等长,你用的复制方法是默认它们的数组占用相同字节数为前提的。
可以重新设置unsigned char数组的尺寸:
t=(unsigned char *)new unsigned char[len*sizeof(float)/sizeof(unsigned char)];
可以重新设置unsigned char数组的尺寸:
t=(unsigned char *)new unsigned char[len*sizeof(float)/sizeof(unsigned char)];
追问
可是我是想舍弃掉float的小数位。。只保留整数。这样子重新分了以后还能只保留整数位吗?
展开全部
t=new unsigned char[len*sizeof(float)];
memcpy(t,p,len*sizeof(float)); // string.h
这就是原封不动按二进制保存过去,不知是否是你要的效果
memcpy(t,p,len*sizeof(float)); // string.h
这就是原封不动按二进制保存过去,不知是否是你要的效果
更多追问追答
追问
不是的。。我是想把float里面的小数部分不要。。比如20.555.。我就只想要20存在char里面。
追答
for (int i=0;i<len;i++)
{
t[i]=(unsigned char)(int)(p[i]);
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询