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