我想将十进制变量“trans”分配给双变量“this.Opacity”。

decimal trans = trackBar1.Value / 5000;
this.Opacity = trans;

当我构建应用程序时,会出现以下错误:

无法将类型decimal隐式转换为double


当前回答

假设您使用的是WinForms,Form.Optity是double类型,因此您应该使用:

double trans = trackBar1.Value / 5000.0;
this.Opacity = trans;

除非您在其他地方需要该值,否则写起来更简单:

this.Opacity = trackBar1.Value / 5000.0;

当您将代码更改为简单的双精度时,控件不起作用的原因是:

double trans = trackbar1.Value / 5000;

它将5000解释为整数,因为trackbar1.Value也是整数,所以trans值始终为零。通过添加.0显式地使数字成为浮点值,编译器现在可以将其解释为双精度值并执行正确的计算。

其他回答

假设您使用的是WinForms,Form.Optity是double类型,因此您应该使用:

double trans = trackBar1.Value / 5000.0;
this.Opacity = trans;

除非您在其他地方需要该值,否则写起来更简单:

this.Opacity = trackBar1.Value / 5000.0;

当您将代码更改为简单的双精度时,控件不起作用的原因是:

double trans = trackbar1.Value / 5000;

它将5000解释为整数,因为trackbar1.Value也是整数,所以trans值始终为零。通过添加.0显式地使数字成为浮点值,编译器现在可以将其解释为双精度值并执行正确的计算。

不需要像这样显式转换为double:

double trans = (double) trackBar1.Value / 5000.0;

将常数确定为5000.0(或5000d)就足够了:

double trans = trackBar1.Value / 5000.0;
double trans = trackBar1.Value / 5000d;

听起来是这样的。不透明度是一个双值,编译器不喜欢你试图将一个十进制值塞进其中。

请尝试以下代码:

十进制值

decimal d1 = 3234.3434m;

转换为双精度

double r1 = Decimal.ToDouble(d1);

对于一般问题“十进制与双精度?”的更一般的答案:

小数用于货币计算以保持精度。Double用于不受微小差异影响的科学计算。由于Double是CPU固有的类型(内部表示形式存储在基数2中),因此使用Double进行的计算比Decimal(内部表示为基数10)执行得更好。