任務(wù)19-時(shí)間對象、引用類型

問答

1. 基礎(chǔ)類型有哪些?復(fù)雜類型有哪些?有什么特征?

  • 基礎(chǔ)類型:Number、Boolean、Null、Undefined、String。
    特征:基礎(chǔ)類型指的是保存在棧內(nèi)存中的簡單數(shù)據(jù)段,它是按值訪問,操作的是它們實(shí)際保存的值;基礎(chǔ)類型從一個(gè)變量向一個(gè)變量復(fù)制時(shí),會(huì)在棧中創(chuàng)建一個(gè)新值,然后把值復(fù)制到為新變量分配的位置上。
  • 復(fù)雜類型:對象、數(shù)組、函數(shù)、正則。
    特征:復(fù)雜類型指的是是那些保存在堆內(nèi)存中的對象,變量中保存的實(shí)際上只是一個(gè)指針,這個(gè)指針執(zhí)行內(nèi)存中的另一個(gè)位置,由該位置保存對象。

2. 如下代碼的輸出? 為什么?

<pre>
var obj1 = {a:1, b:2}; var obj2 = {a:1, b:2}; console.log(obj1 == obj2); console.log(obj1 = obj2); console.log(obj1 == obj2);
</pre>

輸出結(jié)果及原因:
<pre>
var obj1 = {a:1, b:2}; var obj2 = {a:1, b:2}; console.log(obj1 == obj2);// false obj1和obj2代表了兩個(gè)不同的對象,盡管它們的內(nèi)容相同,但其內(nèi)部的地址,以及地址所指引的空間都不相同,所以它們是兩個(gè)對象。 console.log(obj1 = obj2);//Object {a: 1, b: 2} 對象obj2賦值給obj1,obj1的內(nèi)存改變了,指向同一個(gè)位置了。 console.log(obj1 == obj2);//true 經(jīng)過上述步驟之后,兩個(gè)變量均指向同一位置,所以返回true。
</pre>

代碼

1. 寫一個(gè)函數(shù)getIntv,獲取從當(dāng)前時(shí)間到指定日期的間隔時(shí)間

<pre>
var str = getIntv("2016-01-08");
console.log(str); // 距除夕還有 20 天 15 小時(shí) 20 分 10 秒
</pre>

代碼如下:
<pre>
function getIntv(val){
var now = new Date();
var schedule = new Date(val);
var result = schedule - now;
var days = Math.floor(result/(24*60*60*1000));
var hours = Math.floor((result-days*24*60*60*1000)/(60*60*1000));
var minutes = Math.floor((result-days*24*60*60*1000-hours*60*60*1000)/(60*1000));
var seconds = Math.floor((result-days*24*60*60*1000-hours*60*60*1000-minutes*60*1000)/1000);
var str="距離雙十一還有"+days+"天"+hours+"小時(shí)"+minutes+"分鐘"+seconds+"秒";
return str;
}
var str = getIntv ("2016-11-11");
console.log(str);
</pre>

輸出結(jié)果:

2. 把數(shù)字日期改成中文日期

<pre>
var str = getChsDate('2015-01-08');
console.log(str); // 二零一五年一月八日
</pre>

代碼如下:
<pre>function getChsDate(str){ var timeChin = ["零","一", "二", "三", "四", "五", "六", "七", "八", "九", "十", "十一", "十二", "十三", "十四", "十五", "十六", "十七", "十八", "十九", "二十", "二十一", "二十二", "二十三", "二十四", "二十五", "二十六", "二十七", "二十八", "二十九", "三十", "三十一"]; if(!(new Date(str).getDate()==str.substring(str.length-2))) { alert("Oh,輸入的日期不對!"); return; } var date = new Date(Date.parse(str)); var arr = String(date.getFullYear()).split(""); var year = ""; for(var i = 0;i < arr.length;i++){ year += timeChin[Number(arr[i])]; } var month = timeChin[date.getMonth() + 1]; var date = timeChin[date.getDate()]; return year + "年" + month + "月" + date + "日"; }
</pre>

輸出結(jié)果:

3. 寫一個(gè)函數(shù)獲取n天前的日期

<pre>var lastWeek = getLastNDays(7); // ‘2016-01-08’ var lastMonth = getLastNDays(30); //'2015-12-15'</pre>

代碼如下:
<pre>
function getLastNDays(n){
var milliseconds = new Date() - n*24*60*60*1000
var date = new Date(milliseconds);
var year = date.getFullYear();
var month = date.getMonth() + 1;
var date = date.getDate();
return year +"年"+month+"月"+date+"日";
}
</pre>

輸出結(jié)果:

4. 樓梯有200級(jí),每次走1級(jí)或是2級(jí),從底走到頂一共有多少種走法?用代碼(遞歸)實(shí)現(xiàn)

這就是一個(gè)斐波那契數(shù)列:
登上第一級(jí)臺(tái)階有一種登法;
登上兩級(jí)臺(tái)階,有兩種登法;
登上三級(jí)臺(tái)階,有三種登法;
登上四級(jí)臺(tái)階,有五種登法;
......
登上n級(jí)臺(tái)階,有f(n-1)+f(n-2)種登法。
<pre>
`function febSteps(number) {
if (number < 1) {
return;
}
if (number === 1) {
return 1;
} else if (number === 2) {
return 2;
} else {
return febSteps(number - 1) + febSteps(number - 2);
}
}

console.log(febSteps(10));
console.log(febSteps(20));
console.log(febSteps(30));
console.log(febSteps(40));
...
console.log(febSteps(200));`
</pre>

5. 完善如下代碼,用于獲取執(zhí)行時(shí)間如:

  • 將4,5這兩道題的順序調(diào)換一下,個(gè)人覺得有這兩道題可以聯(lián)系起來處理,在這道題中,我們可以用上道題作為例子,可以更直觀的展現(xiàn)如何獲取執(zhí)行時(shí)間,因?yàn)楦鶕?jù)輸出結(jié)果,我們會(huì)發(fā)現(xiàn)遞歸越深,執(zhí)行的時(shí)間就會(huì)越久。
    <pre>
    function febSteps(number) { if (number < 1) { return; } if (number === 1) { return 1; } else if (number === 2) { return 2; } else { return febSteps(number - 1) + febSteps(number - 2); } } var Runtime = (function(){ var startTime,endTime; var obj = { start: function(){ //code here ..., 當(dāng)前時(shí)間 startTime = Date.now(); }, end: function(){ //code here ... 結(jié)束時(shí)間 endTime = Date.now(); }, get: function(){ //code here ... 獲取執(zhí)行時(shí)間 return endTime-startTime; } }; return obj; }()); for(var i=30;i<45;i++){ Runtime.start(); //todo something febSteps(i); Runtime.end(); console.log( "走"+ i + "級(jí)臺(tái)階,運(yùn)行時(shí)間是:" + Runtime.get() + "ms"); }</pre>

輸出結(jié)果:

6. 寫一個(gè)json對象深拷貝的方法,json對象可以多層嵌套,值可以是字符串、數(shù)字、布爾、json對象中的任意項(xiàng)

<pre>`
var Fairy = {
  "birthDay":"1984.01.01",

}
var Snow= {
  "birthYear":"1980",
}

function deepCopy(copyFrom, copyTo) {
    var copyTo = copyTo || {};
    for (var i in copyFrom) {
      if (typeof copyFrom[i] === 'object') {
        copyTo[i] = (copyFrom[i].constructor === Array) ? [] : {};
        deepCopy(copyFrom[i], copyTo[i]);
      } else {
         copyTo[i] = copyFrom[i];
      }
    }
    return copyTo;
  }

var Snow = deepCopy(Fairy,Snow );
Snow.birthYear = "1985";
console.log (Snow.birthYear);
console.log (Fairy.birthDay);

Fairy.address = ["湖北","武漢"];
var Snow =deepCopy(Fairy,Snow );
Snow.address.push("光谷");

console.log(Snow.address);
console.log(Fairy.address);
`</pre>

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,461評論 6 532
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,538評論 3 417
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,423評論 0 375
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,991評論 1 312
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,761評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,207評論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,268評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,419評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,959評論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,782評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,983評論 1 369
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,528評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,222評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,653評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,901評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,678評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,978評論 2 374

推薦閱讀更多精彩內(nèi)容