D Programmierung - Strings
D bietet die folgenden zwei Arten von Zeichenfolgendarstellungen:
- Zeichenarray
- Kernsprachenzeichenfolge
Zeichenarray
Wir können das Zeichenarray in einer der beiden Formen darstellen, wie unten gezeigt. Das erste Formular gibt die Größe direkt an und das zweite Formular verwendet die Dup-Methode, mit der eine beschreibbare Kopie der Zeichenfolge "Guten Morgen" erstellt wird.
char[9] greeting1 = "Hello all";
char[] greeting2 = "Good morning".dup;
Beispiel
Hier ist ein einfaches Beispiel unter Verwendung der obigen einfachen Zeichenarrayformulare.
import std.stdio;
void main(string[] args) {
char[9] greeting1 = "Hello all";
writefln("%s",greeting1);
char[] greeting2 = "Good morning".dup;
writefln("%s",greeting2);
}
Wenn der obige Code kompiliert und ausgeführt wird, ergibt er Folgendes:
Hello all
Good morning
Kernsprachenzeichenfolge
Zeichenfolgen sind in die Kernsprache von D integriert. Diese Zeichenfolgen sind mit dem oben gezeigten Zeichenarray kompatibel. Das folgende Beispiel zeigt eine einfache Zeichenfolgendarstellung.
string greeting1 = "Hello all";
Beispiel
import std.stdio;
void main(string[] args) {
string greeting1 = "Hello all";
writefln("%s",greeting1);
char[] greeting2 = "Good morning".dup;
writefln("%s",greeting2);
string greeting3 = greeting1;
writefln("%s",greeting3);
}
Wenn der obige Code kompiliert und ausgeführt wird, ergibt er Folgendes:
Hello all
Good morning
Hello all
String-Verkettung
Die String-Verkettung in der D-Programmierung verwendet das Tilde-Symbol (~).
Beispiel
import std.stdio;
void main(string[] args) {
string greeting1 = "Good";
char[] greeting2 = "morning".dup;
char[] greeting3 = greeting1~" "~greeting2;
writefln("%s",greeting3);
string greeting4 = "morning";
string greeting5 = greeting1~" "~greeting4;
writefln("%s",greeting5);
}
Wenn der obige Code kompiliert und ausgeführt wird, ergibt er Folgendes:
Good morning
Good morning
Länge der Zeichenfolge
Die Länge der Zeichenfolge in Bytes kann mit Hilfe der Längenfunktion abgerufen werden.
Beispiel
import std.stdio;
void main(string[] args) {
string greeting1 = "Good";
writefln("Length of string greeting1 is %d",greeting1.length);
char[] greeting2 = "morning".dup;
writefln("Length of string greeting2 is %d",greeting2.length);
}
Wenn der obige Code kompiliert und ausgeführt wird, ergibt sich das folgende Ergebnis:
Length of string greeting1 is 4
Length of string greeting2 is 7
String-Vergleich
Der String-Vergleich ist in der D-Programmierung recht einfach. Sie können die Operatoren ==, <und> für Zeichenfolgenvergleiche verwenden.
Beispiel
import std.stdio;
void main() {
string s1 = "Hello";
string s2 = "World";
string s3 = "World";
if (s2 == s3) {
writeln("s2: ",s2," and S3: ",s3, " are the same!");
}
if (s1 < s2) {
writeln("'", s1, "' comes before '", s2, "'.");
} else {
writeln("'", s2, "' comes before '", s1, "'.");
}
}
Wenn der obige Code kompiliert und ausgeführt wird, ergibt er Folgendes:
s2: World and S3: World are the same!
'Hello' comes before 'World'.
Saiten ersetzen
Wir können Strings mit dem String [] ersetzen.
Beispiel
import std.stdio;
import std.string;
void main() {
char[] s1 = "hello world ".dup;
char[] s2 = "sample".dup;
s1[6..12] = s2[0..6];
writeln(s1);
}
Wenn der obige Code kompiliert und ausgeführt wird, ergibt er Folgendes:
hello sample
Indexmethoden
Indexmethoden für die Position eines Teilstrings in einer Zeichenfolge, einschließlich indexOf und lastIndexOf, werden im folgenden Beispiel erläutert.
Beispiel
import std.stdio;
import std.string;
void main() {
char[] s1 = "hello World ".dup;
writeln("indexOf of llo in hello is ",std.string.indexOf(s1,"llo"));
writeln(s1);
writeln("lastIndexOf of O in hello is " ,std.string.lastIndexOf(s1,"O",CaseSensitive.no));
}
Wenn der obige Code kompiliert und ausgeführt wird, ergibt sich das folgende Ergebnis:
indexOf.of llo in hello is 2
hello World
lastIndexOf of O in hello is 7
Fälle behandeln
Die Methoden zum Ändern von Fällen werden im folgenden Beispiel gezeigt.
Beispiel
import std.stdio;
import std.string;
void main() {
char[] s1 = "hello World ".dup;
writeln("Capitalized string of s1 is ",capitalize(s1));
writeln("Uppercase string of s1 is ",toUpper(s1));
writeln("Lowercase string of s1 is ",toLower(s1));
}
Wenn der obige Code kompiliert und ausgeführt wird, ergibt sich das folgende Ergebnis:
Capitalized string of s1 is Hello world
Uppercase string of s1 is HELLO WORLD
Lowercase string of s1 is hello world
Zeichen einschränken
Restzeichen in Zeichenfolgen werden im folgenden Beispiel gezeigt.
Beispiel
import std.stdio;
import std.string;
void main() {
string s = "H123Hello1";
string result = munch(s, "0123456789H");
writeln("Restrict trailing characters:",result);
result = squeeze(s, "0123456789H");
writeln("Restrict leading characters:",result);
s = " Hello World ";
writeln("Stripping leading and trailing whitespace:",strip(s));
}
Wenn der obige Code kompiliert und ausgeführt wird, ergibt sich das folgende Ergebnis:
Restrict trailing characters:H123H
Restrict leading characters:ello1
Stripping leading and trailing whitespace:Hello World