in reply to Re^3: Write large array to file, very slow
in thread Write large array to file, very slow
"Twice as fast" seems like a lot for in memory operations when there are also disk accesses. I'm sure there are plenty of things to consider (HW, and data size), but with the following code I couldn't get past a difference of around ~5% (although I did notice that trying that with supidly big files made my computer crash :P):
use v5.20; use strict; use warnings; use Benchmark qw( cmpthese ); use Data::Dump qw( pp ); my $size = 10; my $length = 1E6; my @data = ('X' x $length, ) x $size; sub write_copy { open my $fh, ">", "tmp.txt" or die "Can't open output file $!"; $| = 0; my $data = shift; for (@$data) { print $fh "$_\n"; } } sub write_simple { local $\ = "\n"; open my $fh, ">", "tmp.txt" or die "Can't open output file $!"; $| = 0; my $data = shift; for (@$data) { print $fh $_; } } cmpthese( -15, { copy => sub { write_copy(\@data); }, simple => sub { write_simple(\@data); }, } ); __END__ Rate copy simple copy 27.3/s -- -5% simple 28.8/s 5% --
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^5: Write large array to file, very slow
by hippo (Archbishop) on Aug 20, 2018 at 18:11 UTC | |
by Eily (Monsignor) on Aug 21, 2018 at 08:29 UTC | |
by hippo (Archbishop) on Aug 21, 2018 at 08:52 UTC |