PowerShell减法是否在内部将uint32值转换为int32?
发布时间:2021-01-24 08:36:54 所属栏目:系统 来源:网络整理
导读:当我想编写涉及两个[unit32]变量的减法脚本时,我得到了警告“错误:”对于Int32,值太大或太小.“ 一个样本来说明我所看到的 $v1 = [uint32]([int32]::MaxValue + 1)$v2 = [uint32]([int32]::MaxValue + 2)$v2 - $v1 这是正常的行为吗? 我该如何避免错误?
当我想编写涉及两个[unit32]变量的减法脚本时,我得到了警告“错误:”对于Int32,值太大或太小.“ 一个样本来说明我所看到的 $v1 = [uint32]([int32]::MaxValue + 1) $v2 = [uint32]([int32]::MaxValue + 2) $v2 - $v1 这是正常的行为吗? 解决方法显然,PowerShell的算术总是被签名,并且如果必要的话,确实不会转换为下一个更大的类型.作为解决方法,您可以使用[long] / [Int64]:PS> [long]$v2-$v1 1 或者最初将变量声明为[long]. (编辑:好传媒网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |