为什么我会在';智能铸造';,在kotlin中使用委托时?

为什么我会在';智能铸造';,在kotlin中使用委托时?,kotlin,Kotlin,我在Kotlin中创建了一个委托类,用于“循环”变量,如小时: 将“25”与初始值为“0”的小时相加时,结果应为“1”, 因为没有“25小时”这个词 我创建的类可以工作,但是当我重新分配这样一个委托变量时, 然后使用“print(…)”打印它, 我得到一个错误,说“智能转换是不可能的,X是一个可变变量” 我做错什么了吗? 我怎样才能解决这个问题 我尝试添加一个明确的演员阵容,这很有帮助, 但是给出了一个警告说“不需要石膏”,而没有石膏它就不能工作 这是再现错误的最小代码: package

我在Kotlin中创建了一个委托类,用于“循环”变量,如小时:

将“25”与初始值为“0”的小时相加时,结果应为“1”, 因为没有“25小时”这个词

我创建的类可以工作,但是当我重新分配这样一个委托变量时, 然后使用“print(…)”打印它, 我得到一个错误,说“智能转换是不可能的,X是一个可变变量”

我做错什么了吗? 我怎样才能解决这个问题

我尝试添加一个明确的演员阵容,这很有帮助, 但是给出了一个警告说“不需要石膏”,而没有石膏它就不能工作

这是再现错误的最小代码:

    package <package name>

    import kotlin.reflect.KProperty


    fun main(){

        val test = Test()

        test.hour = 25

        print(test.hour)    

        // this works:      print(test.hour as Number)   ("No cast needed")

    }

    // just a class which uses the delegate
    class Test {
        var hour by CyclicVariable(24)
    }

    // the delegate class
    class CyclicVariable(val max: Number, var value: Number = 0){

        operator fun getValue(reference: Any?, property: KProperty<*>): Number = value.toDouble()

        operator fun setValue(reference: Any?, property: KProperty<*>, value: Number) {
            val result = value.toDouble() % max.toDouble()
            this.value = if (result >= 0) result else max.toDouble() + result
        }

    }

包
导入kotlin.reflect.KProperty
主要内容(){
val测试=测试()
测试时间=25小时
打印(测试时间)
//这项工作:打印(test.hour作为数字)(“无需浇铸”)
}
//只是一个使用委托的类
课堂测试{
按周期变量计算的var小时数(24)
}
//委托类
类周期变量(val最大值:数字,var值:数字=0){
运算符fun getValue(引用:Any?,属性:KProperty):Number=value.toDouble()
运算符fun setValue(引用:Any?,属性:KProperty,值:Number){
val result=value.toDouble()%max.toDouble()
this.value=if(result>=0)result else max.toDouble()+result
}
}
预期结果:
1.0
在控制台上

实际结果:
错误:(12,11)Kotlin:智能转换为“Int”是不可能的,因为“test.hour”是一个可变属性,此时可能已更改该属性

出现问题,因为没有具有
Number
参数的方法
print
。 您只需使用
test.hour.toString()


Kotlin尝试将此变量强制转换为
Int
,正如它所看到的,您将Int设置为变量:
test.hour=25
。但是它不能,因为变量是可变的。

这个示例即使没有打印也不适用于我,它无法生成,因为
setValue
Number
+
Double
操作未解决。您需要为每种数字类型创建离散实现,以使其正常工作。在@Pawel的注释之后,我再次测试了我的代码,因为我在测试代码时它对我有效。似乎我忘了在同一个包中为Number创建了一个扩展函数,用于添加两个“Number”。我尝试了您的建议,效果很好(使用
toString()
)。在进一步试验的同时,我也认为我知道为什么“不必要的强制转换”会起作用:因为它似乎使用了
print(message:Any?
)方法,而不是更具体的
print(message:Int)
,我相信这会阻止智能强制转换。