C文字列
C言語では、文字列が実際にヌル文字'\ 0'で終了文字の1次元配列を使用しています。 したがって、文字列の文字が含まれている、NULLで終わる文字列。
次の文は、作成し、「こんにちは」の文字列を初期化します。 NULL文字を格納する配列の終わり以来、そのように単語「こんにちは」よりも文字の配列のサイズは文字の数よりも多いです。
char greeting[6] = {'H', 'e', 'l', 'l', 'o', '\0'};
配列の初期化ルールに基づいて、上記のステートメントを次のような文を作成することができます。
char greeting[] = "Hello";
以下は、C / Cの文字列++メモリに定義されている、と彼は言いました:
実際には、文字列定数の末尾にヌル文字を必要としません。 ときに、文字列の末尾に '\ 0'自動的にCコンパイラの配列の初期化、。 それでは、上記の出力文字列を試してみましょう:
#include <stdio.h> int main () { char greeting[6] = {'H', 'e', 'l', 'l', 'o', '\0'}; printf("Greeting message: %s\n", greeting ); return 0; }
上記のコードはコンパイルされ、実行されると、次の結果を生成します。
Greeting message: Hello
文字列を操作するためのC関数が多数あります。
序号 | 函数 & 目的 |
---|---|
1 | strcpy(s1, s2); 复制字符串 s2 到字符串 s1。 |
2 | strcat(s1, s2); 连接字符串 s2 到字符串 s1 的末尾。 |
3 | strlen(s1); 返回字符串 s1 的长度。 |
4 | strcmp(s1, s2); 如果 s1 和 s2 是相同的,则返回 0;如果 s1<s2 则返回小于 0;如果 s1>s2 则返回大于 0。 |
5 | strchr(s1, ch); 返回一个指针,指向字符串 s1 中字符 ch 的第一次出现的位置。 |
6 | strstr(s1, s2); 返回一个指针,指向字符串 s1 中字符串 s2 的第一次出现的位置。 |
次の例では、上記の機能の一部を使用しています。
#include <stdio.h> #include <string.h> int main () { char str1[12] = "Hello"; char str2[12] = "World"; char str3[12]; int len ; /* 复制 str1 到 str3 */ strcpy(str3, str1); printf("strcpy( str3, str1) : %s\n", str3 ); /* 连接 str1 和 str2 */ strcat( str1, str2); printf("strcat( str1, str2): %s\n", str1 ); /* 连接后,str1 的总长度 */ len = strlen(str1); printf("strlen(str1) : %d\n", len ); return 0; }
上記のコードはコンパイルされ、実行されると、次の結果を生成します。
strcpy( str3, str1) : Hello strcat( str1, str2): HelloWorld strlen(str1) : 10
あなたは、C標準ライブラリに複数の文字列関連の機能を見つけることができます。