C語言查漏補缺——單引號和雙引號
一、基本知識
1、C語言中單引號用來表示字符字面量
2、C語言中雙引號用來表示字符串字面量
比如:'a'表示字符字面量,在內存中占1個字節, 'a'+1表示的是'a'的ASCII碼加1,結果為'b'
"a"表示字符串字面量,在內存中占2個字節,其中,第一個字節是"a",第二個字節是結束符'\0',"a"+1表示的是進行指針運算,結果指向"a"結束符'\0'。
二、代碼分析
下面存在這樣一段代碼
#include <stdio.h> int main() { char* p1 = 1 ; char* p2 = '1'; char* p3 = "1"; printf("%s, %s, %s", p1, p2, p3); printf('\n'); printf("\n"); return 0; }
那麽這段代碼是否合法呢?
在Linux下,編譯運行後,結果如下
為什麽會報段錯誤呢?下面我們進行分析。
首先,我們看
char* p1 = 1 ; char* p2 = '1'; char* p3 = "1";
char* 在是指針,根據指針的概念,對應的指針變量存儲的應該是一個地址,那麽上述代碼的內存分布可以理解如下
也就是說,p1和p2是在內存的低地址處。這裏有一點需要記住,程序的內存地址,必須要小於0x08048000,不然就會產生段錯誤。
三、擴展
#include <stdio.h> int main() { char c = " "; while( (c == "\t") || (c == " ") || (c == "\n") ) { scanf("%c", &c); } return 0; }
這段程序,在Linux中運行結果如下
可以看到程序運行以後,直接就完了,並沒有我們想象中的需要輸入的情況。為什麽會這樣呢?
分析如下
char c = " ";
這段代碼等同於
char c = "string";
1、編譯後字符串"string"的內存地址被賦值給了變量c
2、內存地址占用4個字節,而變量c只占用1個字節
3、由於類型不同,賦值後產生截斷
因此,這裏需要將所有的雙引號改成單引號,就可以實現。
四、總結
1、單引號括起來的單個字符代表整數
2、雙引號括起來的字符代表字符指針
3、C編譯器接受字符和字符串的比較,無任何意義
4、C編譯器允許字符串對字符變量賦值,只能得到錯誤
C語言查漏補缺——單引號和雙引號