Portál AbcLinuxu, 11. května 2025 23:38
Řešení dotazu:
sub new { my ( $pkg, $db ) = @_; my $self = bless {}, $pkg; $self->{_db} = "db/$db.db"; open( $self->{_dbhandler}, $self->{_db} ) or die "DB $db.db not open\n"; return $self; } sub _view { my ( $self, $arg ) = @_; my $dbhandler = $self->{_dbhandler}; while ( my $line = <$dbhandler> ) { if ( $line =~ /( *)$arg( *)\=( *)'(.*?)';( *)/ ) { return $4; } } return undef; }
$self->{_db} = new TAI::DB( 'status' ); print Dumper( $self->{_db} ); print "test1: " . $self->{_db}->_view( 'task' ) . "\n"; print Dumper( $self->{_db} ); print "test2: " . $self->{_db}->_view( 'task' ) . "\n"; print Dumper( $self->{_db} ); print "test3: " . $self->{_db}->_view( 'task' ) . "\n"; print "test4: " . $self->{_db}->_view( 'task' ) . "\n";No a k tomu dotazu, myslím si to co ostatní: soubor projíždíte po řádkách, takže nebude vracet v každém volání totéž. Dá se to řešit různě, ale myslím, že děláte tu celou věc trochu přes ruku, co přesně má být účelem toho kódu?
seek
je jeden z těch méně šťastných.
Nejjednodušší je dát open/close do rutiny _view, čili pokaždé soubor otevřít, najít řádek a potom ho zavřít. Je to stejně efektivní jako seek, ale čistější a robustnější vůči přepisu/smazání souboru.
Další možnost je v konstruktoru soubor kompletně přečíst a uložit si páry klíč=hodnota (pokud chápu dobře, tak ten soubor má takovou strukturu) do hashe a ve _view pouze vracet hodnoty z hashe. Případně dodělat něco jako reload, kterej to načte na požádání znova. Tento přístup je nesporně efektivnější co se týče počtu čtení souboru.
Třetí možnost je se porozhlédnout po CPANu, co například Config::Tiny a další?
Jinak, databáze není nevyhnutelně špatná věc.
Ještě pár postřehů k tomu kódu:
if ( $line =~ /( *)$arg( *)\=( *)'(.*?)';( *)/ ) { return $4; }je lépe zapsat jako
if ( $line =~ /\A\s*\Q$arg\E\s*\=\s*'(.*?)';\s*\Z/ ) { return $1; }(použití \s pro prázdné znaky, \A ... \Z pro ohraničení a \Q ... \E pro quotování proměnné. BTW regexp pro načtení celého souboru by mohl vypadat asi takto nějak
my %config; open (my $soubor, '<', 'soubor.txt'); { unset $/; %config = (<$soubor> =~ /^\s*(\Q$arg\E)\s*\=\s*'(.*?)';\s*?/xmsg); }Místo
return undef;
je kratší (a správnější) použít jen return;
.
Místo open...or die
je modernější metoda use autodie
.
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.