C++中double和long double有什么区别?
7个回答
展开全部
二者均为浮点数类型,区别如下:
1 double类型为C++原始类型,所有编译器均支持,而long double是C99规范增加的新类型,只有支持C99的编译器才支持long double;
2 占用大小不同,double占8个字节,long double根据编译器实现不同,有占用8,10,12字节和16字节四种;
在long double用8字节实现时,long double 和double没有其它区别。对于其它实现方式,还有以下三项区别:
1 运算速度不同,long double占用字节多,运算速度会慢一些;
2 精度不同,long double可以表示更大的精度;
3 表示范围不同,long double可以表示更大范围的浮点数。
1 double类型为C++原始类型,所有编译器均支持,而long double是C99规范增加的新类型,只有支持C99的编译器才支持long double;
2 占用大小不同,double占8个字节,long double根据编译器实现不同,有占用8,10,12字节和16字节四种;
在long double用8字节实现时,long double 和double没有其它区别。对于其它实现方式,还有以下三项区别:
1 运算速度不同,long double占用字节多,运算速度会慢一些;
2 精度不同,long double可以表示更大的精度;
3 表示范围不同,long double可以表示更大范围的浮点数。
展开全部
引用的意思呢就是说返回变量的地址而非变量本身。比如一楼的返回值就是一个double类型的引用,这样子函数结束之后存储返回值的内存单元不会被销毁,保留了它的地址。
例如下面这个例子:
int a=1,b;
b=a;
b++;
这个例子里执行完之后a为1,而b为2。
但这个例子:
int a=1;
int *b;
b=&a;//指针b获取了a的地址
(*b)++;
a和b的值都会变为2
例如下面这个例子:
int a=1,b;
b=a;
b++;
这个例子里执行完之后a为1,而b为2。
但这个例子:
int a=1;
int *b;
b=&a;//指针b获取了a的地址
(*b)++;
a和b的值都会变为2
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
double 8 个字节
long double 8 个字节
long double 和 double 的表示方式相同。 但是, long double 和 double 是不同的类型。
double d(0);
long double ld(0);
size_t t1 = sizeof(d);
size_t t2 = sizeof(ld);
long double 8 个字节
long double 和 double 的表示方式相同。 但是, long double 和 double 是不同的类型。
double d(0);
long double ld(0);
size_t t1 = sizeof(d);
size_t t2 = sizeof(ld);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
标准只保证long double 的精度不低于double(也就是说可以一样),具体是怎样得取决于你的编译器
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
一般来说是占的字节数不同,但对于现在的编译器,比如vc,他们占字节数一样,都是16
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询