草庐IT

奇怪的面试(上)

全部标签

ruby - 使用哈希默认值时出现奇怪的意外行为(消失/更改值),例如哈希.new([])

考虑这段代码:h=Hash.new(0)#Newhashpairswillbydefaulthave0asvaluesh[1]+=1#=>{1=>1}h[2]+=2#=>{2=>2}没关系,但是:h=Hash.new([])#Emptyarrayasdefaultvalueh[1]{1=>[1]}←Okh[2]{1=>[1,2],2=>[1,2]}←Whydid`1`change?h[3]{1=>[1,2,3],2=>[1,2,3]}←Whereis`3`?此时我希望散列为:{1=>[1],2=>[2],3=>[3]}但远非如此。发生了什么,我怎样才能得到我期望的行为?

javascript - IE9 Javascript 比 IE8 慢 - 这很奇怪!

我很难解释为什么以下代码在IE9中比在IE8中运行慢!下面是一些测试代码,在OSX、WinXP和Win7plusIE7和8上的(最新)FF/Chrome/Safari中运行大约半秒(为简单起见,我删除了使其在IE6中工作的调整)。出于某种我无法解释的原因,它在IE9中很糟糕,又慢又笨重。减少setTimeout的时间会使它更快一些,但同样不流畅。我已经尝试删除和基准化一些可能是瓶颈的东西(例如Math.min...所有这些都没有改变。我很困惑......谁能给我指出正确的方向?......最好是不需要浏览器嗅探的方向?这是测试代码...xxxxxxxxxxxxxxxxxxxxxxxxx

javascript - 窗口对象中的奇怪自身对象

我无法理解为什么window在self下,而self在window对象下。如果您转到开发工具或Firebug并编写window,您将得到DOMwindow对象,self位于该对象下。奇怪的是window又在self下了!你可以写window.self.window.self.window.self.window.self.window.self.window.self.window.self.window.self.window.self.window.self.window.self.window.self.window.self.window.self.window.self.wi

javascript - 带有数组的javascript的奇怪行为

让我们考虑以下JavaScript片段vararr=[];functionpushMe(){vartemp={"name":"me"};arr.push(temp)console.log(arr)temp["name"]="you";arr.push(temp)console.log(arr)}我惊讶地看到输出为[Object{name="you"},Object{name="you"}]当我们推送引用时,两者必须引用同一个对象。但至少在第一次推送之后输出必须像Object{name="me"}为什么会这样??谢谢:) 最佳答案 C

javascript - 奇怪的 javascript 表达式的解释是什么?

在JavaScript中,以下代码行给出的答案为1+!{}[true]我不明白怎么办?感谢任何大师的解释。 最佳答案 {}是一个空对象。因此{}[0]或{}[true]或{}[1]等是未定义的添加!将{}[0]转换为boolean,返回相反的值。(undefined变为false,因此返回true)。添加+将其转换为int,因此true变为1。 关于javascript-奇怪的javascript表达式的解释是什么?,我们在StackOverflow上找到一个类似的问题:

javascript - 在 JavaScript 中使用++ 时的奇怪行为

每个人都知道JavaScript中两个字符串的基本连接:>"Hello"+"World!"'HelloWorld!'但是如果我们使用++而不是+会发生什么?我刚遇到以下奇怪行为:>"Hello"++"World!"'HelloNaN'>"Hello"++""'Hello0'从上面的例子中,我可以看到第二个字符串被转换为数字。因此,将具有valueOf属性的对象作为函数传递,该函数返回的值将被转换。>"Hello"++({valueOf:function(){return1;}})'Hello1'正如预期的那样,它显示"Hello1"。为什么在Number中转换第二个字符串?为什么不抛出

javascript - 奇怪的 javascript 行为(作业)

交换两个数字C++:inta=3;intb=5;a^=b^=a^=b;printf("%d,%d\n",a,b);//5,3PHP:$a=3;$b=5;$a^=$b^=$a^=$b;echo"$a,$b\n";//5,3Javascript:>a=3;b=5;a^=b^=a^=b;[a,b][0,3]为什么?看起来所有变量在所有表达式执行之前都已初始化... 最佳答案 你在JS中的赋值等同于a=a^(b=b^(a=a^b));这是从左到右计算的,我们得到3^(5^(3^5))所以一个简单的解决办法就是写a=(b^=(a^=b))^a

javascript - react-native fetch 返回奇怪的响应

我正在使用fetch从这样的API获取一些东西:fetch('http://facebook.github.io/react-native/movies.json').then(data=>console.log(data),error=>console.log(error))但是我得到的是下面的对象,并不是实际的数据_bodyBlob:Blob_bodyInit:Blobheaders:Headersok:truestatus:200statusText:undefinedtype:"default"url:"http://facebook.github.io/react-nativ

javascript - 用于扩展 jQuery 的奇怪语法

我最近在另一篇文章(jQuerySetCursorPositioninTextArea)上看到这段代码newfunction($){$.fn.setCursorPosition=function(pos){//functionbodyomitted,notrelevanttoquestion}}(jQuery);在试图理解它在做什么之后花了很长时间,我终于弄清楚它只是创建一个带有参数$的新函数,然后使用jQuery作为参数值调用它。所以实际上,它只是这样做:jQuery.fn.setCursorPosition=function(pos){//functionbodyomitted,n

javascript - javascript中的切换条件很奇怪

我发现下面这两个是等价的,但是奇怪的是,单个=不是关系运算符而是赋值运算符,为什么它在第二个中有效?首先:switch(true){casecolor=='green':casecolor=='red':casecolor=='blue':casecolor=='pink':alert('colorful')break;casecolor=='black':casecolor=='white':alert('classical')break;default:alert('dull')break;}第二个:switch(color){casecolor='green':casecolor