在一個微信公眾號:AutoCodes 上面看到一篇推文,感覺整理的挺好
的,分享給大家!后面有一個問題,可以一塊討論,數字0和字符0不是一
樣的吧,那數字有ASCII碼嗎?
原文如下:
【C語言】'\0'、'0'、' '、“0”、0的區別詳解文章內容部分整理自網絡!若有冒犯請指出,我們及時更正! 在計算機中,所有的數據在存儲和運算時都要使用二進制數表示(因為計算機用高電平和低電平分別表示1和0),例如,像a、b、c、d這樣的52個字母(包括大寫)、以及0、1等數字符號還有一些常用的符號(例如*、#、@等)在計算機中存儲時也要使用二進制數來表示,而具體用哪些二進制數字表示哪個符號,當然每個人都可以約定自己的一套(這就叫編碼),而大家如果要想互相通信而不造成混亂,那么大家就必須使用相同的編碼規則,于是美國有關的標準化組織就出臺了ASCII編碼,統一規定了上述常用符號用哪些二進制數來表示。 有關字符集和編碼的內容繼續在微信公眾號:AutoCodes中推出。 需要明白的是,這里的映射關系式“字符” <-->"數字(編碼)"。 第一部分:區別第一:'\0'是字符,其ASCII碼為0,內存中存放表示:0000 0000。 '\0'是一個ASCII控制字符,是轉義字符,代表空字符。作為字符串結尾字符。字符'\0'可以直接用ASCII碼0表示,0不管是幾進制,都是0(十進制),也就是0x00(十六進制)。 char c = '\0'; char c = 0; //ASCII碼為0的字符賦給字符變量c 這兩個是一樣的。當你打印的時候看你以什么形式去打印,如果是 %d,那會打印出0,如果是 %c 打印出一個空格,不是輸出到屏幕上'\0'。'\0'與 0 本質上其實是一樣的,一個是ASCII碼,一個是該ASCII碼對應的字符。字符串結束符 '\0' 的 ASCII 值正好是 0。所以用0判斷和用 '\0' 判斷,結果一樣(在內存中存放一樣)。 '\0'就表示將字符'0'轉義,系統遇到'\0'時輸出一個空格,從而表示ASCII碼為0的字符(字符串結束符),而數值0和這個是一個意思, ‘\0’是字符數組或者字符串結束標志,系統在引用字符數組或者字符串的時候遇到‘\0’就會結束,在進行字符數組初始化的時候,這個‘\0’是自動加上去的。而‘0’可以作為字符數組的一個元素。 第二:'0''0'是數字字符,其ASCII碼為48,也就是0x30,內存中存放表示:0011 0000 第三:' '' '空格是一個字符,其ASCII碼為32,內存中存放表示:0011 0000 比如 abcd (空格)cdefg; 存入數組時,空格作為一個字符占有一個字節的空間,我們可以把它看作一個字符去處理。而 "\0" 則是這個字符串的結束標識符,也占有一個字節的空間,表示字符串結束! 第四:"0""0"是字符串。 “0”代表字符串“0”,即這個字符串里只包含一個字符'0'(當然字符串結尾默認再加一個'\0') 第五:00是個整數,內存中表示為0000 0000,0就代表阿拉伯數字0 在邏輯運算值方面,0和'0'(ascii碼值為48)的主要區別,比如 !0 =1 !'0'=0; 字符0的ASCII碼實際上是48,C語言中字符0 只占一個字節(Byte),也就是內存中存放的是 01001000 (其中每一個0或1表示一個bit位) 而整數0, 它在內存中的表示全是0,C語言中一個整數的占4個字節,整數0在內存中的表示為: 00000000 00000000 00000000 00000000 .
如下:
char c = '0'; //字符0
int a = 0; //整數0
printf("%c, %d\n", c, a); //0,0
printf("%d\n", c); //48 用整數形式打印字符,實際是打印c在內存中的值。
printf("%d\n", (c+a)); //48
printf("%c\n", (char)(c+a)); //0
輸出的結果:
0,0
48
48
0
從上面你就能看出字符0和整數0的區別了。 第二部分:內容擴展附:如果用scanf來接收字符串的話,字符串中不能含有空格,否則將以空格作為串的結束符。如果你鍵入得是hello world 那么實際上scanf只能獲取hello 這個單詞。所以要接收空格的話可以用gets()這個函數。gets(str)是讀入一串以回車結束的字符,順序存入到以str為首地址的內存單元中,最后寫入字符串結束標志 “\0 “, 同樣在輸出字符串時要用puts(),輸出時直到遇到 \0 為止,最后輸出一個換行符。 第三部分:問題那么,C語言中既然'\0'與空格‘ ’是不一樣的,那為什么在字符串問題中,scanf中還不能讀入空格?例如字符串"hello world",用scanf以%s格式輸入,只能輸出"hello",字符串是以‘\0’作為結尾,而‘ ’!='\0'。為什么呢? 這不是說明空格與\0等價,而是由于C語言的緩沖機制,scanf讀取數據不是從鍵盤直接讀取,因為鍵盤是字符型輸入設備,且它是中斷方式來被操作系統控制,所以這些IO設備存取速率及其低下,而內存是塊設備,讀取速度非常快,因此引入緩沖區機制來緩沖IO設備與內存的數據交換,scanf也是從緩沖區地區,而scanf函數是把空格作為緩沖區數據的分隔符,每遇到一個空格,則表示當前一段數據為可用數據,被scanf讀取,而不是空格表示字符結束而被讀入。 第四部分:遺留問題在我們平臺上,有讀者提出這樣一個問題:在查找網上資料的過程中,看到有這么一個說法“數字的ASCII碼”,數字有ASCCII碼嗎? 讀者認為字符'0'、'1'......'9'有對應的ASCII碼,而數字0、1......9是沒有ASCII碼的。對于這個問題,給大家一塊討論~ |