char陣列和char*初始化
阿新 • • 發佈:2019-01-10
初始化
char str[10]="Hello";
char str[10]={'H','e','l','l','o','\0'};
char str[10]={'H'};
char str[10]={0};
char str[10]="Hello, world.\n";
char str[]="Hello, world.\n";
第一種情況:初始化資料小於陣列長度
如前面兩個初始化的例子,這兩個例子的效果一樣,前五個字元為Hello,剩餘的用'\0'填充
第三行與第四行,都只指定了第一個字元,剩餘的全部用'\0'填充。第四個例子相當將整個陣列初始化為'\0'
第二種情況:初始化資料等於或超過資料長度
這種情況下,超出的部分將被丟棄,所以最五個例子的最後一個字元為'r'.
此時使用一些字串函式時要特別注意,因為該陣列不含有'\0',會造成不可預期的結果
第三種情況:不指定陣列長度
這種情況下,陣列部分如果不含有明確指定的'\0',那麼編譯時會被自動新增一個'\0';
在陣列不含有明確的'\0'時,sizeof=strlen+1
一些字串函式
#incldue <string.h>
void *memset(void *s,int c,size_t n);
size_t strlen(const char *s);
void *memcpy(void *dest,constvoid *src,size_t n);
void *memmove(void *dest,constvoid *src,size_t n);
char *strcat(char *dest,constchar *src);
char *strncat(char *desk,constchar *src,size_t n);
//大小寫敏感
int memcmp(constvoid *s1,constvoid *s2,size_t n);
int strcmp(constchar *s1,constchar *s2);
int strncmp(constchar *s1,constchar *s2,size_t n);
//大小寫不敏感
int strcasecmp(constchar *s1,constchar *s2);
int strncasecmp (constchar *s1,constchar *s2,size_t n);
//正反向查詢
char *strchr(constchar *s,int c);
char *strrchr(constchar *s,int c);
char *strstr(constchar *haystack,constchar *needle);
//分割字串
char *strtok(char *str,constchar *delim);
char *strtok_r(char *str,constchar *delim,char **saveptr);