- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在小于 1 的数字上使用逻辑运算符时,我得到了意想不到的结果。
我认为 VBA 会将除零以外的任何数字视为 TRUE,但似乎将分数视为 FALSE。这么奇怪。
我误会了什么。
我把它归结为这两行 VBA 代码。第一个返回我所期望的,但不是第二个。
谢谢
kbrown4600
MsgBox 1 And True ' returns 1
MsgBox 0.5 And True ' returns 0. Unexpected result
最佳答案
位运算符不进行浮点数学运算,因此在为 And
给出操作数之前会进行隐式转换。运算符来做它的按位操作。
“逻辑”运算符是一个骗局。没有这样的事情,我们一直被骗 - 这是另一个圣诞老人/牙仙/复活节兔子(没关系,我被告知复活节兔子是真实的):他们总是按位运算符,不管你给他们什么。
而且由于按位数学产生0
,那么它只能意味着隐式转换只是切掉小数部分。
底线,...不要对非整数进行按位处理,并且通常避免隐式类型转换。标准库为此提供了一堆显式转换函数:
Debug.Print VBA.Conversion.CLng(0.5) And True '<~ explicit conversion
CLng
是
documented舍入
0.5
下至
0
, 如果您需要确定是向下取整到 0 还是向上取整到 1,请明确说明:
Debug.Print CInt(0.5 + 0.01) And True '<~ explicit "round 0.5 up to 1"
When the fractional part is exactly 0.5, CInt and CLng always round it to the nearest even number. For example, 0.5 rounds to 0, and 1.5 rounds to 2.
I thought VBA would treat any number other than zero as TRUE
-1
是
True
, 但是
True
是
Not False
.这使得
True
-1
在内部,可能是一个 32 位整数,所以在二进制中它可能看起来像这样:
11111111 11111111 11111111 11111111
True
必须有这个表示,因为这需要是
False
的表示:
00000000 00000000 00000000 00000000
MsgBox 42 And 12
,您将得到按位结果
8
:
00000000 00000000 00000000 00101010 ' 42
00000000 00000000 00000000 00001100 ' 12
00000000 00000000 00000000 00001000 ' 8 (AND)
And
的结果运算符总是按位和结果 - 我们所说的“逻辑运算符”只是使用 bool 操作数的按位运算符:
00000000 00000000 00000000 00000000 ' False
11111111 11111111 11111111 11111111 ' True
00000000 00000000 00000000 00000000 ' False (AND)
True
变成
-1
, 那就是
0.5
变成
0
.
关于excel - 将分数视为 FALSE 的逻辑运算符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62093720/
当我尝试加载库 Raster 时,我收到如下错误: 错误:inDL(x, as.logic(local), as.logic(now), ...) 中的“raster”的包或命名空间加载失败:无法加载
当我尝试加载库 Raster 时,我收到如下错误: 错误:inDL(x, as.logic(local), as.logic(now), ...) 中的“raster”的包或命名空间加载失败:无法加载
望着help section about_Comparison_Operators of PowerShell我是这样理解的: PS C:\> $false,$false -eq $true PS C
我刚刚修改了旧代码,现在似乎没有任何效果。请您指导我哪里出错了。 一些不起作用的事情是: 以前,焦点始终停留在屏幕上唯一的输入字段上。 (现在不行了),代码中的 if else 条件也不起作用。 On
请帮我找到一个使用普通 'ol javascript 的解决方案(我无法使用外部框架)。此外,CSS :hover 选择器不适用于现实世界的实现。 注册事件发生的事情设置所有调用最后注册事件数组项。
我想创建一个软件来为残障 child 交通规划公交路线(及其最佳载客量)。 这些总线具有以下规范: m 个座位(最多 7 个 - 因为有司机和助理) o 轮椅“座位”(最多 4 个) 固定的最大负载量
有人能帮我吗?似乎我的 for 逻辑根本不起作用,因为它一直在上午 12:00 返回我的开始时间 这是我的代码 Sub forlogic() Dim i As Single Dim t
我正在尝试设置 OR两个切片器过滤器之间的逻辑。两个切片器来自相同的数据集。以下是更多详细信息: 我的源表: 带切片器的视觉效果: 我的目标是,如果我从切片器 1 和切片器 2 中选择任何值,我的视觉
我有以下 C 语句: int res = x & (x ^ y); 有没有办法做同样的事情,但每次只使用一次x和y? 例如: x | (~x & y) == x | y 最佳答案 是的,通过扩展 xo
我正在创建 Azure 逻辑应用程序以将新的 Sharepoint 文件添加到 Azure Blob。 Sharepoint 由我的公司运行,我使用我的凭据登录来为逻辑应用程序创建 Sharepoin
我有一个问题要求为给定函数合成最简单的乘积表达式总和。基本上,如果 AB == CD,则函数为 1,否则为 0,结果如下: (!A && !B && !C && !D) || (!A && B &&
我正在尝试确定是否可以在不溢出的情况下计算两个 32 位整数的总和,同时仅使用某些按位运算符和其他运算符。因此,如果整数 x 和 y 可以相加而不会溢出,则以下代码应返回 1,否则返回 0。 ((((
处理乍一看需要许多嵌套 if 语句的复杂业务逻辑的好方法是什么? 例子: 折扣券。可能: 1a) 超值折扣 1b) 百分比折扣 2a) 正常折扣 2b) 累进折扣 3a) 需要访问优惠券 3b) 不需
假设我有一个“numbers”对象数组,其中包含“startNo”整数和“endNo”整数。 数组中可以有多个“数字”,我想获取一个包含修改对象的新数组,该数组仅具有不重叠的范围。 例如:如果数组有:
我在这个问题上遇到了困难。我正在使用 JavaScript。 我有一个文本区域,用于检测 @ 输入并将其位置存储在数组中。 var input = "@a @b @c" //textarea var
默认 IN 使用 OR 基本逻辑。有没有办法在范围内使用 AND 基本逻辑。 例如下面的查询 SELECT ItemId,CategoryID FROM ItemCategories WHERE Ca
我想在您将鼠标悬停在网站图像上时添加叠加层。我在这里实现了这个,它工作正常http://jsfiddle.net/stujLbjh/ 这是js代码: var divs = document.query
这个问题在这里已经有了答案: Which is faster: x>2 是否比 x>>31 快?换句话说,sar x, 2 是否比 sar x, 31 快?我做了一些简单的测试,他们似乎有相同的速度
我有grails criteriaQuery,我在这里再次检查OR逻辑,就像这样一个状态变量: or { eq("status", Status.ONE) eq("status",
我有grails criteriaQuery,我在这里再次检查OR逻辑,就像这样一个状态变量: or { eq("status", Status.ONE) eq("status",
我是一名优秀的程序员,十分优秀!