- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我想为 JavaScript 枚举编写一个小库。为此,我需要决定如何存储枚举值。因此,我想在比较时使用最快的方式,但我也想要一些可调试的东西,所以我在使用字符串或数字之间犹豫不决。我知道我也可以使用对象,但那是另一个问题了
例如
// I don't want this because when debugging, you'd see just the value 0
var Planets = {Earth:0, Mars:1, Venus: 2}
// I'd prefer this so that Planets.Earth gives me a nice readable value ("Earth")
var Planets = {Earth: 'Earth', Mars: 'Mars'}
但我担心当我使用 if (myPlanet === Planet.Earth)
比较它们时,字符串比较可能需要更长的时间(假设它处于紧密循环中) .应该是这样,因为http://ecma-international.org/ecma-262/5.1/#sec-11.9.6说
If Type(x) is String, then return true if x and y are exactly the same sequence of characters (same length and same characters in corresponding positions); otherwise, return false.
但是当我写一个测试用例的时候,我发现他们花费的时间是一样的http://jsperf.com/string-comparison-versus-number-comparison/2所以它看起来不像是在扫描整个字符串。
我知道这可能是一个微优化,但我的问题是:字符串相等比较是使用指针完成的,因此与数字相等比较一样快吗?
最佳答案
字符串比较可以“一样快”(取决于实现和值)- 或者它可以“慢得多”。
ECMAScript specification描述语义,而不是实现。确定知道的唯一方法是创建一个适用性能基准,在特定实现上运行它。
平凡地,我预计情况会是这样1,字符串实习对特定实现的影响正在观察中。 p>
也就是说,所有来自文字的字符串值(不是字符串对象)都可以简单地存入池中,这样 implIdentityEq("foo", "foo")
是真的——也就是说,只需要一个字符串对象。这样的实习可以在常量折叠之后进行,这样"f" + "oo" -> "foo"
- 同样,根据特定的实现,只要它支持 ECMAScript 语义。
如果这样的实习完成了,那么对于 implStringEq
第一个检查可能是评估 implIdentityEq(x,y)
并且,如果为真,则比较是平凡的,并且在 O(1) 中执行。如果为假,则需要进行普通字符串字符比较,时间复杂度为 O(min(n,m))。
(立即错误也可以用 x.length != y.length
来确定,但这在这里似乎不太相关。)
1 虽然在上面我认为 字符串实习是一个可能的原因,但现代 JavaScript 实现执行很多优化 - 因此,实习只是可以(并且已经)完成的各种优化和代码提升的一小部分!
我创建了一个 "intern breaker" jsperf 。这些数字与上述假设一致。
如果字符串被驻留,则比较在性能上近似于测试“身份” - 虽然它比数字比较慢,但仍然比字符比较快得多-字符串比较。
根据上述断言,IE10 似乎没有考虑对象身份来进行快速通过字符串比较,尽管它确实使用了快速失败长度检查。
在 Chrome 和 Firefox 中,比较两个不相等的内部字符串也和两个相同的字符串一样快 - 比较两个不同内部字符串可能是一种特殊情况.
即使对于小字符串(长度 = 8),实习也可以快得多。 IE10 再次显示它没有这种“优化”,即使它似乎具有高效的字符串比较实现。
当遇到第一个不同的字符时,字符串比较很快就会失败:即使比较等长的长字符串也可能只比较前几个字符。
Do common JavaScript implementations use string interning? (但没有给出引用)
Yes. In general any literal string, identifier, or other constant string in JS source is interned. However implementation details (exactly what is interned for instance) varies, as well as when the interning occurs
参见 JS_InternString (FF 确实有字符串实习,尽管我不知道字符串在哪里/如何从 JavaScript 隐式实习)
关于javascript - JavaScript 字符串比较和数字比较一样快吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23836825/
我想使用 NetworkX Graph 对象作为 Python dict 中的键。但是,我不希望默认的比较行为(即通过对象的地址)。相反,我希望同构图是 dict 中相同元素的键。 此行为是否已在某处
这个问题已经有答案了: What is the most effective way for float and double comparison? (33 个回答) 已关闭 7 年前。 在您认为我
我正在学习 C 编程,为了练习,我找到了一个需要解决的任务。这有点像一个游戏,有人选择一个单词,其他人猜测字母。我必须检查有多少给定的单词可能是所选单词的正确答案。 输入: 3 3//数字 n 和 m
我两天前开始学习C,在做作业时遇到了问题。我们的目的是从字符数组中获取字符列表,并通过计算连续字符并将其替换为数字来缩短它。对“a4b5c5”说“aaaabbbbbccccc”。这是我到目前为止的代码
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
为什么我在 if 中的比较不起作用?答案应该是 8 但它返回 0。 function findMissing(missingArray){ var getArray = missing
我想知道为什么以下 JavaScript 比较会给出不同的结果。 (1==true==1) true (2==true==2) false (0==false==0) false (0==false)
我想知道是否有人可以帮助我完成这个程序。编写一个接受两个字符串的函数。该函数应该将这两个字符串与字典顺序上排在第一位的字符串组合起来。两个字符串之间应该有一个空格。在一行上打印结果字符串。在一行上打印
有谁知道一个免费的开源库(实用程序类),它允许您比较一个 Java bean 的两个实例并返回一个属性列表/数组,这两个实例的值不同?请发布一个小样本。 干杯 托马斯 最佳答案 BeanCompara
我是java新手。任何人都可以给出以下类声明的含义 public class ListNode, V> { K key; V value; ListNode next;
我需要用 C 语言计算和比较 3 种不同大小(100 * 100、1000 * 1000 和 10000 * 10000)的 2 个矩阵相乘的执行时间。我编写了以下简单代码来为 1000 * 1000
当我在 ACCESS 2007 中运行以下 SQL 时 Select Location, COUNT(ApartmentBuildings) AS TotalIBuildingsManaged Fro
根据我对互斥锁的了解——它们通常提供对共享资源的锁定功能。因此,如果一个新线程想要访问这个锁定的共享资源——它要么退出,要么必须不断轮询锁(并在等待锁时浪费处理器周期)。 但是,监视器具有条件变量,它
通常在编程中,不应该比较浮点数据类型是否相等,因为存储的值通常是近似值。 由于两个非整数 Oracle NUMBER 值的存储方式不同(以 10 为基数),是否可以可靠地比较它们是否相等? 最佳答案
使用 PowerShell 时,我们偶尔会比较不同类型的对象。一个常见的场景是 $int -eq $bool (即其中 0 -eq $false 、 0 -ne $true 和任何非零值仅等于真,但不
#include #define MAX 1000 void any(char s1[], char s2[], char s3[]); int main() { char string1[
我想比较两个日期。 从这两个日期中,我只使用 ToShortDateString() 获取日期组件, 如下所示。现在的问题是当我比较两个日期时。它的 throw 错误—— "Operator >= c
用户输入一个数字( float 或整数),并且它必须大于下限。 这是从 UITextField 获取数字的代码: NSNumberFormatter * f = [[NSNumberFormatter
我已经摆弄这段代码大约一个小时了,它让我难以置信。我认为解决方案相当简单,但我似乎无法弄清楚。无论如何,这里去。我制作了一个 javascript 函数来检查用户输入的字符,以便它只能接受 7 个字符
我不太明白为什么当我们在不覆盖 equals 的情况下比较具有相同类属性的两个实例时方法,它将给出 false .但它会给出 true当我们比较一个案例类的两个实例时。例如 class A(val
我是一名优秀的程序员,十分优秀!