免费注册 查看新帖 |

Chinaunix

广告
  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1797 | 回复: 1
打印 上一主题 下一主题

[C++]有一个关于double型数据的问题想请教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-02-13 08:55 |只看该作者 |倒序浏览
建立一个函数,该函数接受一个指向double类型数组的指针和一个表明该数组大小的值。该函数应该输出数组中的每个元素值。现在建立一个double类型的数组,且初始化每个元素的值为0,然后使用你的函数输出该数组。接着使用reinterpret_cast关键字把数组的起始地址转化为unsigned char*,把每个元素值设置为1(提示:必须用sizeof运算符计算一个double类型变量包含的字节数)。现在使用你的数组输出函数输出结果。
代码:
#include<iostream>
using namespace std;
typedef unsigned char unchar;
int main(){
    void setdouble(double*);
    void display(double*,int);
    double d_array[10]={0};
    display(d_array,10);
    for(double* d_i=d_array;d_i<d_array+10;d_i++){
                setdouble(d_i);
    }
    cout<<endl;
    display(d_array,10);
    system("pause");
    return 0;
}
void display(double* d_arr,int size){
     for(int i=0;i<size;i++){
             cout<<d_arr<<endl;
     }
}
void setdouble(double* d_ptr){
          unchar* uc_ptr=
          reinterpret_cast<unchar*>(d_ptr);
          short highbit=sizeof(double)-1;
          uc_ptr[highbit]|=7;
          uc_ptr[highbit-1]|=240;
          for(int i=highbit-2;i>=0;i--){
                  uc_ptr=0;
          }
}

[ 本帖最后由 parcel 于 2008-2-13 09:04 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2008-02-13 09:03 |只看该作者
我的问题就是出在setdouble这个函数里:
查资料知道double(8字节)在内存中是以
SEEEEEEEEEEEMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMM
形式存储的,一个符号位(S),11个指数位(E),52个底数位(M)
既然初始化为1,那么S=0,指数位该是00001111111,因为1不需要移动小数点就已经是科学计数,
E=0+127=01111111,所以只要最高位赋值00000111,然后接着是11110000,后面的全是0就行,但是输出结果
是:
0
0
0
0
0
0
0
0
0
0

1.24052e-265
1.24052e-265
1.24052e-265
1.24052e-265
1.24052e-265
1.24052e-265
1.24052e-265
1.24052e-265
1.24052e-265
1.24052e-265
错在哪呢
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP