On Monday, 8 June 2015 at 10:59:45 UTC, Daniel Kozák wrote:
import std.conv;
import std.utf;
import std.datetime;
import std.stdio;

void f0() {
string somestr = "some not so long utf8 string forbenchmarking";
    dstring str = to!dstring(somestr);
}


void f1() {
string somestr = "some not so long utf8 string forbenchmarking";
    dstring str = toUTF32(somestr);
}

void main() {
    auto r = benchmark!(f0,f1)(1_000_000);
    auto f0Result = to!Duration(r[0]);
    auto f1Result = to!Duration(r[1]);
    writeln("f0 time: ",f0Result);
    writeln("f1 time: ",f1Result);
}


/// output ///
f0 time: 2 secs, 281 ms, 933 μs, and 8 hnsecs
f1 time: 600 ms, 979 μs, and 8 hnsecs

Chances are you're benchmarking the GC. Try benchmark!(f0,f1,f0,f1,f0,f1);

Reply via email to