📄 ch11_15.htm
字号:
<HTML><HEAD><TITLE>Recipe 11.14. Transparently Persistent Data Structures (Perl Cookbook)</TITLE><METANAME="DC.title"CONTENT="Perl Cookbook"><METANAME="DC.creator"CONTENT="Tom Christiansen & Nathan Torkington"><METANAME="DC.publisher"CONTENT="O'Reilly & Associates, Inc."><METANAME="DC.date"CONTENT="1999-07-02T01:40:54Z"><METANAME="DC.type"CONTENT="Text.Monograph"><METANAME="DC.format"CONTENT="text/html"SCHEME="MIME"><METANAME="DC.source"CONTENT="1-56592-243-3"SCHEME="ISBN"><METANAME="DC.language"CONTENT="en-US"><METANAME="generator"CONTENT="Jade 1.1/O'Reilly DocBook 3.0 to HTML 4.0"><LINKREV="made"HREF="mailto:online-books@oreilly.com"TITLE="Online Books Comments"><LINKREL="up"HREF="ch11_01.htm"TITLE="11. References and Records"><LINKREL="prev"HREF="ch11_14.htm"TITLE="11.13. Storing Data Structures to Disk"><LINKREL="next"HREF="ch11_16.htm"TITLE="11.15. Program: Binary Trees"></HEAD><BODYBGCOLOR="#FFFFFF"><img alt="Book Home" border="0" src="gifs/smbanner.gif" usemap="#banner-map" /><map name="banner-map"><area shape="rect" coords="1,-2,616,66" href="index.htm" alt="Perl Cookbook"><area shape="rect" coords="629,-11,726,25" href="jobjects/fsearch.htm" alt="Search this book" /></map><div class="navbar"><p><TABLEWIDTH="684"BORDER="0"CELLSPACING="0"CELLPADDING="0"><TR><TDALIGN="LEFT"VALIGN="TOP"WIDTH="228"><ACLASS="sect1"HREF="ch11_14.htm"TITLE="11.13. Storing Data Structures to Disk"><IMGSRC="../gifs/txtpreva.gif"ALT="Previous: 11.13. Storing Data Structures to Disk"BORDER="0"></A></TD><TDALIGN="CENTER"VALIGN="TOP"WIDTH="228"><B><FONTFACE="ARIEL,HELVETICA,HELV,SANSERIF"SIZE="-1"><ACLASS="chapter"REL="up"HREF="ch11_01.htm"TITLE="11. References and Records"></A></FONT></B></TD><TDALIGN="RIGHT"VALIGN="TOP"WIDTH="228"><ACLASS="sect1"HREF="ch11_16.htm"TITLE="11.15. Program: Binary Trees"><IMGSRC="../gifs/txtnexta.gif"ALT="Next: 11.15. Program: Binary Trees"BORDER="0"></A></TD></TR></TABLE></DIV><DIVCLASS="sect1"><H2CLASS="sect1"><ACLASS="title"NAME="ch11-11536">11.14. Transparently Persistent Data Structures</A></H2><DIVCLASS="sect2"><H3CLASS="sect2"><ACLASS="title"NAME="ch11-pgfId-1440">Problem<ACLASS="indexterm"NAME="ch11-idx-1000004879-0"></A><ACLASS="indexterm"NAME="ch11-idx-1000004879-1"></A><ACLASS="indexterm"NAME="ch11-idx-1000004879-2"></A><ACLASS="indexterm"NAME="ch11-idx-1000004879-3"></A><ACLASS="indexterm"NAME="ch11-idx-1000004879-4"></A><ACLASS="indexterm"NAME="ch11-idx-1000004879-5"></A></A></H3><PCLASS="para">You have a complex data structure that you want to persist outside your program.</P></DIV><DIVCLASS="sect2"><H3CLASS="sect2"><ACLASS="title"NAME="ch11-pgfId-1446">Solution</A></H3><PCLASS="para">Use MLDBM and either (preferably) DB_File, or else GDBM_File:</P><PRECLASS="programlisting">use MLDBM qw(DB_File);use Fcntl; tie(%hash, 'MLDBM', 'testfile.db', O_CREAT|O_RDWR, 0666) or die "can't open tie to testfile.db: $!";# ... act on %hashuntie %hash;</PRE></DIV><DIVCLASS="sect2"><H3CLASS="sect2"><ACLASS="title"NAME="ch11-pgfId-1470">Discussion</A></H3><PCLASS="para">A hash with 100,000 items in it would undoubtably take considerable time to build. Storing this to disk, either slowly by hand or quickly with Storable, is still an expensive operation in memory and computation.</P><PCLASS="para">The DBM modules solve this by tying hashes to disk database files. Rather than reading the whole structure in at once, they only pull in what they need, when they need it. To the user, it looks like a hash that persists across program invocations.</P><PCLASS="para">Unfortunately, the values in this persistent hash must be plain strings. You cannot readily use a database file as a backing store for a hash of hashes, a hash of arrays, and so on, just for a hash of strings.</P><PCLASS="para">However, the MLDBM module from CPAN allows you to store references in a database. It uses Data::Dumper to stringify these references for external storage:</P><PRECLASS="programlisting">use MLDBM qw(DB_File);use Fcntl; tie(%hash, 'MLDBM', 'testfile.db', O_CREAT|O_RDWR, 0666) or die "can't open tie to testfile.db: $!";</PRE><PCLASS="para">Now you can use <CODECLASS="literal">%hash</CODE> to fetch or store complex records from disk. The only drawback is that you can't access the references piecemeal. You have to pull in the reference from the database, work with it, and then store it back.</P><PRECLASS="programlisting"># this doesn't work!$hash{"some key"}[4] = "fred";# RIGHT$aref = $hash{"some key"};$aref->[4] = "fred";$hash{"some key"} = $aref;<ACLASS="indexterm"NAME="ch11-idx-1000004881-0"></A><ACLASS="indexterm"NAME="ch11-idx-1000004881-1"></A><ACLASS="indexterm"NAME="ch11-idx-1000004881-2"></A><ACLASS="indexterm"NAME="ch11-idx-1000004881-3"></A><ACLASS="indexterm"NAME="ch11-idx-1000004881-4"></A><ACLASS="indexterm"NAME="ch11-idx-1000004881-5"></A></PRE></DIV><DIVCLASS="sect2"><H3CLASS="sect2"><ACLASS="title"NAME="ch11-pgfId-1506">See Also</A></H3><PCLASS="para">The documentation for the CPAN module MLDBM; <ACLASS="xref"HREF="ch14_02.htm"TITLE="Making and Using a DBM File">Recipe 14.1</A>; <ACLASS="xref"HREF="ch14_08.htm"TITLE="Treating a Text File as a Database Array">Recipe 14.7</A>; <ACLASS="xref"HREF="ch14_12.htm"TITLE="Program: ggh - Grep Netscape Global History">Recipe 14.11</A></P></DIV></DIV><DIVCLASS="htmlnav"><P></P><HRALIGN="LEFT"WIDTH="684"TITLE="footer"><TABLEWIDTH="684"BORDER="0"CELLSPACING="0"CELLPADDING="0"><TR><TDALIGN="LEFT"VALIGN="TOP"WIDTH="228"><ACLASS="sect1"HREF="ch11_14.htm"TITLE="11.13. Storing Data Structures to Disk"><IMGSRC="../gifs/txtpreva.gif"ALT="Previous: 11.13. Storing Data Structures to Disk"BORDER="0"></A></TD><TDALIGN="CENTER"VALIGN="TOP"WIDTH="228"><ACLASS="book"HREF="index.htm"TITLE="Perl Cookbook"><IMGSRC="../gifs/txthome.gif"ALT="Perl Cookbook"BORDER="0"></A></TD><TDALIGN="RIGHT"VALIGN="TOP"WIDTH="228"><ACLASS="sect1"HREF="ch11_16.htm"TITLE="11.15. Program: Binary Trees"><IMGSRC="../gifs/txtnexta.gif"ALT="Next: 11.15. Program: Binary Trees"BORDER="0"></A></TD></TR><TR><TDALIGN="LEFT"VALIGN="TOP"WIDTH="228">11.13. Storing Data Structures to Disk</TD><TDALIGN="CENTER"VALIGN="TOP"WIDTH="228"><ACLASS="index"HREF="index/index.htm"TITLE="Book Index"><IMGSRC="../gifs/index.gif"ALT="Book Index"BORDER="0"></A></TD><TDALIGN="RIGHT"VALIGN="TOP"WIDTH="228">11.15. Program: Binary Trees</TD></TR></TABLE><HRALIGN="LEFT"WIDTH="684"TITLE="footer"><FONTSIZE="-1"></DIV<!-- LIBRARY NAV BAR --> <img src="../gifs/smnavbar.gif" usemap="#library-map" border="0" alt="Library Navigation Links"><p> <a href="copyrght.htm">Copyright © 2002</a> O'Reilly & Associates. All rights reserved.</font> </p> <map name="library-map"> <area shape="rect" coords="1,0,85,94" href="../index.htm"><area shape="rect" coords="86,1,178,103" href="../lwp/index.htm"><area shape="rect" coords="180,0,265,103" href="../lperl/index.htm"><area shape="rect" coords="267,0,353,105" href="../perlnut/index.htm"><area shape="rect" coords="354,1,446,115" href="../prog/index.htm"><area shape="rect" coords="448,0,526,132" href="../tk/index.htm"><area shape="rect" coords="528,1,615,119" href="../cookbook/index.htm"><area shape="rect" coords="617,0,690,135" href="../pxml/index.htm"></map> </BODY></HTML>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -