標準C---關于字符串操作
字符串操作是常用的操作之一,下面是相關的函數介紹和相關注意的地方,
一、strtok查找函數,這個函數改變了源字符串,而且第一個參數必須是數組,不能是指針或字符串,如果是指針或字符串,則會報異常,直接返回NULL.如果不想改變源字符串的內容,建議用strstr來查找子串。
其他常用的查找函數有strchr和strrchr,前者在字符在字符串第一次出現的位置,后者則是查詢的是字符在字符串中出現的最后一次的位置;兩個函數返回的都是地址,注意,這里返回的首地址的值就是這個字符。這兩個查找函數都不會改變源字符串(數組的)內容。
二、Strlen和memset,如下面的代碼:
char* temp = (char*)malloc(67 * sizeof(char));
Int leng = strlen(temp);
Memset(temp,0,strlen(temp));
Leng = strlen(temp);
兩次leng的值是不一樣的,第一次是正確的值,第二次是0;strlen找的是’\0’,但是不包括’\0’;
三、strcpy等雖然不安全可,但是要記住:strcpy_s等是微軟自己搞的一套,在liunx上是無法使用的。如果要部分拷貝,我們可以在
strcpy的參數上直接對地址加減或在strncpy上對源字符串的地址更改或是對strncpy上的第三個參數加以修改來達到目的。
strcpy等不安全主要表現在沒有會發生字符串截斷、 字符串沒有正確的結束符,還有就是字符串的邊界問題。
malloc和free一般情況下要配對,但是如果是static變量,則可以不用free,不會發生內存泄漏的情況。
四、構造字符串---sprintf,提取一個字符串的某個字段---scanf,這兩個是相反的過程。
sprintf常用在拼接字符串,如:sprintf(buffer,"%s=%s","Three",3);buffer中的字符串就是"Three=3",有時它可以替代strcat函數;
那么我們可以提取34.3433,sscanf(str,"%s %s %f",ch,&t_fTemp);這個t_fTemp的值就是34.3433.
五、提取子串和字符在字符串的位置:strstr、strtok、strchr等,這些函數有個缺憾:如果我們要查找字串“222”是否在“22222 tok“中時,這幾個函數都不起作用,要么自己寫,要么自己根據字串在父串中的指針的下個地址的內容來確定.例如:
char str[] = "2222 tok";
char end_char = ' ';//這個可由自己根據業務定義
if(*(strstr(str,"222")+1) != end_char)
{
..................
}
六、strstr函數另一個缺點:char str[] = "port 56 78" char *ch = strstr(str,"port");ch的值是str的首地址,而非我們要的結果,如果把空格改成/t/r等轉義字符
結果依然如此,我們在使用str相關的函數時要主義類似的問題,這種結果在解析協議和讀文件時是致命,而且是難以察覺的錯誤。
posted on 2010-07-28 21:10 Benjamin 閱讀(753) 評論(6) 編輯 收藏 引用 所屬分類: C/C++