C語言字符串與字符數(shù)組面試題中最易錯考點詳解
本文介紹字符串與字符數(shù)組中最易錯的3個考點。若以后遇到其他相關的易錯點,會持續(xù)補充更新。
一、'\0'對字符串與字符數(shù)組的重要性
#include<stdio.h> #include<string.h> //下面代碼,打印結果是什么? int main(){ char arr1[] = "abc"; char arr2[] = { 'a', 'b', 'c'}; char arr3[] = { 'a', 'b', 'c','\0'}; printf("arr1 %s\n",arr1); printf("arr2 %s\n",arr2); printf("arr3 %s\n",arr3); return 0; }
運行程序結果如下:
其中,arr1與arr3的打印結果正確,而arr2打印結果出現(xiàn)了異常(打印的其實是隨機值)。這是'\0'的使用造成的差異。
我們知道,'\0'是字符串的結束標志,當遇到'\0'時,字符串才算作結束。在計算字符串長度時,作為結束標志的'\0'不算做字符串的內(nèi)容。
本題中%s意味著三個數(shù)組都以字符串的形式打印,arr1是字符串字面量"abc",其中末尾自帶隱藏的'\0';而arr3則是人為手動地在末尾添加了'\0',它們兩個均有'\0'作結尾。計算機能很好地識別到這個'\0',并正確打印兩個數(shù)組。而arr2由于沒有'\0',打印時計算機“找不著尾”,只能打印出隨機值,當在內(nèi)存中“偶遇”一個'\0'時它才停止。
二、strlen與sizeof有什么區(qū)別
先說結論
事實上二者沒有什么的關聯(lián)。
總結如下
1. strlen 是一個包含在 string.h 中的字符串庫函數(shù),用于求字符串長度(也只能對字符串求長度)。它計算的是'\0'之前的所有字符的個數(shù)(不包括'\0')。
2. sizeof 是一個操作符。它計算變量、數(shù)組、類型的大小,單位是字節(jié)byte。
示例
char a[] = "abcdef"; strlen(a) = 6; //一共有6個字符(不包括'\0') sizeof(a) = 7; //一共有7個字符元素(包括'\0'),且每個元素都是char型變量,分別占1字節(jié)。 //總大小為 7*1=7(byte)
注意
雖然'\0'在 strlen 中不算數(shù),但它實際存在且占了空間。因而在計算所占空間總大?。╯izeof)時,必須把'\0'也算入其中,作為一個字符元素參與計算。
補充示例
char arr1[] = "abc"; char arr2[] = {'a','b','c'}; sizeof(arr1) // 4*1 = 4 (byte) sizeof(arr2) // 3*1 = 3 (byte) strlen(arr1) // 共有3個非'\0'字符,故答案為3 strlen(arr2) // 沒有'\0'做結尾,故為隨機值
三、含轉(zhuǎn)義字符求字符串長度
引例
如果要在屏幕上打印一個目錄: c:\code\test.c 我們這樣寫代碼:
#include <stdio.h> int main() { printf("c:\code\test.c\n"); return 0; }
恐怕不能達到想要的效果:
原因很簡單:\t 作為轉(zhuǎn)義字符,表示“水平制表符”的含義,不再是字面含義'\'和't'兩個字符的拼接。
轉(zhuǎn)義字符如下:
要小心這些藏在一堆字符串字母中的轉(zhuǎn)義字符!請看如下代碼,請問程序會輸出什么?
//程序輸出什么? #include <stdio.h> int main() { printf("%d\n", strlen("abcdef")); printf("%d\n", strlen("c:\test\628\test.c")); return 0; }
第一個printf輸出6,而第二個printf輸出的是14. 通過上表的查閱我 們可知,\62最終會被解析成一個轉(zhuǎn)義字符(注意,不是\628被轉(zhuǎn)義,因為八進制中沒有數(shù)字‘8’!),加上其余兩個轉(zhuǎn)義字符'\t' ,合計起來的字符串長度是14。
到此這篇關于C語言字符串與字符數(shù)組面試題中最易錯考點詳解的文章就介紹到這了,更多相關C語言字符串與字符數(shù)組內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
C語言使用stdlib.h庫函數(shù)的二分查找和快速排序的實現(xiàn)代碼
以下是對C語言使用stdlib.h庫函數(shù)的二分查找和快速排序的實現(xiàn)代碼進行了詳細的介紹,需要的朋友可以過來參考下。希望對大家有所幫助2013-10-10