位操作符-数字如何转化为二进制并进行操作

ECMAScript语言中的位操作符,所有的数值都是以IEEE-754 64位格式存储,但是位操作符不直接存储64位的储存格式,得把数值64转化为32位的整数,执行操作,执行后再将结果转化为64位。

32位中的前31位用于表示整数的值,第32位用于表示数值的符号(0表示整数,1表示负数


例如:18的二进制怎么转换?

  1. 18/2 (整除 右边第一位为0)
  2. 9/2 (4余1 右边第二位为1)
  3. 4/2 (整除 右边第三位为0)
  4. 2/2 (整除 右边第四位位0)
  5. 1/2 (有余 右边第五为为1)

二进制码为 10010
32位补全之后为000000000000000000000000000**10010**

那么如果是二进制码如何转化为数字?
例如:10010
2^4*1 + 2^3* 0 + 2^2 * 0 + 2^1*1 + 2^0* 0
16+0+0+2+0=18


这里写图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用 VBA 的 "DecimalToBinary" 函数将十进制数字转换二进制。示例代码如下: ``` Sub DecimalToBinary() Dim decimals() As Long decimals = Array(10, 15, 20, 25) Dim binary As String For i = LBound(decimals) To UBound(decimals) binary = DecimalToBinary(decimals(i)) MsgBox "十进制数字: " & decimals(i) & " 转换二进制: " & binary Next i End Sub ``` 在上面的代码中,使用了一个名为 "DecimalToBinary" 的函数,用来将十进制数字转换二进制,然后在循环中遍历数组中的每个元素,并将其转换二进制,最后使用 MsgBox 函数显示结果。 ### 回答2: VBA 是 Visual Basic for Applications 的缩写,它是一种用于在应用程序中编写宏的编程语言。要将数组中的十进制数字转换二进制,可以使用 VBA 中的操作符和循环来实现。 首先,需要定义一个包含十进制数字的数组,可以使用 VBA 中的 Array 函数来创建一个数组。例如: Dim decimalArray() As Integer decimalArray = Array(10, 15, 23, 6) 接下来,需要编写一个循环来遍历数组中的每个元素,并将其转换二进制。可以使用 VBA 中的 For Each 循环来实现。例如: Dim binArray() As String Dim decNum As Integer For Each decNum In decimalArray Dim binNum As String binNum = "" Do While decNum > 0 binNum = (decNum Mod 2) & binNum decNum = decNum \ 2 Loop binArray = VBA.Array(binNum) Next 在这个例子中,使用一个名为 binNum 的字符串变量来存储二进制数字。通过不断地取十进制数的模除以 2,并将结果与 binNum 字符串连接起来,最后得到的就是十进制数的二进制表示。 最后,我们使用 VBA 中的 Array 函数来创建一个包含所有二进制数字的数组 binArray,并输出结果: For Each binNum In binArray Debug.Print binNum Next 这样,就可以将数组内的十进制数字转换二进制,并打印输出结果。 ### 回答3: 在VBA中,可以使用一些简单的步骤将数组内的十进制数字转换二进制。 首先,我们需要定义一个数组并将十进制数字赋值给它。例如,我们可以定义一个名为decimals的数组,并将十进制数字放入其中。 然后,我们可以使用For循环来遍历数组中的每个数字,并使用VBA的内置函数来将其转换二进制。在每次循环中,我们将当前的十进制数字赋值给一个变量,并使用VBA的函数Bin()将其转换二进制。将转换后的二进制数字存储在一个新的数组binary中。 最后,我们可以通过输出数组binary的每个元素来显示转换后的二进制数字。 下面是一个示例代码: ```vba Sub DecimalToBinary() Dim decimals(1 To 3) As Integer '定义一个包含3个十进制数字的数组 Dim binary() As String '存储转换后的二进制数字 Dim i As Integer '计数器 decimals(1) = 10 '赋值给数组元素 decimals(2) = 15 decimals(3) = 7 ReDim binary(1 To UBound(decimals)) '调整binary数组的大小与decimals数组相同 For i = 1 To UBound(decimals) Dim dec As Integer dec = decimals(i) binary(i) = Application.WorksheetFunction.Dec2Bin(dec) '将十进制数字转换二进制存储在binary数组中 Next i For i = 1 To UBound(binary) Debug.Print binary(i) '输出转换后的二进制数字 Next i End Sub ``` 在此示例中,我们定义了一个包含3个十进制数字的数组,并将它们转换二进制数字。最后,我们通过使用Debug.Print语句将转换后的二进制数字输出到调试窗口。您可以根据需求更改数组的大小或数字的值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值