字符串以及內存操作相關函數 - wuliming - CSDNBlog_第1頁
字符串以及內存操作相關函數 - wuliming - CSDNBlog_第2頁
字符串以及內存操作相關函數 - wuliming - CSDNBlog_第3頁
字符串以及內存操作相關函數 - wuliming - CSDNBlog_第4頁
字符串以及內存操作相關函數 - wuliming - CSDNBlog_第5頁
已閱讀5頁,還剩4頁未讀, 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、字符串以及內存操作相關函數 - wuliming - CSDNBlog    字符串拷貝和內存拷貝函數: strcpy strncpy memcpy memmove memccpy bcopy   字符串和內存數據比較函數: strcmp strcasecmp strncasecmp memcmp strcoll bcmp   連接字符串的函數: strcat strncat   查找字符/字符串的函數: strstr strchr strrchr memchr   其它相關的函數: index rindex st

2、rlen strdup memset bzero strspn strcspn strpbrk strtok     字符串拷貝和內存拷貝函數:   strcpy(拷貝字符串)  定義函數:char *strcpy( char *dest, const char *src ); strcpy()函數只能拷貝字符串。strcpy()函數將源字符串src的每個字節拷貝到目的字符串dest中,src字符串末尾的0也被拷貝過去。strcpy()函數返回參數dest的起始地址。如果參數dest所指的內存空間不夠大,可能會造成緩沖溢出(buffer Overflow

3、)的錯誤情況,在編寫程序時請特別留意,或者用strncpy()來取代。   strncpy(拷貝字符串)  定義函數:char *strncpy( char *dest, const char *src, size_t n ); strncpy()會將參數src字符串拷貝前n個字符至參數dest所指的地址。函數返回參數dest的字符串起始地址。 注意n的取值范圍,不要超過src和dest的長度。         #include<string.h>   

4、 #include<stdio.h>         int main()            char a130="string(1)"        char b1="STRING(2)"      &

5、#160; printf("before strcpy()  : %sn", a1 );        printf("after  strcpy()  : %sn", strcpy( a1, b1 ) );             char a230="string(1)"   

6、0;    char b2="STRING(2)"        printf("before strncpy() : %sn", a2 );        printf("after  strncpy() : %sn", strncpy( a2, b2, 6 ) );       

7、60;      memcpy(拷貝內存內容)   定義函數:void * memcpy( void * dest, const void *src, size_t n ); memcpy()用來拷貝src所指的內存內容前n個字節到dest所指的內存地址上。與strcpy()不同的是,memcpy()會完整的復制n個字節,不會因為遇到字符串結束0而結束。memcpy()函數可以拷貝任意類型的數據。memcpy()函數返回指向dest的指針。指針src和dest所指的內存區域不可重疊。在拷貝字符串時,通常都使用strcpy()

8、函數;在拷貝其它數據(例如結構)時,通常都使用memcpy()函數。   memmove(拷貝內存內容)  定義函數:void *memmove(void *dest, const void *src, size_t n ); memmove()與memcpy()一樣都是用來拷貝src所指的內存內容前n個字節到dest所指的地址上。不同的是,當src和dest所指的內存區域重疊時,memmove()仍然可以正確的處理,不過執行效率上會比使用memcpy()略慢些。該函數返回指向dest的指針。       

9、;  #include<string.h>         int main()            char a30="string(1)"        char b="string(2)"      

10、  printf("before strcpy() :%sn", a );        printf("after strcpy() :%sn", strcpy( a, b ) );             a30="string(1)"        b="

11、;string(2)"        printf("before strncpy() : %sn", a );        printf("after strncpy() : %sn", strncpy( a, b, 6 ) );            memccpy(拷貝內存內容)&

12、#160; 定義函數:void * memccpy( void *dest, const void *src, int c, size_t n ); memccpy()用來拷貝src所指的內存內容前n個字節到dest所指的地址上。與memcpy()不同的是,memccpy()會在復制時檢查參數c是否出現,若是則返回dest中值為c的下一個字節地址。該函數返回指向dest中值為c的下一個字節指針。返回值為NULL表示在src所指內存前n個字節中沒有值為c的字節。           #include<

13、string.h>    #include<stdio.h>         int main()            char a="string(a)"        char b="string(b)"  

14、;      char *p;                p = ( char * )memccpy( a, b, k, sizeof( b ) );                if( p = NULL )    

15、0;               /注意p為NULL的情況,這時不能讀取p所指的地方的內容             printf("the return pointer of mymccpy is null !n");           

16、     else                    printf("memccpy(): %s, *p = %cn", a, *p );                   

17、   bcopy(拷貝內存內容)  定義函數:void bcopy ( const void *src,void *dest ,int n); bcopy()與memcpy()一樣都是用來拷貝src所指的內存內容前n個字節到dest所指的地址,不過參數src與dest在傳給函數時是相反的位置。建議使用memcpy()取代 。            字符串和內存數據比較函數:   strcmp(比較字符串)  int strcmp( const char *s1, const char

18、*s2 ); strcmp()用來比較參數s1和s2字符串。字符串大小的比較是以ASCII 碼表上的順序來決定,此順序亦為字符的值。strcmp()首先將s1第一個字符值減去s2第一個字符值,若差值為0則再繼續比較下個字符,若差值不為0則將差值返回。例如字符串"Ac"和"ba"比較則會返回字符"A"(65)和b(98)的差值(33)。 若參數s1和s2字符串相同則返回0。s1若大于s2則返回大于0的值。s1若小于s2則返回小于0 的值。   strcoll(采用目前區域的字符排列次序來比較字符串)  int str

19、coll( const char *s1, const char *s2 ); strcoll()會依環境變量LC_COLLATE所指定的字符排列次序來比較s1和s2 字符串。若參數s1和s2字符串相同則返回0,s1若大于s2則返回大于0的值,s1若小于s2則返回小于0 的值。若LC_COLLATE為"POSIX"或"C",則strcoll()與strcmp()作用完全相同。   strcasecmp(忽略大小寫比較字符串)  int strcasecmp ( const char *s1, const char *s2 ); str

20、casecmp()用來比較參數s1和s2字符串,比較時會自動忽略大小寫的差異。若參數s1和s2字符串相同則返回0,s1長度大于s2長度則返回大于0 的值,s1 長度若小于s2 長度則返回小于0的值。   strncasecmp(忽略大小寫比較字符串)  int strncasecmp( const char *s1, const char *s2, size_t n ); strncasecmp()用來比較參數s1和s2字符串前n個字符,比較時會自動忽略大小寫的差異。若參數s1和s2 字符串相同則返回0。s1 若大于s2則返回大于0的值,s1若小于s2則返回小于0 的值。

21、  strcmpi()或stricmp():對兩個字符串進行大小寫不敏感的比較。 strncmp():對兩個字符串的一部分進行大小寫敏感的比較。 strnicmp():對兩個字符串的一部分進行大小寫不敏感的比較。         #include <stdio.h>    #include <string.h>         int main()

22、60;           char *a="aBcDeF"        char *b="AbCdEf"        char *c="aacdef"        char *d="ABCDEF"

23、60;               printf("strcmpi(a,b) : %dn",strcmpi(a,b);        printf("stricmp(a,b) : %dn",stricmp(a,b);        printf("strcmp(a,d) : %d

24、n",strcmp(a,d);             printf("strncmp(a,b,3) : %dn",strncmp(a,b,3);        printf("strnicmp(a,b,3) : %dn",strnicmp(a,b,3);        

25、0;    getchar();    return 0;         memcmp(比較內存內容)  int memcmp( const void *s1, const void *s2, size_t n ); memcmp()用來比較s1和s2所指的內存區間前n個字符。字符串大小的比較是以ASCII碼表上的順序來決定。memcmp()首先將s1第一個字符值減去s2第一個字符的值,若差為0則再繼續比較下個字符,若差值不為0則將差

26、值返回。例如,字符串"Ac"和"ba"比較則會返回字符A(65)和b(98)的差值(33)。若參數s1和s2所指的內存內容都完全相同則返回0值。s1若大于s2則返回大于0的值。s1若小于s2則返回小于0的值。   bcmp(比較內存內容)  int bcmp ( const void *s1,const void * s2,int n); bcmp()用來比較s1和s2所指的內存區間前n個字節,若參數n為0,則返回0。若參數s1 和s2 所指的內存內容都完全相同則返回0 值,否則返回非零值。 建議使用memcmp()取代。 

27、        #include <stdio.h>    #include <string.h>    int main()            char *a ="aBcDeF"        char *b="

28、;AbCdEf"        char *c="aacdef"        char *d="aBcDeF"        printf("memcmp(a,b):%dn",memcmp(void*)a,(void*) b,6);       

29、printf("memcmp(a,c):%dn",memcmp(void*)a,(void*) c,6);        printf("memcmp(a,d):%dn",memcmp(void*)a,(void*) d,6);                        連接字符串的函數:   strcat(連接兩

30、字符串)  char *strcat (char *dest, const char *src ); strcat()會將參數src字符串拷貝到參數dest所指的字符串尾。第一個參數dest要有足夠的空間來容納要拷貝的字符串。該函數返回參數dest的字符串起始地址。   strncat(連接兩字符串)  char * strncat( char *dest, const char *src, size_t n ); strncat()會將參數src字符串拷貝n個字符到參數dest所指的字符串尾。第一個參數dest要有足夠的空間來容納要拷貝的字符串。該函數返回參數d

31、est的字符串起始地址。           #include<stdio.h>    #include<string.h>    int main()            /strcat        char a30=&

32、quot;string1ABCDE"        char b="STRING2"        printf( "before strcat() : %sn",a );        printf( "after strcat()  : %sn",strcat( a, b ) );  

33、              /strncat        char a130="string1"        char b1="STRING2"        printf( "before strnact(): %

34、sn", a1 );        printf( "after strncat() : %sn", strncat( a1, b1, 6 ) );                    getchar();        return 0; 

35、60;                 查找字符/字符串的函數:   strstr(在一字符串中查找指定的字符串)  char *strstr( const char *haystack, const char *needle ); strstr()會從字符串haystack中搜尋字符串needle,并將第一次出現的地址返回。返回指定字符串第一次出現的地址,否則返回NULL。   strchr(查找字符串中第一個出現的指定字符)  char *s

36、trchr( const char *s, int c ); strchr()用來找出參數s字符串中第一個出現的參數c地址,然后將該字符出現的地址返回。如果找到指定的字符則返回該字符所在地址,否則返回NULL。   strrchr(查找字符串中最后出現的指定字符)  char * strrchr( const char *s, int c ); strrchr()用來找出參數s字符串中最后一個出現的參數c地址,然后將該字符出現的地址返回。如果找到指定的字符則返回該字符所在地址,否則返回NULL。   memchr(在某一內存范圍中查找一特定字符)  vo

37、id *memchr( const void *s, int c, size_t n ); memchr()從頭開始搜尋s所指的內存內容前n個字節,直到發現第一個值為c的字節,則返回指向該字節的指針。如果找到指定的字節則返回該字節的指針,否則返回NULL。           #include<stdio.h>    #include<string.h>    int main()  

38、;          char *s = "0123456789012345678901234567890"        char *p;                p = strchr(s,9);      &#

39、160; printf(" strchr(): %sn",p);                p = strrchr(s,9);        printf("strrchr(): %sn",p);             &#

40、160;      p = strstr(s,"901");        printf(" strstr(): %sn",p);                   p = (char *)memchr( s, 9, 10 );     

41、   printf(" memchr(): %sn",p);                          其它相關的函數:     index(查找字符串中第一個出現的指定字符)  char * index( const char *s, int c ); index()用來找出參數s字符串中第一個出現的參數c的地址,然后將該字符出現的地址返

42、回。字符串結束字符(NULL)也視為字符串一部分。如果找到指定的字符則返回該字符所在地址,否則返回NULL。用Dev-C+4.9.9.2調試時,提示index為定義,在linux下確認一下   rindex(查找字符串中最后一個出現的指定字符)  char * rindex( const char *s, int c ); rindex()用來找出參數s字符串中最后一個出現的參數c的地址,然后將該字符出現的地址返回。字符串結束字符(NULL)也視為字符串一部分。如果找到指定的字符則返回該字符所在的地址,否則返回NULL。用Dev-C+4.9.9.2調試時,提示rindex為

43、定義,在linux下確認一下   strlen(返回字符串長度)  size_t strlen( const char *s ); strlen()用來計算指定的字符串s的長度,不包括結束字符"0",該函數返回字符串s的字符數。   strdup(復制字符串)  char *strdup( const char *s ); strdup()會先用maolloc()配置與參數s字符串相同的空間大小,然后將參數s字符串的內容復制到該內存地址,然后把該地址返回。該地址最后可以利用free()來釋放。函數返回一字符串指針,該指針指向復制后的新

44、字符串地址,若返回NULL表示內存不足。           #include<stdio.h>    #include<stdlib.h>    #include<string.h>         int main()       

45、;     char a = "strdup"         char *b;        b = strdup( a );        printf("b="%s"n", b );        free(b);

46、    return 0;             bzero(將一段內存內容全清為零)  void bzero(void *s,int n); bzero()會將參數s所指的內存區域前n個字節,全部設為零值。相當于調用memset(void*)s,0,size_tn);建議使用memset取代該函數。       memset(將一段內存空間填入某值)  void * memset (void *s ,i

47、nt c, size_t n ); memset()會將參數s所指的內存區域前n個字節以參數c填入,然后返回指向s的指針。在編寫程序時,若需要將某一數組作初始化,memset()會相當方便。附加說明:參數c雖聲明為int,但必須是unsigned char,所以范圍在0到255之間。           #include<string.h>    #include<stdio.h>    #includ

48、e<stdlib.h>         int main()            char s30;        memset (s,A,sizeof(s);        s29=0;     

49、;        for( int i = 0; i < 30; i+ )                    printf("%d ", si );               

50、printf("n%sn",s);             memset (s,0,sizeof(s);        for( int i = 0; i < 30; i+ )                  &

51、#160; printf("%d ", si );                printf("nn%sn",s);        return 0;             輸出結果為:  

52、60; 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 65 0    AAAAAAAAAAAAAAAAAAAAAAAAAAAAA    0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0         strspn(返回字符串中連續含指定字符串內容的字符數)

53、  size_t strspn( const char *s, const char *accept ); strspn()從參數s 字符串的開頭計算連續的字符,而這些字符都完全是accept 所指字符串中的字符。簡單的說,若strspn()返回的數值為n,則代表字符串s 開頭連續有n 個字符都是屬于字符串accept內的字符。該函數返回字符串s開頭連續包含字符串accept內的字符數目。   strcspn(返回字符串中連續不含指定字符串內容的字符數)  size_t strcspn( const char *s, const char *reject ); s

54、trcspn()從參數s字符串的開頭計算連續的字符,而這些字符都完全不在參數reject 所指的字符串中。簡單地說,若strcspn()返回的數值為n,則代表字符串s開頭連續有n個字符都不含字符串reject內的字符。該函數返回字符串s開頭連續不含字符串reject內的字符數目。           #include<stdio.h>    #include<string.h>     

55、60;   int main()            char *str="Linux was first developed for 386/486-based PCs."        char *t1="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"  

56、0;     printf( "strspn:n%dn",strspn( str,t1 ) );             printf( "strcspn: %dn",strcspn( str, " " ) );        printf( "strcspn: %dn",strcspn(

57、 str, "/-" ) );        printf( "strcspn: %dn",strcspn( str, "1234567890" ) );             strpbrk(查找字符串中第一個出現的指定字符)  char *strpbrk( const char *s, const char *accept ); strpbrk()用來

58、找出參數s 字符串中最先出現存在參數accept 字符串中的任意字符。如果找到指定的字符則返回該字符所在地址,否則返回NULL。用Dev-C+4.9.9.2調試時,提示index為定義,在linux下確認一下     strtok(分割字符串)  char * strtok( char *s, const char *delim ); strtok()用來將字符串分割成一個個片段。參數s指向欲分割的字符串,參數delim則為分割字符串,當strtok()在參數s的字符串中發現到參數delim的分割字符時則會將該字符改為0 字符。在第一次調用時,strtok()必需給予參數s字符串,往后的調用則將參數s設置成NULL。每次調用成功則返回下一個分割后的字符串指針。如果已無從分割則返回NULL。   函數strtok()具有“破壞性”,它會在原字符串中插入NUL字符(如果原字符串還要做其它的改變,應該拷貝原字符串,并將這份拷貝傳遞給函數strtok()。函數strtok()是不能“重新進入”的,你不能在一個信號處理函數中調用strtok()函數,因為在下一次調用strtok()函數時它總是會“記住”上一次被調用時的某些參數。strtok()函數是一個古怪的函數,

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論