C語言(字元陣列)

鋸齒流沙發表於2017-12-27

編寫程式時,經常輸出一些字元資訊,這些資訊通常是由多個字元組成的。將陣列元素定義為char型別,用陣列來存放字元資訊。通常採用迴圈方式來實現輸入輸出功能。

使用字元陣列儲存字串

void main(){
	char str[] = { 'h', 'e', 'l', 'l', 'o','\0' };
	for (int i = 0; i < 6;i++){
		printf("%c", str[i]);
	}
	getchar();
}

複製程式碼

執行結果.png

'\0'迴圈結束

void main(){
	char str[15] = "hello world!";
	
	for (int i = 0; i < 15;i++){
		printf("%c", str[i]);
	}


	getchar();
}

複製程式碼

執行結果.png

字元陣列可以修改元素

void main(){

	char str[15] = "hello world";
	//可以修改
	str[0] = 'w';

	printf("%s\n", str);
	printf("%#x\n", str);
	getchar();
}
複製程式碼

執行結果.png

字元指標

void main(){
	//記憶體連續排列
	char* p = "hello world";
	while (*p){
		printf("%c", *p);
		p++;
	}
	getchar();
}
複製程式碼

執行結果.png

void main(){
	//記憶體連續排列
	char* p = "hello world";

	p += 3;
	while (*p){
		printf("%c", *p);
		p++;
	}
	getchar();
}
複製程式碼

執行結果.png

字串不可以修改

void main(){
	//記憶體連續排列
	char* p = "hello world";
	//不可以修改
	p += 1;
	*p = 'S';
	printf("%s\n", p);
	printf("%#x\n", p);

	/*while (*p){
		printf("%c", *p);
		p++;
	}*/
	getchar();
}
複製程式碼

執行結果.png

字串

c語言本省沒有設定一種型別來定義字串變數的,字串的存在完全依賴於字元陣列,但是字元陣列又不等於字串變數。

字串常量:用一對雙引號括起來的一串字元。雙引號是字串起止的標誌符,它不屬於字串本身的字元。

字串結束標誌'\0' '\0':是轉義字元,代表ASC||碼為0的字元。

字串函式查詢 strcat:字串拼接函式

void main(){
	char str[50];
	char* a = "Hello";
	char* b = "World";
	strcpy(str,a);
	strcat(str, b);
	printf("%s\n", str);
	getchar();
}
複製程式碼

執行結果.png

字串查詢給定字元的第一個匹配之處

void main(){
	char str[50];
	char* a = "Hello";
	char* b = "World";
	strcpy(str,a);
	strcat(str, b);
	printf("%s\n", str);
	char* p = strchr(str, 'W');
	if (p){
		printf("索引位置:%d\n", p - str);
	}
	else{
		printf("沒有找到");
	}
	getchar();
}
複製程式碼

執行結果.png

void main(void){
	char *haystack = "I want go to USA!";
	char *needle = "to";
	//U元素的指標

	char* p = strstr(haystack, needle);
	if (p){
		printf("索引位置:%d\n", p - haystack);
	}
	else{
		printf("沒有找到");
	}

	system("pause");
}
複製程式碼

執行結果.png

strcmp

比較字串 ,區分大小寫

_strcmpi

比較字串,忽略大小寫

void main(void){
	char *str1 = "abc";
	char *str2 = "ABC";
	int r = _strcmpi(str1, str2);
	printf("%d\n", r);
	//str1 > str2
	if (r > 0){
		printf("str1 大於 str2\n");
	}
	else if (r == 0){
		printf("str1 等於 str2\n");
	}
	//str1 < str2
	else if (r < 0){
		printf("str1 小於 str2\n");
	}

	getchar();
}

複製程式碼

執行結果.png

strset

把字串中的所有字元都設定成字元w

void main(void){
	char str1[] = "abc";
	/*char *str2 = "ABC";*/
	_strset(str1, 'w');
	printf("%s\n", str1);
	getchar();
}

複製程式碼

執行結果.png

strrev

把字串所有字元的順序顛倒過來

void main(void){
	char str1[] = "abc";
	/*char *str2 = "ABC";*/
	_strrev(str1);
	printf("%s\n", str1);
	getchar();
}
複製程式碼

執行結果.png

strtod

字串轉為double型別

void main(void){
	char* str = "33abc";
	char** p = NULL;
	double r = strtod(str, p);
	printf("%lf\n", r);
	getchar();
}
複製程式碼

執行結果.png

strupr

轉換為大寫

void main(void){
	char str[] = "abc";
	_strupr(str);
	printf("%s\n", str);
	getchar();
}
複製程式碼

執行結果.png

_strlwr

轉換為小寫

void main(void){
	char str[] = "ABC";
	_strlwr(str);
	printf("%s\n", str);
	getchar();
}
複製程式碼

執行結果.png

void mystrlwr(char str[], int len){
	int i = 0;
	for (; i < len; i++){
		//A-Z 字母 a-Z
		if (str[i] >= 'A' && str[i] <= 'Z'){
			str[i] = str[i] - 'A' + 'a';
		}
	}

}

void main(void){
	char str[] = "ABC";
	mystrlwr(str, strlen(str));
	printf("%s\n", str);
	getchar();
}
複製程式碼

執行結果.png

刪除字串中指定的字元

void delchar(char *str, char del){
	char *p = str;
	while (*str != '\0') {
		if (*str != del) {
			*p++ = *str;
		}
		str++;
	}
	*p = '\0';
}
void main(void){
	char str[] = "ABC";
	delchar(str, 'B');
	printf("%s\n", str);
	getchar();
}

複製程式碼

執行結果.png

刪除最後一個字元

void main(void){
	char str[] = "ABC";
	str[strlen(str) - 1] = '\0';
	printf("%s\n", str);
	getchar();
}
複製程式碼

memcpy

由str所指記憶體區域複製count個位元組到dest所指記憶體區域

void main(void){
	char str[] = "ABCEFGHIJKLMNOPQ";
	char dest[20] = { 0 };
	memcpy(dest, str, 5);
	printf("%s\n", str);
	getchar();
}
複製程式碼

memchr:從buf所指記憶體區域的前count個位元組查詢字元ch。

void main(void){
	char src[] = "C,C++,Java";
	char ch = 'C';

	//位元組 (分段擷取)
	char* p = memchr(src+1, ch, 5);
	if (p){
		printf("索引:%d\n", p - src);
	}
	else{
		printf("找不到\n");
	}
	getchar();
}
複製程式碼

memmove:由src所指記憶體區域複製count個位元組到dest所指記憶體區域。

strpbrk(s1, s2)

在字串s1中尋找字串s2中任何一個字元相匹配的第一個字元的位置,空字元NULL不包括在內

相關文章