JavaScript 深入理解之基本數(shù)據(jù)類型(Primitive Values)

變量是內(nèi)存中被分配的指定空間的名字, 而變量的值是這個空間中的存儲的數(shù)據(jù)螃壤。
JavaScript 是個動態(tài)類型的編程語言(關(guān)于語言的分類可以研究一下這篇文字 類型系統(tǒng)(Type System)

變量本身數(shù)據(jù)類型不固定的語言稱之為動態(tài)語言氢烘。
與之相反的是靜態(tài)類型的編程語言钠乏,指的是在定義變量時必須指定變量類型幕与,如果賦值的時候類型不匹配鸟召,就會報錯腥寇。

JavaScript 的變量的數(shù)據(jù)類型可以分為兩類:基本類型(Primitive Values)和引用類型(Reference Values)民珍,基本類型也稱為簡單類型仑扑,由于其占據(jù)空間固定,是簡單的數(shù)據(jù)段,為了便于提升變量查詢速度段磨,將其存儲在棧中取逾,即按值訪問。

基本類型主要有五種:

  • String
  • Number
  • Boolean
  • Null
  • undefined
  • ES6新增了 Symbol(Symbol 生成一個全局的唯一的值)苹支。

基本類型在內(nèi)存中占據(jù)空間小且大小固定 砾隅,他們的值保存在棧(stack)空間,是按值來訪問债蜜。就是說你可以操作保存在變量中的實際值晴埂。

在 JavaScript 里變量的存儲包含三個部分:

  • 棧區(qū)的變量標示符;
  • 棧區(qū)變量的值策幼;
  • 堆區(qū)存儲的對象邑时。

基本類型的數(shù)據(jù)類型有以下4個特點:

一奴紧、值不可變

任何方法都無法改變一個基本類型的值特姐,比如一個字符串:

var blog = 'Felix';
var blogLower = blog. toLowerCase(); // toLowerCase 函數(shù)返回一個新字符串
console.log(blogLower) // 'felix'
console.log(blog); //  'Felix'

var blogSub = blog.substring(0, 3); // substring 函數(shù)返回一個新字符串
console.log(blogSub); // 'Fel'
console.log(blog); // 'Felix'

上面的代碼,我們可以看到 blog 在調(diào)用字符串函數(shù) toLowerCase 和 substring 后并未發(fā)生改變黍氮。toLowerCase 和 substring 返回的都是一個新的字符串唐含。

var user = 'Felix';
user.age = 32;
user.getName = function(){//...};
 
console.log(user.age); // undefined
console.log(user.getName); // undefined

通過上面的代碼可知,我們不能給基本類型的數(shù)據(jù)添加屬性和方法沫浆,再次說明基本類型的數(shù)據(jù)是不可變的捷枯。

二、值的比較

如下代碼

var a = 1;
var b = true;
console.log(a == b); // true

這里其實這是隱式類型轉(zhuǎn)換(Implicit Type Conversion)和 == 運算符的知識了专执,也就是說在用 == 比較兩個不同類型的變量時會進行一些隱式類型轉(zhuǎn)換淮捆。像上面的比較先會把 a 的數(shù)字 1 轉(zhuǎn)換為 true 再和數(shù)字 b 進行比較,結(jié)果就是 true 了本股。 這是當比較的兩個值的類型不同的時候 == 運算符會進行隱式類型轉(zhuǎn)換攀痊,因此在做比較運算時,即使兩個值和類型都相同拄显,也強烈建議使用 === 苟径。

三、存放在棧區(qū)的

棧區(qū)指內(nèi)存中的棧內(nèi)存躬审,假如有以下幾個基本類型的變量:

var name = 'Felix';
var isStudent = true;
var age = 32;

那么它的存儲結(jié)構(gòu)如下圖:

<img src="https://user-images.githubusercontent.com/8563874/47794531-a1bbc500-dd5b-11e8-9bfc-0df9911e7ed0.png" width="400">

棧區(qū)包括了變量的標識符和變量的值棘街。

四、 typeOf 操作符檢測

基本數(shù)據(jù)類型的數(shù)據(jù)類型檢測使用 typeOf() 函數(shù)承边,除 null遭殉,null 有屬于自己的數(shù)據(jù)類型 Null 。

typeof ''; // string 有效
typeof 1; // number 有效
typeof Symbol(); // symbol 有效
typeof true; //boolean 有效
typeof undefined; //undefined 有效
typeof null; //object 無效
  • 對于引用類型博助,除 function 以外恩沽,一律返回 object 類型。
  • 對于 function 返回 function 類型翔始。
typeof [] ; //object 無效
typeof new Function(); // function 有效
typeof new Date(); //object 無效
typeof new RegExp(); //object 無效
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末罗心,一起剝皮案震驚了整個濱河市里伯,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌渤闷,老刑警劉巖疾瓮,帶你破解...
    沈念sama閱讀 217,084評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異飒箭,居然都是意外死亡狼电,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評論 3 392
  • 文/潘曉璐 我一進店門弦蹂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來肩碟,“玉大人,你說我怎么就攤上這事凸椿∠髌恚” “怎么了?”我有些...
    開封第一講書人閱讀 163,450評論 0 353
  • 文/不壞的土叔 我叫張陵脑漫,是天一觀的道長髓抑。 經(jīng)常有香客問我,道長优幸,這世上最難降的妖魔是什么吨拍? 我笑而不...
    開封第一講書人閱讀 58,322評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮网杆,結(jié)果婚禮上羹饰,老公的妹妹穿的比我還像新娘。我一直安慰自己碳却,他們只是感情好队秩,可當我...
    茶點故事閱讀 67,370評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著追城,像睡著了一般刹碾。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上座柱,一...
    開封第一講書人閱讀 51,274評論 1 300
  • 那天迷帜,我揣著相機與錄音,去河邊找鬼色洞。 笑死戏锹,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的火诸。 我是一名探鬼主播锦针,決...
    沈念sama閱讀 40,126評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了奈搜?” 一聲冷哼從身側(cè)響起悉盆,我...
    開封第一講書人閱讀 38,980評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎馋吗,沒想到半個月后焕盟,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,414評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡宏粤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,599評論 3 334
  • 正文 我和宋清朗相戀三年脚翘,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片绍哎。...
    茶點故事閱讀 39,773評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖崇堰,靈堂內(nèi)的尸體忽然破棺而出沃于,到底是詐尸還是另有隱情,我是刑警寧澤赶袄,帶...
    沈念sama閱讀 35,470評論 5 344
  • 正文 年R本政府宣布揽涮,位于F島的核電站抠藕,受9級特大地震影響饿肺,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜盾似,卻給世界環(huán)境...
    茶點故事閱讀 41,080評論 3 327
  • 文/蒙蒙 一敬辣、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧零院,春花似錦溉跃、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,713評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至打洼,卻和暖如春龄糊,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背募疮。 一陣腳步聲響...
    開封第一講書人閱讀 32,852評論 1 269
  • 我被黑心中介騙來泰國打工炫惩, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人阿浓。 一個月前我還...
    沈念sama閱讀 47,865評論 2 370
  • 正文 我出身青樓他嚷,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子筋蓖,可洞房花燭夜當晚...
    茶點故事閱讀 44,689評論 2 354

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