Sök…


Anmärkningar

  • Strängar i D är oföränderliga; använd .dup att skapa en muterbar char grupp om du vill redigera på plats.

Omvänd en sträng

string definieras som alias string = immutable(char)[]; : så måste använda dup att göra en muterbar char array, innan den kan vändas:

import std.stdio;
import std.string;

int main() {

    string x = "Hello world!";
    char[] x_rev = x.dup.reverse;
    
    writeln(x_rev); // !dlrow olleH
    
    return 0;

}

Testa för en tom eller noll sträng

Tom sträng

Tom sträng är inte noll utan har noll längd:

string emptyString = "";
// an empty string is not null...
assert(emptyString !is null);

// ... but it has zero lenght
assert(emptyString.length == 0);

Nullsträng

string nullString = null;

en nollsträng är noll (De Lapalisse)

assert(nullString is null);

men till skillnad från C #, läser längden på en nollsträng inte ett fel:

assert(nullString.length == 0);
assert(nullString.empty);

Testa för tom eller null


if (emptyOrNullString.length == 0) {
}

// or
if (emptyOrNullString.length) {
}

// or
import std.array;
if (emptyOrNullString.empty) {
}

Test för noll

if (nullString is null) {
}

referenser

Konvertera sträng till ubyte [] och vice versa

Sträng till oföränderlig ubyte[]

string s = "unogatto";
immutable(ubyte[]) ustr = cast(immutable(ubyte)[])s;

assert(typeof(ustr).stringof == "immutable(ubyte[])");
assert(ustr.length == 8);
assert(ustr[0] == 0x75); //u
assert(ustr[1] == 0x6e); //n
assert(ustr[2] == 0x6f); //o
assert(ustr[3] == 0x67); //g
assert(ustr[7] == 0x6f); //o

Sträng till ubyte[]

string s = "unogatto";
ubyte[] mustr = cast(ubyte[])s;

assert(typeof(mustr).stringof == "ubyte[]");

assert(mustr.length == 8);
assert(mustr[0] == 0x75);
assert(mustr[1] == 0x6e);
assert(mustr[2] == 0x6f);
assert(mustr[3] == 0x67);
assert(mustr[7] == 0x6f);

ubyte[] till sträng

ubyte[] stream = [ 0x75, 0x6e, 0x6f, 0x67];
string us  = cast(string)stream;
assert(us == "unog");

referenser



Modified text is an extract of the original Stack Overflow Documentation
Licensierat under CC BY-SA 3.0
Inte anslutet till Stack Overflow