You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <meta name="theme-color" content="#375EAB">
<title>twotier - The Go Programming Language</title>
<link type="text/css" rel="stylesheet" href="../../../../../lib/godoc/style.css">
<link rel="stylesheet" href="../../../../../lib/godoc/jquery.treeview.css"> <script type="text/javascript">window.initFuncs = [];</script> </head> <body>
<div id='lowframe' style="position: fixed; bottom: 0; left: 0; height: 0; width: 100%; border-top: thin solid grey; background-color: white; overflow: auto;"> ... </div><!-- #lowframe -->
<div id="topbar" class="wide"><div class="container"> <div class="top-heading" id="heading-wide"><a href="http://localhost:6060/">The Go Programming Language</a></div> <div class="top-heading" id="heading-narrow"><a href="http://localhost:6060/">Go</a></div> <a href="index.html#" id="menu-button"><span id="menu-button-arrow">▽</span></a> <form method="GET" action="http://localhost:6060/search"> <div id="menu"> <a href="http://localhost:6060/doc/">Documents</a> <a href="http://localhost:6060/pkg/">Packages</a> <a href="http://localhost:6060/project/">The Project</a> <a href="http://localhost:6060/help/">Help</a> <a href="http://localhost:6060/blog/">Blog</a>
<input type="text" id="search" name="q" class="inactive" value="Search" placeholder="Search"> </div> </form>
</div></div>
<div id="page" class="wide"> <div class="container">
<h1>Package twotier</h1>
<div id="nav"></div>
<!--
Copyright 2009 The Go Authors. All rights reserved. Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. --> <!--
Note: Static (i.e., not template-generated) href and id attributes start with "pkg-" to make it impossible for them to conflict with generated attributes (some of which correspond to Go identifiers). -->
<script type='text/javascript'> document.ANALYSIS_DATA = null; document.CALLGRAPH = null; </script>
<div id="short-nav"> <dl> <dd><code>import "github.com/die-net/lrucache/twotier"</code></dd> </dl> <dl> <dd><a href="index.html#pkg-overview" class="overviewLink">Overview</a></dd> <dd><a href="index.html#pkg-index" class="indexLink">Index</a></dd> </dl> </div> <!-- The package's Name is printed as title by the top-level template --> <div id="pkg-overview" class="toggleVisible"> <div class="collapsed"> <h2 class="toggleButton" title="Click to show Overview section">Overview ▹</h2> </div> <div class="expanded"> <h2 class="toggleButton" title="Click to hide Overview section">Overview ▾</h2> <p> Package twotier provides a wrapper for two httpcache.Cache instances, allowing you to use both a small and fast cache for popular objects and fall back to a larger and slower cache for less popular ones. </p>
</div> </div>
<div id="pkg-index" class="toggleVisible"> <div class="collapsed"> <h2 class="toggleButton" title="Click to show Index section">Index ▹</h2> </div> <div class="expanded"> <h2 class="toggleButton" title="Click to hide Index section">Index ▾</h2>
<!-- Table of contents for API; must be named manual-nav to turn off auto nav. --> <div id="manual-nav"> <dl> <dd><a href="index.html#TwoTier">type TwoTier</a></dd> <dd> <a href="index.html#New">func New(first httpcache.Cache, second httpcache.Cache) *TwoTier</a></dd> <dd> <a href="index.html#TwoTier.Delete">func (c *TwoTier) Delete(key string)</a></dd> <dd> <a href="index.html#TwoTier.Get">func (c *TwoTier) Get(key string) ([]byte, bool)</a></dd> <dd> <a href="index.html#TwoTier.Set">func (c *TwoTier) Set(key string, value []byte)</a></dd> </dl> </div><!-- #manual-nav -->
<h4>Package files</h4> <p> <span style="font-size:90%"> <a href="http://localhost:6060/src/github.com/die-net/lrucache/twotier/twotier.go">twotier.go</a> </span> </p> </div><!-- .expanded --> </div><!-- #pkg-index -->
<div id="pkg-callgraph" class="toggle" style="display: none"> <div class="collapsed"> <h2 class="toggleButton" title="Click to show Internal Call Graph section">Internal call graph ▹</h2> </div> <!-- .expanded --> <div class="expanded"> <h2 class="toggleButton" title="Click to hide Internal Call Graph section">Internal call graph ▾</h2> <p> In the call graph viewer below, each node is a function belonging to this package and its children are the functions it calls—perhaps dynamically. </p> <p> The root nodes are the entry points of the package: functions that may be called from outside the package. There may be non-exported or anonymous functions among them if they are called dynamically from another package. </p> <p> Click a node to visit that function's source code. From there you can visit its callers by clicking its declaring <code>func</code> token. </p> <p> Functions may be omitted if they were determined to be unreachable in the particular programs or tests that were analyzed. </p> <!-- Zero means show all package entry points. --> <ul style="margin-left: 0.5in" id="callgraph-0" class="treeview"></ul> </div> </div> <!-- #pkg-callgraph -->
<h2 id="TwoTier">type <a href="http://localhost:6060/src/github.com/die-net/lrucache/twotier/twotier.go?s=426:497#L2">TwoTier</a></h2> <pre>type TwoTier struct { <span class="comment">// contains filtered or unexported fields</span> }</pre> <p> TwoTier creates a two-tiered cache out of two httpcache.Cache instances. Reads are favored from first, and writes affect both first and second. </p>
<h3 id="New">func <a href="http://localhost:6060/src/github.com/die-net/lrucache/twotier/twotier.go?s=564:628#L8">New</a></h3> <pre>func New(first <a href="../../../gregjones/httpcache/index.html">httpcache</a>.<a href="../../../gregjones/httpcache/index.html#Cache">Cache</a>, second <a href="../../../gregjones/httpcache/index.html">httpcache</a>.<a href="../../../gregjones/httpcache/index.html#Cache">Cache</a>) *<a href="index.html#TwoTier">TwoTier</a></pre> <p> New creates a TwoTier. Both first and second must be non-nil. </p>
<h3 id="TwoTier.Delete">func (*TwoTier) <a href="http://localhost:6060/src/github.com/die-net/lrucache/twotier/twotier.go?s=1577:1613#L44">Delete</a></h3> <pre>func (c *<a href="index.html#TwoTier">TwoTier</a>) Delete(key <a href="../../../../builtin/index.html#string">string</a>)</pre> <p> Delete removes the value associated with a key from both the first and second tier caches. </p>
<h3 id="TwoTier.Get">func (*TwoTier) <a href="http://localhost:6060/src/github.com/die-net/lrucache/twotier/twotier.go?s=990:1038#L19">Get</a></h3> <pre>func (c *<a href="index.html#TwoTier">TwoTier</a>) Get(key <a href="../../../../builtin/index.html#string">string</a>) ([]<a href="../../../../builtin/index.html#byte">byte</a>, <a href="../../../../builtin/index.html#bool">bool</a>)</pre> <p> Get returns the []byte representation of a cached response and a bool set to true if the key was found. It tries the first tier cache, and if that's not successful, copies the result from the second tier into the first tier. </p>
<h3 id="TwoTier.Set">func (*TwoTier) <a href="http://localhost:6060/src/github.com/die-net/lrucache/twotier/twotier.go?s=1380:1427#L37">Set</a></h3> <pre>func (c *<a href="index.html#TwoTier">TwoTier</a>) Set(key <a href="../../../../builtin/index.html#string">string</a>, value []<a href="../../../../builtin/index.html#byte">byte</a>)</pre> <p> Set stores the []byte representation of a response for a given key into the second tier cache, and deletes the cache entry from the first tier cache. </p>
<div id="footer"> Build version go1.6.<br> Except as <a href="https://developers.google.com/site-policies#restrictions">noted</a>, the content of this page is licensed under the Creative Commons Attribution 3.0 License, and code is licensed under a <a href="http://localhost:6060/LICENSE">BSD license</a>.<br> <a href="http://localhost:6060/doc/tos.html">Terms of Service</a> | <a href="http://www.google.com/intl/en/policies/privacy/">Privacy Policy</a> </div>
</div><!-- .container --> </div><!-- #page -->
<!-- TODO(adonovan): load these from <head> using "defer" attribute? --> <script type="text/javascript" src="../../../../../lib/godoc/jquery.js"></script> <script type="text/javascript" src="../../../../../lib/godoc/jquery.treeview.js"></script> <script type="text/javascript" src="../../../../../lib/godoc/jquery.treeview.edit.js"></script>
<script type="text/javascript" src="../../../../../lib/godoc/godocs.js"></script>
</body> </html>
|