PowerShell减法是否在内部将uint32值转换为int32?
发布时间:2021-01-24 00:53 所属栏目:52 来源:网络整理
导读:当我想编写涉及两个[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]. (编辑:ASP站长网) |
相关内容
网友评论
推荐文章
热点阅读