[C++對象模型][4]指針與字符串


開始之前必須明確strlen的含義,原型為size_t strlen( char *str ); strlen返回字符串的長度,即null(/0)之前的字符的數量。

一 char* 與 char []

實例加注釋:

Code
void TestCharPointerAndArray()
{
   
char *c1 = "abc"; //abc/0常量區,c1在棧上, 常量區程序結束后自動釋放。
   
//c1[1] = 'g'; // 常量不能修改
    int i = strlen(c1); // 3

   
char c2[] = "abc"; // c2,abc/0都在棧上
    c2[1] = 'g'; // 可以修改
    int j = strlen(c2); // 3
    int jj = sizeof(c2); // 4

   
char *c3 = ( char* )malloc(4* sizeof(char)); // c3 棧上
    memcpy(c3,"abc",4); // abc/0 在堆上, 4 = 3(strlen("abc")) + 1('/0');
    c3[1] = 'g'; // 可以修改
    int x = strlen(c3); // 3
    free(c3); //如果這里不free,會內存泄漏
    c3 = "abc"; // abc/0 在常量區,c3指向了常量區
   
//c3[1] = 'g'; // 常量不能修改
    int y = strlen(c3); // 3
}

 

字符串都以/0結尾,所以例如:char *c1 = "abc";char c2[] = "abc";,使用strlen得到長度都為3,但是實際的存儲空間為strlen+1即3+1。

二 C中字符串操作函數

C++的程序員對C中的字符串指針操作的函數卻並不是相當的熟悉。而C中的這些字符串的指針操作函數有的時候也是必須要面對的,比如我們的庫要提供C函數接口,保持向后兼容和跨平台,還有我們經常使用一些第三方的庫中都或多或少的使用到了這些C中的指針操作函數,所以下面列出C的指針操作函數,幫助大家熟悉之。

1) memcpy/memset/memcmp

 

    memcpy

原型:extern void *memcpy( void *to, const void *from, size_t count );
包含:#include <string.h> 或<string>或<cstring>
功能:由src所指內存區域復制count個字節到dest所指內存區域。
說明:src和dest所指內存區域不能重疊,函數返回指向dest的指針。

 

    memset

原型:extern void* memset( void* buffer, int ch, size_t count );
包含:#include <string.h> 或<string>或<cstring>
功能:把buffer所指內存區域的前count個字節設置成字符c。
說明:返回指向buffer的指針。

 

 

   memcmp

原型:extern int memcmp(const void *buffer1, const void *buffer2, size_t count );
包含:#include <string.h> 或<string>或<cstring>
功能:比較內存區域buf1和buf2的前count個字節。
說明:
        當buf1<buf2時,返回值<0
        當buf1=buf2時,返回值=0
        當buf1>buf2時,返回值>0



    memchr
原型: extern void *memchr( const void *buffer, int ch, size_t count );
包含:#include <string.h> 或<string>或<cstring>
功能:查找ch在buffer中第一次出現的位置。
說明:如果發現返回指針,如果沒有返回NULL。

 

實例:

 

Code
void TestMemFunction()
{
   
char *s1="Hello!"; // Hello!/0
    int l = strlen(s1); // 6
    char *d1 = new char[l+1]; // d1 需要strlen(s1) + 1 空間
    memcpy(d1,s1,l+1);

    memcpy(d1,d1,l);

    memmove(d1
+ 1,d1,l-1);

   
const int ARRAY_LENGTH = 5;
   
char the_array[ARRAY_LENGTH];
   
// zero out the contents of the_array
    memset( the_array, 'c', ARRAY_LENGTH );

   
char *a1 = "source1";
   
char arr1[8] = "source2";
   
int r = memcmp(a1,arr1,strlen(a1) - 1); // 僅比較source,所以相等

   
char str[17];
   
char *ptr;
    strcpy(str,
"This is a string");
    ptr
= (char*)memchr(str, 'r', strlen(str));
}

 

2) strlen/strcpy/strcat/strcmp/strchr/strcoll/strstr/strtok/strtod/strtol


strcpy

char *strcpy(char *s1, const char *s2) 將字符串s2復制到字符串數組s1中,返回s1的值


strcat

char *strcat(char *s1, const char *s2)
將字符串s2添加到字符串s1的后面。s2的第一個字符重定義s1的null終止符。返回s1的值



strcmp

int strcmp(const char *s1, const char *s2)
比較字符串s1和字符串s2。函數在s1等於、小於或大於s2時分別返回0、小於0或者大於0的值

strchr

char *strchr(char * str,int c ); 在str中查找c第一次出現的位置。

strstr char *strstr(char *str,const char *strSearch );在string1中查找string2第一次出現的位置。
strtok char *strtok(char *strToken,const char *strDelimit ); 分割字符串。

 

實例:

 

Code
void TestStrFunction()
{
    
char string[11];
    
char *str1 = "123456789"// 123456789/0
    strcpy(string, str1);

    strcat(
string,"A"); //123456789A/0

    
int r = strcmp(string,"123456789B"); // 123456789A/0 < 123456789B/0
}

void TestStrFunction2()
{
    
int  ch = 'r';
    
char string[] = "The quick # brown dog # jumps over # the lazy fox";
    
char *pdest = NULL;
    pdest 
= strchr( string, ch );

    pdest 
= NULL;
    
char * str = "dog";
    pdest 
= strstr(string,str);

    pdest 
= NULL;
    
char delims[] = "#";
    pdest 
= strtok( string, delims );
    
while( pdest != NULL ) 
    {
        pdest 
= strtok( NULL, delims );
    }
}

 

總結:

1)以mem開始的函數用來bytes的操作,所以需要指定長度,但是以str用來操作以/0結尾的字符串,不需要指定長度。

2)對於unicode,相應的字符串操作函數前綴為wcs,例如wcscpy,wcscat,wcscmp,wcschr,wcsstr,wcstok等。

3)在vc中還提供了有安全檢測的字符串函數后綴_s,例如strcpy_s,strcat_s,strcmp_s,wcscpy_s,wcscat_s,wcscmp_s等。

4)char*如果指向常量區,不能被修改,且此char*不需要delete。例如 char* pStr = "ABC";。

三 std::string和std::wstring使用相當簡單哦!


注意!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。



 
粤ICP备14056181号  © 2014-2020 ITdaan.com