change to hexo
diff --git a/.nojekyll b/.nojekyll
deleted file mode 100644
index b522d54..0000000
--- a/.nojekyll
+++ /dev/null
@@ -1 +0,0 @@
-Gor Here. http://github.com/wendal/gor
\ No newline at end of file
diff --git a/2013/new-born.html b/2013/new-born.html
deleted file mode 100644
index 3af4543..0000000
--- a/2013/new-born.html
+++ /dev/null
@@ -1,247 +0,0 @@
-<!DOCTYPE html>
-<html lang="en">
- <head>
- <meta charset="utf-8">
- <title>你的第一篇博客</title>
-
- <meta name="author" content="Archer Ding">
-
- <!-- Le HTML5 shim, for IE6-8 support of HTML elements -->
- <!--[if lt IE 9]>
- <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
-
- <!-- Le styles -->
- <link href="/assets/twitter/stylesheets/bootstrap.min.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/stylesheets/style.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/widgets/google_prettify/stylesheets/twitter-bootstrap.css" type="text/css" rel="stylesheet" media="all">
-
-
- <!-- Le fav and touch icons -->
- <!-- Update these with your own images
- <link rel="shortcut icon" href="images/favicon.ico">
- <link rel="apple-touch-icon" href="images/apple-touch-icon.png">
- <link rel="apple-touch-icon" sizes="72x72" href="images/apple-touch-icon-72x72.png">
- <link rel="apple-touch-icon" sizes="114x114" href="images/apple-touch-icon-114x114.png">
- -->
- </head>
-
- <body>
-
- <div class="navbar">
- <div class="navbar-inner">
- <div class="container">
- <a class="brand" href="/">ArcherDing's Blog</a>
- <ul class="nav">
-
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
-
-
-
-
- <li><a href="/tags">Tags</a></li>
-
-
-
-
-
-
- <li><a href="/categories">Categories</a></li>
-
-
-
-
-
-
- <li><a href="/pages">Pages</a></li>
-
-
-
-
-
-
- <li><a href="/about">About Me</a></li>
-
-
-
- </ul>
- </div>
- </div>
- </div>
-
- <div class="container">
-
- <div class="content">
- <div class="page-header">
- <h1>你的第一篇博客 </h1>
-</div>
-
-<div class="row">
- <div class="span8">
- <h1>感谢你使用Gor编写博客</h1>
-
-<h2>本文位于 posts/first-blog.md , 你可以任意删掉,修改这个文件</h2>
-
-<p>文件开头是当前文章的元数据</p>
-
-<ol>
-<li>date为自动生成, 当然,你可以修改,这是你的自由</li>
-<li>permalink 可以是固定地址,也可以由gor为你自动生成</li>
-<li>categories 就是分类, 可以多个</li>
-<li>tags 同理,多个标签也是很常见的</li>
-</ol>
-
-<p>请确保文件使用UTF8 without BOM编码</p>
-
-<h2>你可以通过执行下面的语句来新建一篇博客:</h2>
-
-<pre><code>gor post 文章标题
-</code></pre>
-
-<h2>编译你的博客,并预览之</h2>
-
-<pre><code>gor compile #编译
-gor http
-</code></pre>
-
-<p>然后打开你的浏览器,访问 <a href="http://127.0.0.1:8080">http://127.0.0.1:8080</a> 来预览</p>
-
-<h2>你将使用Markdown来编写博客</h2>
-
-<p><a href="http://wowubuntu.com/markdown/">Markdown 语法中文版</a> 能让你快速入门其语法</p>
-
-<p>相信<a href="http://markdownpad.com">MarkdownPad</a>或<a href="http://code.google.com/p/liteide/">liteide</a>会是你的编写博客的好帮手</p>
-
-<h2>如果你打算部署到github的pages上</h2>
-
-<ol>
-<li>申请github帐户</li>
-<li>新建一个库 username.github.com 即你的用户名命名的地址</li>
-<li>将compiled目录,作为根路径,提交上去github.com上</li>
-<li>稍等几分钟, 你即可通过 <a href="http://username.github.com">http://username.github.com</a> 访问到</li>
-</ol>
-
-<h2>附上git教程 <a href="http://gitbook.liuhui998.com/">GitBook中文版</a></h2>
-
-<p>一般来说,你只需要几个简单的git命令就足以应付大部分需求(仅示例)</p>
-
-<pre><code>git clone git://github.com/wendal/wendal.net.git
-git add -A
-git commit -m "..."
-git pull
-git push
-</code></pre>
-
-<h2>用gor编写博客将会是一件很开心的事,如果有任何意见或建议,欢迎到 <a href="http://github.com/wendal/gor">gor的官网</a> 提交issue</h2>
-
-<h1>祝你使用愉快</h1>
-
- <hr>
- <div class="pagination">
- <ul>
- <ul>
-
- <li class="prev"><a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E6%95%B0%E7%BB%84/" title="JavaScript学习笔记-数组">← Previous</a></li>
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
-
- <li class="next disabled"><a>Next →</a>
-
- </ul>
- </ul>
- </div>
- <hr>
-
-<div id="disqus_thread"></div>
-<script>
- var disqus_developer = 1;
- var disqus_shortname = 'jekyllbootstrap'; // required: replace example with your forum shortname
- /* * * DON'T EDIT BELOW THIS LINE * * */
- (function() {
- var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
- dsq.src = 'http://' + disqus_shortname + '.disqus.com/embed.js';
- (document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
- })();
-</script>
-<noscript>Please enable JavaScript to view the <a href="http://disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript>
-<a href="http://disqus.com" class="dsq-brlink">blog comments powered by <span class="logo-disqus">Disqus</span></a>
-
- </div>
-
- <div class="span4">
- <h4>Published</h4>
- <div class="date"><span>2013-02-08</span></div>
- <br>
- <h4>Categories</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/categories/#Gor-ref">Gor <span>1</span></a>
-</li>
-
- <li>
- <a href="/categories/#Blog-ref">Blog <span>1</span></a>
-</li>
-
- </ul>
- <br>
- <h4>Tags</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/tags/#Gor-ref">Gor <span>1</span></a>
-</li>
-
- </ul>
- </div>
-</div>
-
- </div>
-
- <footer>
- <p>© Archer Ding 2013
- with help from <a href="http://github.com/wendal/gor" target="_blank" title="Gor -- Fast Blog">Gor</a>
- and <a href="http://twitter.github.com/bootstrap/" target="_blank">Twitter Bootstrap</a>
- and Idea from <a href="http://ruhoh.com" target="_blank" title="The Definitive Technical Blogging Framework">ruhoh</a>
- </p>
- </footer>
-
- </div> <!-- /container -->
-
-
-<script src="//cdnjscn.b0.upaiyun.com/libs/prettify/r298/prettify.min.js"></script>
-<script>
- var pres = document.getElementsByTagName("pre");
- for (var i=0; i < pres.length; ++i) {
- pres[i].className = "prettyprint linenums";
- }
- prettyPrint();
-</script>
-
-
-<script type="text/javascript">
-
- var _gaq = _gaq || [];
- var pluginUrl = '//www.google-analytics.com/plugins/ga/inpage_linkid.js';
- _gaq.push(['_require', 'inpage_linkid', pluginUrl]);
- _gaq.push(['_setAccount', 'UA-123-12']);
- _gaq.push(['_trackPageview']);
-
- (function() {
- var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
- ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
- var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
- })();
-
-</script>
- </body>
-</html>
diff --git a/2015/05/29/javascript-note-01/index.html b/2015/05/29/javascript-note-01/index.html
new file mode 100644
index 0000000..6a72af1
--- /dev/null
+++ b/2015/05/29/javascript-note-01/index.html
@@ -0,0 +1,634 @@
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="JavaScript," />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
+</script>
+
+
+
+
+ <title> JavaScript学习笔记-数组 // ArcherDing's Notes </title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column page-post-detail">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
+<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
+
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
+
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
+
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-expand">
+
+
+ <div class="post post-type-normal ">
+ <div class="post-header">
+
+
+
+ <h1 class="post-title">
+
+
+
+ JavaScript学习笔记-数组
+
+
+ </h1>
+
+
+ <div class="post-meta">
+ <span class="post-time">
+ 发表于 2015-05-29
+ </span>
+
+
+ <span class="post-category">
+ | 分类于
+
+ <a href="/categories/JavaScript/">JavaScript</a>
+
+
+
+
+
+ </span>
+
+
+
+
+ <span class="post-comments-count">
+ |
+ <a href="/2015/05/29/javascript-note-01/#comments" >
+ <span class="post-comments-count ds-thread-count" data-thread-key="2015/05/29/javascript-note-01/"></span>
+ </a>
+ </span>
+
+
+ </div>
+ </div>
+
+ <div class="post-body">
+
+
+
+
+
+ <h3 id="什么是数组">什么是数组</h3><p>通常数组是一种线性结构,但是JavaScript中的数组是一个<strong>特殊的对象</strong>,其索引值在内部被转换成字符串处理。</p>
+<h3 id="创建数组">创建数组</h3><figure class="highlight smali"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br></pre></td><td class="code"><pre><span class="line">var<span class="instruction"> array </span>= <span class="keyword">[</span>]; //length = 0</span><br><span class="line">var<span class="instruction"> array </span>= <span class="keyword">[</span>10]; //length = 1</span><br><span class="line">var<span class="instruction"> array </span>= <span class="keyword">[</span>1,2,3,4,5];//length = 5</span><br><span class="line">var<span class="instruction"> array </span>=<span class="instruction"> new </span>Array(<span class="function">)</span>; //length = 0</span><br><span class="line">var<span class="instruction"> array </span>=<span class="instruction"> new </span>Array(10<span class="function">)</span>; //length = 10</span><br><span class="line">var<span class="instruction"> array </span>=<span class="instruction"> new </span>Array(1,2,3,4,6<span class="function">)</span>; //length = 5</span><br></pre></td></tr></table></figure>
+<p><em>使用[]创建数组的效率高,因为字符少。</em></p>
+<h3 id="遍历数组">遍历数组</h3><figure class="highlight matlab"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br></pre></td><td class="code"><pre><span class="line">var nums = <span class="matrix">[<span class="number">1</span>,<span class="number">3</span>,<span class="number">4</span>,<span class="number">5</span>,<span class="number">6</span>]</span>;</span><br><span class="line"><span class="keyword">for</span>(var <span class="built_in">i</span> = <span class="number">0</span>; <span class="built_in">i</span> < nums.<span class="built_in">length</span>; ++<span class="built_in">i</span>)<span class="cell">{</span><br><span class="line"> console.log(nums[i]); //<span class="number">1</span> <span class="number">23</span> <span class="number">4</span> <span class="number">5</span> <span class="number">6</span></span><br><span class="line">}</span></span><br><span class="line"></span><br><span class="line"><span class="keyword">for</span>(var <span class="built_in">i</span> = <span class="number">0</span>; <span class="built_in">i</span> < nums.<span class="built_in">length</span>; ++<span class="built_in">i</span>)<span class="cell">{</span><br><span class="line"> nums[i] = i;</span><br><span class="line">}</span></span><br></pre></td></tr></table></figure>
+<p>length属性反映的是当前数组中元素的个数,使用它,可以确保循环遍历了数组中的所有元素。</p>
+<h3 id="字符串生成数组">字符串生成数组</h3><figure class="highlight applescript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><span class="line">var sentence = <span class="string">"the quick brown fox jumped over the lazy dog"</span>;</span><br><span class="line">var <span class="property">words</span> = sentence.split(<span class="string">" "</span>);</span><br><span class="line"><span class="keyword">for</span> (var i = <span class="number">0</span>; i < <span class="property">words</span>.<span class="property">length</span>; ++i) </span><br><span class="line"> console.<span class="command">log</span>(<span class="string">"word "</span> + i + <span class="string">": "</span> + <span class="property">words</span>[i]);</span><br><span class="line">}</span><br></pre></td></tr></table></figure>
+<h3 id="数组的类方法">数组的类方法</h3><figure class="highlight cs"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><span class="line"><span class="keyword">bool</span> = Array.isArray(<span class="keyword">var</span>);<span class="comment">//检查变量是否为数组</span></span><br></pre></td></tr></table></figure>
+<h3 id="数组的属性">数组的属性</h3><p><strong>获取长度</strong><br><figure class="highlight delphi"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br></pre></td><td class="code"><pre><span class="line"><span class="keyword">var</span> nums = [<span class="number">1</span>,<span class="number">2</span>,<span class="number">3</span>,<span class="number">4</span>,<span class="number">5</span>];</span><br><span class="line">length = <span class="keyword">array</span>.length;<span class="comment">//length = 5</span></span><br></pre></td></tr></table></figure></p>
+<h3 id="数组的对象方法">数组的对象方法</h3><p><strong>查找元素</strong><br><figure class="highlight fortran"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br></pre></td><td class="code"><pre><span class="line">/*</span><br><span class="line"><span class="built_in">index</span>:</span><br><span class="line">查找到返回下标</span><br><span class="line">查找失败返回-<span class="number">1</span></span><br><span class="line">*/</span><br><span class="line"><span class="built_in">index</span> = array.indexOf(<span class="keyword">value</span>);//从前往后找元素<span class="keyword">value</span>,找到<span class="number">1</span>个就返回</span><br><span class="line"><span class="built_in">index</span> = array.lastIndexOf(<span class="keyword">value</span>);// 从后往前找元素<span class="keyword">value</span>,找到<span class="number">1</span>个就返回</span><br></pre></td></tr></table></figure></p>
+<p><strong>数组转字符串</strong><br><figure class="highlight lasso"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br></pre></td><td class="code"><pre><span class="line"><span class="built_in">string</span> <span class="subst">=</span> <span class="built_in">array</span><span class="built_in">.</span><span class="keyword">join</span>(); <span class="comment">//1,2,3,4,5</span></span><br><span class="line"><span class="built_in">string</span> <span class="subst">=</span> <span class="built_in">array</span><span class="built_in">.</span>toString(); <span class="comment">//1,2,3,4,5</span></span><br><span class="line"><span class="built_in">string</span> <span class="subst">=</span> <span class="built_in">array</span><span class="built_in">.</span><span class="keyword">join</span>(<span class="string">'-'</span>);<span class="comment">//1-2-3-4</span></span><br></pre></td></tr></table></figure></p>
+<p><strong>拼接数组</strong><br><figure class="highlight kotlin"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br></pre></td><td class="code"><pre><span class="line"><span class="variable"><span class="keyword">var</span> a</span> = [<span class="number">1</span>,<span class="number">2</span>,<span class="number">3</span>];</span><br><span class="line"><span class="variable"><span class="keyword">var</span> b</span> = [<span class="number">4</span>,<span class="number">5</span>,<span class="number">6</span>];</span><br><span class="line"></span><br><span class="line"><span class="variable"><span class="keyword">var</span> c</span> = a.concat(b);</span><br><span class="line"><span class="comment">//c = [ 1, 2, 3, 4, 5, 6 ]</span></span><br><span class="line"><span class="variable"><span class="keyword">var</span> c</span> = b.concat(a);</span><br><span class="line"><span class="comment">//c = [ 4, 5, 6, 1, 2, 3 ]</span></span><br></pre></td></tr></table></figure></p>
+<p><strong>添加元素</strong><br>push和unshift都返回数组的新长度.<br><figure class="highlight smali"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><span class="line">//push方法在数组的尾部添加元素</span><br><span class="line">//unshift方法在数组的头部添加元素</span><br><span class="line">var<span class="instruction"> array </span>= <span class="keyword">[</span>1,2,3];</span><br><span class="line">array.push(4<span class="function">)</span>;//<span class="keyword">[</span>1,2,3,4] rtn = length = 4</span><br><span class="line">array.unshift(0<span class="function">)</span>;//<span class="keyword">[</span>0,1,2,3,4] rtn = length = 5</span><br></pre></td></tr></table></figure></p>
+<p><strong>删除元素</strong><br>pop和shift都返回被删除元素组成的数组<br><figure class="highlight smali"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><span class="line">//pop方法在数组的尾部删除元素</span><br><span class="line">//shift方法在数组的头部删除元素</span><br><span class="line">var<span class="instruction"> array </span>= <span class="keyword">[</span>0,1,2,3,4];</span><br><span class="line">array.pop(<span class="function">)</span>;//<span class="keyword">[</span>0,1,2,3] rtn = 4</span><br><span class="line">array.shift(<span class="function">)</span>;//<span class="keyword">[</span>1,2,3] rtn= 0</span><br></pre></td></tr></table></figure></p>
+<p><strong>splice操作</strong><br>被删除元素数组 = splice(起始位置, 删除字符数, 插入的字符…)</p>
+<ul>
+<li>起始索引(也就是你希望开始添加元素的地方) ;</li>
+<li>需要删除的元素个数(添加元素时该参数设为 0) ;</li>
+<li>想要添加进数组的元素。</li>
+</ul>
+<p>先<strong>删除</strong>元素,再<strong>增加</strong>元素.<br><figure class="highlight inform7"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br></pre></td><td class="code"><pre><span class="line">var nums = <span class="comment">[1,2,3,4,5]</span>;</span><br><span class="line">nums.splice(2,0);//rtn = <span class="comment">[]</span> nums = <span class="comment">[ 1, 2, 3, 4, 5 ]</span></span><br><span class="line">nums.splice(2,1);//rtn =<span class="comment">[ 3 ]</span> nums = <span class="comment">[ 1, 2, 4, 5 ]</span></span><br><span class="line">nums.splice(2,2);//rtn = <span class="comment">[ 4, 5 ]</span> nums = <span class="comment">[ 1, 2 ]</span></span><br><span class="line">nums.splice(2,0,10,20,30);//rtn = <span class="comment">[]</span> nums = <span class="comment">[ 1, 2, 10, 20, 30 ]</span></span><br><span class="line">nums.splice(1,1,40);//rtn = <span class="comment">[ 2 ]</span> nums = <span class="comment">[ 1, 40, 10, 20, 30 ]</span></span><br></pre></td></tr></table></figure></p>
+<p><strong>数组排序</strong><br>reverse方法是将数组反转<br><figure class="highlight smali"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br></pre></td><td class="code"><pre><span class="line">var<span class="instruction"> array </span>= <span class="keyword">[</span>1,2,3,4,5];</span><br><span class="line">array.reverse(<span class="function">)</span>;//rtn =<span class="instruction"> array </span>= <span class="keyword">[</span> 5, 4, 3, 2, 1 ];</span><br></pre></td></tr></table></figure></p>
+<p>sort方法默认是按照字典顺序进行排序<br>适用于字符串排序,对于数字排序不适用.<br><em>数组本身被改变</em><br>Array = sort([function compare]);<br><figure class="highlight actionscript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br></pre></td><td class="code"><pre><span class="line"><span class="keyword">var</span> words = [<span class="string">'one'</span>,<span class="string">'two'</span>,<span class="string">'three'</span>,<span class="string">'four'</span>];</span><br><span class="line">words.sort();<span class="comment">//[ 'four', 'one', 'three', 'two' ]</span></span><br><span class="line"><span class="keyword">var</span> nums = [<span class="number">4</span>,<span class="number">5</span>,<span class="number">2</span>,<span class="number">20</span>,<span class="number">11</span>,<span class="number">1</span>,<span class="number">10</span>,<span class="number">11</span>,<span class="number">23</span>,<span class="number">42</span>];</span><br><span class="line">nums.sort();<span class="comment">//[ 1, 10, 11, 11, 2, 20, 23, 4, 42, 5 ]</span></span><br><span class="line">nums.sort(<span class="function"><span class="keyword">function</span><span class="params">(a,b)</span></span>{<span class="keyword">return</span> a-b; });<span class="comment">//[ 1, 2, 4, 5, 10, 11, 11, 20, 23, 42 ]</span></span><br><span class="line">nums.sort(<span class="function"><span class="keyword">function</span><span class="params">(a,b)</span></span>{<span class="keyword">return</span> b-a; });<span class="comment">//[ 42, 23, 20, 11, 11, 10, 5, 4, 2, 1 ]</span></span><br></pre></td></tr></table></figure></p>
+<h3 id="迭代器">迭代器</h3><p>forEach() 该方法接受一个函数作为参数,对数组中的每个元素使用该函数.<br><figure class="highlight openscad"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br></pre></td><td class="code"><pre><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">square</span><span class="params">(num)</span>{</span></span><br><span class="line"> console.<span class="built_in">log</span><span class="params">(num, num* num)</span>;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line">var nums = [<span class="number">1</span>,<span class="number">2</span>,<span class="number">3</span>,<span class="number">4</span>,<span class="number">5</span>];</span><br><span class="line">nums.forEach<span class="params">(square)</span>;</span><br></pre></td></tr></table></figure></p>
+<p>every(), 该方法接受一个返回值为布尔类型的函数, 对数组中的每个元素使用该函数。 如果对于所有的元素, 该函数均返回 true, 则该方法返回 true。<br><figure class="highlight javascript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><span class="line"><span class="keyword">var</span> nums = [<span class="number">2</span>,<span class="number">4</span>,<span class="number">6</span>,<span class="number">8</span>,<span class="number">10</span>];</span><br><span class="line"><span class="keyword">var</span> rtn = nums.every(<span class="function"><span class="keyword">function</span>(<span class="params">num</span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> num%<span class="number">2</span>==<span class="number">0</span>;</span><br><span class="line">});</span><br><span class="line"><span class="built_in">console</span>.log(rtn); <span class="comment">// true</span></span><br></pre></td></tr></table></figure></p>
+<p>some() 方法也接受一个返回值为布尔类型的函数, 只要有一个元素使得该函数返回 true,该方法就返回 true。<br><figure class="highlight javascript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><span class="line"><span class="keyword">var</span> nums = [<span class="number">2</span>,<span class="number">3</span>,<span class="number">5</span>,<span class="number">7</span>,<span class="number">9</span>];</span><br><span class="line"><span class="keyword">var</span> rtn = nums.some(<span class="function"><span class="keyword">function</span>(<span class="params">num</span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> num%<span class="number">2</span>==<span class="number">0</span>;</span><br><span class="line">});</span><br><span class="line"><span class="built_in">console</span>.log(rtn); <span class="comment">// true</span></span><br></pre></td></tr></table></figure></p>
+<p>reduce() 方法接受一个函数, 返回一个值。 该方法会从一个累加值开始, 不断对累加值和<br>数组中的后续元素调用该函数, 直到数组中的最后一个元素, 最后返回得到的累加值。<br>计算数组中元素的平方和.<br><figure class="highlight stata"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><span class="line"><span class="keyword">var</span> nums = [1,2,3,4];</span><br><span class="line"><span class="keyword">var</span> <span class="keyword">sum</span> = nums.reduce(function(<span class="keyword">sum</span>,num){</span><br><span class="line"> <span class="keyword">return</span> <span class="keyword">sum</span> + num*num;</span><br><span class="line">});</span><br><span class="line">console.<span class="literal">log</span>(<span class="keyword">sum</span>);<span class="comment">//30 1*1 + 2*2 + 3*3 + 4*4 =30</span></span><br></pre></td></tr></table></figure></p>
+<p>reduceRight() 方法, 和 reduce() 方法不同, 它是从右到左执行。<br><figure class="highlight javascript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br></pre></td><td class="code"><pre><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">concat</span>(<span class="params">accumulatedString, item</span>) </span>{</span><br><span class="line"> <span class="keyword">return</span> accumulatedString + item;</span><br><span class="line">}</span><br><span class="line"><span class="keyword">var</span> words = [<span class="string">" the "</span> , <span class="string">" quick "</span> , <span class="string">" brown "</span> , <span class="string">" fox "</span> ] ;</span><br><span class="line"><span class="keyword">var</span> sentence = words. reduceRight(concat);</span><br><span class="line"><span class="built_in">console</span>.log(sentence); <span class="comment">// 显示 " fox brown quick the"</span></span><br></pre></td></tr></table></figure></p>
+<p>map() 和 forEach() 有点儿像, 对数组中的每个元素使用某个函数。 两者的区别是 map() 返回一个新的数组, 该数组的元素是对原有元素应用某个函数得到的结果。<br><figure class="highlight javascript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br></pre></td><td class="code"><pre><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">square</span>(<span class="params">num</span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> num* num;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="keyword">var</span> nums = [<span class="number">1</span>,<span class="number">2</span>,<span class="number">3</span>,<span class="number">4</span>,<span class="number">5</span>];</span><br><span class="line"><span class="keyword">var</span> news = nums.map(square); <span class="comment">//rtn = [ 1, 4, 9, 16, 25 ]</span></span><br><span class="line"><span class="built_in">console</span>.log(nums);<span class="comment">//[ 1, 2, 3, 4, 5 ]</span></span><br><span class="line"><span class="built_in">console</span>.log(news);<span class="comment">//[ 1, 4, 9, 16, 25 ]</span></span><br></pre></td></tr></table></figure></p>
+<p>给定一个字符串生成首字母缩写形式<br><figure class="highlight javascript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><span class="line"><span class="keyword">var</span> str = <span class="string">'Asynchronous Javascript And XML'</span>;</span><br><span class="line"><span class="keyword">var</span> arr = str.split(<span class="string">" "</span>);</span><br><span class="line"><span class="keyword">var</span> newArr = arr.map(<span class="function"><span class="keyword">function</span>(<span class="params">word</span>)</span>{<span class="keyword">return</span> word.charAt(<span class="number">0</span>);});</span><br><span class="line"><span class="keyword">var</span> newStr = newArr.join(<span class="string">""</span>);</span><br><span class="line"><span class="built_in">console</span>.log(str + <span class="string">'->'</span> + newStr); <span class="comment">// Asynchronous Javascript And XML->AJAX</span></span><br></pre></td></tr></table></figure></p>
+<p>filter() 和 every() 类似, 传入一个返回值为布尔类型的函数。 和 every() 方法不同的是,当对数组中的所有元素应用该函数, 结果均为 true 时, 该方法并不返回 true, 而是返回一个新数组, 该数组包含应用该函数后结果为 true 的元素。<br>随机生成20个数字,取出大于60的数字.<br><figure class="highlight javascript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br></pre></td><td class="code"><pre><span class="line"><span class="keyword">var</span> nums = [];</span><br><span class="line"><span class="keyword">for</span>(<span class="keyword">var</span> i=<span class="number">0</span>;i<<span class="number">20</span>;i++){</span><br><span class="line"> nums[i] = <span class="built_in">Math</span>.floor(<span class="built_in">Math</span>.random()*<span class="number">101</span>);</span><br><span class="line">}</span><br><span class="line"><span class="keyword">var</span> bigNums = nums.filter(<span class="function"><span class="keyword">function</span>(<span class="params">num</span>)</span>{<span class="keyword">return</span> num >= <span class="number">60</span>;});</span><br><span class="line"><span class="built_in">console</span>.log(nums);<span class="comment">//[ 46, 56, 53, 65, 49, 3, 25, 26, 46, 25, 36, 73, 44, 43, 58, 97, 100, 65, 97, 47 ]</span></span><br><span class="line"><span class="built_in">console</span>.log(bigNums);<span class="comment">//[ 65, 73, 97, 100, 65, 97 ]</span></span><br></pre></td></tr></table></figure></p>
+<figure class="highlight coffeescript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br></pre></td><td class="code"><pre><span class="line"><span class="reserved">var</span> words = [<span class="string">"recieve"</span> , <span class="string">" deceive"</span> , <span class="string">"percieve"</span> , <span class="string">"deceit"</span> , <span class="string">"concieve"</span> ] ;</span><br><span class="line"><span class="reserved">var</span> filter = <span class="string">'cie'</span>;</span><br><span class="line"><span class="reserved">var</span> misspelled = words.filter(<span class="reserved">function</span>(word){</span><br><span class="line"> <span class="keyword">if</span>(word.indexOf(filter)>-<span class="number">1</span>){</span><br><span class="line"> <span class="keyword">return</span> <span class="literal">true</span>;</span><br><span class="line"> }<span class="keyword">else</span>{</span><br><span class="line"> <span class="keyword">return</span> <span class="literal">false</span>;</span><br><span class="line"> }</span><br><span class="line">});</span><br><span class="line"><span class="built_in">console</span>.log(misspelled );<span class="regexp">//</span>[ <span class="string">'recieve'</span>, <span class="string">'percieve'</span>, <span class="string">'concieve'</span> ]</span><br></pre></td></tr></table></figure>
+
+ </div>
+
+ <div class="post-footer">
+
+ <div class="post-tags">
+
+ <a href="/tags/JavaScript/"> #JavaScript </a>
+
+ </div>
+
+
+
+ <div class="post-nav">
+ <div class="post-nav-prev post-nav-item">
+
+ <a href="/2015/06/06/coredump-01/">使用gdb解析core dump-概念篇</a>
+
+ </div>
+
+ <div class="post-nav-next post-nav-item">
+
+ <a href="/2015/05/29/javascript-note-03/">JavaScript学习笔记-数组练习题</a>
+
+ </div>
+ </div>
+
+
+
+
+ </div>
+ </div>
+
+
+
+
+
+
+ <div class="comments" id="comments">
+
+ <div class="ds-thread" data-thread-key="2015/05/29/javascript-note-01/"
+ data-title="JavaScript学习笔记-数组" data-url="http://archerding.github.io/2015/05/29/javascript-note-01/">
+ </div>
+
+ </div>
+
+ </div>
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+ <ul class="sidebar-nav motion-element">
+ <li class="sidebar-nav-toc sidebar-nav-active" data-target="post-toc-wrap">
+ 文章目录
+ </li>
+ <li class="sidebar-nav-overview" data-target="site-overview">
+ 站点概览
+ </li>
+ </ul>
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+ <div class="post-toc-wrap sidebar-panel-active">
+ <div class="post-toc-indicator-top post-toc-indicator"></div>
+ <div class="post-toc">
+
+
+ <div class="post-toc-content"><ol class="nav"><li class="nav-item nav-level-3"><a class="nav-link" href="#什么是数组"><span class="nav-number">1.</span> <span class="nav-text">什么是数组</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#创建数组"><span class="nav-number">2.</span> <span class="nav-text">创建数组</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#遍历数组"><span class="nav-number">3.</span> <span class="nav-text">遍历数组</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#字符串生成数组"><span class="nav-number">4.</span> <span class="nav-text">字符串生成数组</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#数组的类方法"><span class="nav-number">5.</span> <span class="nav-text">数组的类方法</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#数组的属性"><span class="nav-number">6.</span> <span class="nav-text">数组的属性</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#数组的对象方法"><span class="nav-number">7.</span> <span class="nav-text">数组的对象方法</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#迭代器"><span class="nav-number">8.</span> <span class="nav-text">迭代器</span></a></li></ol></div>
+
+ </div>
+ <div class="post-toc-indicator-bottom post-toc-indicator"></div>
+ </div>
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+<script type="text/javascript" src="/js/bootstrap.scrollspy.js?v=0.4.3" id="bootstrap.scrollspy.custom"></script>
+
+
+<script type="text/javascript" id="sidebar.toc.highlight">
+ $(document).ready(function () {
+ var tocSelector = '.post-toc';
+ var $tocSelector = $(tocSelector);
+ var activeCurrentSelector = '.active-current';
+
+ $tocSelector
+ .on('activate.bs.scrollspy', function () {
+ var $currentActiveElement = $(tocSelector + ' .active').last();
+
+ removeCurrentActiveClass();
+ $currentActiveElement.addClass('active-current');
+
+ $tocSelector[0].scrollTop = $currentActiveElement.position().top;
+ })
+ .on('clear.bs.scrollspy', function () {
+ removeCurrentActiveClass();
+ });
+
+ function removeCurrentActiveClass () {
+ $(tocSelector + ' ' + activeCurrentSelector)
+ .removeClass(activeCurrentSelector.substring(1));
+ }
+
+ function processTOC () {
+ getTOCMaxHeight();
+ toggleTOCOverflowIndicators();
+ }
+
+ function getTOCMaxHeight () {
+ var $sidebarInner = $('.sidebar-inner');
+ var height = $('.sidebar').height() -
+ $tocSelector.position().top -
+ $('.post-toc-indicator-bottom').height();
+
+ $tocSelector.css('height', height);
+
+ return height;
+ }
+
+ function toggleTOCOverflowIndicators () {
+ tocOverflowIndicator(
+ '.post-toc-indicator-top',
+ $tocSelector.scrollTop() > 0 ? 'show' : 'hide'
+ );
+
+ tocOverflowIndicator(
+ '.post-toc-indicator-bottom',
+ $tocSelector.scrollTop() >= $tocSelector.find('ol').height() - $tocSelector.height() ? 'hide' : 'show'
+ )
+ }
+
+ $(document).on('sidebar.didShow', function () {
+ processTOC();
+ });
+
+ $('body').scrollspy({ target: tocSelector });
+ $(window).on('resize', function () {
+ if ( $('.sidebar').hasClass('sidebar-active') ) {
+ processTOC();
+ }
+ });
+
+ onScroll($tocSelector);
+
+ function onScroll (element) {
+ element.on('mousewheel DOMMouseScroll', function (event) {
+ var oe = event.originalEvent;
+ var delta = oe.wheelDelta || -oe.detail;
+ var self = this;
+
+ this.scrollTop += ( delta < 0 ? 1 : -1 ) * 30;
+ event.preventDefault();
+
+ toggleTOCOverflowIndicators();
+ });
+ }
+
+ function tocOverflowIndicator (indicator, action) {
+ $(indicator).velocity('stop').velocity({
+ opacity: action === 'show' ? 0.4 : 0
+ }, { duration: 100 });
+ }
+
+ });
+</script>
+
+
+ <script type="text/javascript" id="sidebar.nav">
+ $(document).ready(function () {
+ var html = $('html');
+
+ $('.sidebar-nav li').on('click', function () {
+ var item = $(this);
+ var activeTabClassName = 'sidebar-nav-active';
+ var activePanelClassName = 'sidebar-panel-active';
+ if (item.hasClass(activeTabClassName)) {
+ return;
+ }
+
+ var currentTarget = $('.' + activePanelClassName);
+ var target = $('.' + item.data('target'));
+
+ currentTarget.velocity('transition.slideUpOut', 200, function () {
+ target
+ .velocity('stop')
+ .velocity('transition.slideDownIn', 200)
+ .addClass(activePanelClassName);
+ });
+
+ item.siblings().removeClass(activeTabClassName);
+ item.addClass(activeTabClassName);
+ });
+
+ $('.post-toc a').on('click', function (e) {
+ e.preventDefault();
+ var offset = $(escapeSelector(this.getAttribute('href'))).offset().top;
+ html.velocity('stop').velocity('scroll', {
+ offset: offset + 'px',
+ mobileHA: false
+ });
+ });
+
+ // Expand sidebar on post detail page by default, when post has a toc.
+ var $tocContent = $('.post-toc-content');
+ if (isDesktop() && CONFIG.sidebar === 'post') {
+ if ($tocContent.length > 0 && $tocContent.html().trim().length > 0) {
+ displaySidebar();
+ }
+ }
+ });
+ </script>
+
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+
+
+ <script type="text/javascript">
+ var duoshuoQuery = {short_name:"archerding"};
+ (function() {
+ var ds = document.createElement('script');
+ ds.type = 'text/javascript';ds.async = true;
+ ds.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') + '//static.duoshuo.com/embed.js';
+ ds.charset = 'UTF-8';
+ (document.getElementsByTagName('head')[0]
+ || document.getElementsByTagName('body')[0]).appendChild(ds);
+ })();
+ </script>
+
+
+
+
+
+
+
+</body>
+</html>
diff --git a/2015/05/29/javascript-note-02/index.html b/2015/05/29/javascript-note-02/index.html
new file mode 100644
index 0000000..f271dd5
--- /dev/null
+++ b/2015/05/29/javascript-note-02/index.html
@@ -0,0 +1,607 @@
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="JavaScript," />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
+</script>
+
+
+
+
+ <title> JavaScript学习笔记-数组2 // ArcherDing's Notes </title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column page-post-detail">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
+<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
+
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
+
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
+
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-expand">
+
+
+ <div class="post post-type-normal ">
+ <div class="post-header">
+
+
+
+ <h1 class="post-title">
+
+
+
+ JavaScript学习笔记-数组2
+
+
+ </h1>
+
+
+ <div class="post-meta">
+ <span class="post-time">
+ 发表于 2015-05-29
+ </span>
+
+
+ <span class="post-category">
+ | 分类于
+
+ <a href="/categories/JavaScript/">JavaScript</a>
+
+
+
+
+
+ </span>
+
+
+
+
+ <span class="post-comments-count">
+ |
+ <a href="/2015/05/29/javascript-note-02/#comments" >
+ <span class="post-comments-count ds-thread-count" data-thread-key="2015/05/29/javascript-note-02/"></span>
+ </a>
+ </span>
+
+
+ </div>
+ </div>
+
+ <div class="post-body">
+
+
+
+
+
+ <h3 id="二维数组">二维数组</h3><p>JavaScript只支持一维数组,但是通过在数组里保存数组元素的方式,可以轻松创建多维<br>数组。</p>
+<h3 id="创建二维数组">创建二维数组</h3><figure class="highlight inform7"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br></pre></td><td class="code"><pre><span class="line">var twod = <span class="comment">[]</span>;</span><br><span class="line">var rows = 5;</span><br><span class="line">for (var i = 0; i < rows; ++i) {</span><br><span class="line"> twod<span class="comment">[i]</span> = <span class="comment">[]</span>;</span><br><span class="line">}</span><br><span class="line">console.log(twod);//<span class="comment">[ <span class="comment">[]</span>, <span class="comment">[]</span>, <span class="comment">[]</span>, <span class="comment">[]</span>, <span class="comment">[]</span> ]</span></span><br></pre></td></tr></table></figure>
+<p>为数组类添加方法matrix(行数,列数,初始值),用于创建二维数组并初始化.<br><figure class="highlight cal"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br></pre></td><td class="code"><pre><span class="line">Array.matrix = function(rows,cols,initial){</span><br><span class="line"> <span class="keyword">var</span> arr = [];</span><br><span class="line"> <span class="keyword">for</span>(<span class="keyword">var</span> i = <span class="number">0</span>; i < rows; i++){</span><br><span class="line"> <span class="keyword">var</span> col = [];</span><br><span class="line"> <span class="keyword">for</span>(<span class="keyword">var</span> j = <span class="number">0</span>; j < cols; j++){</span><br><span class="line"> col[j] = initial;</span><br><span class="line"> }</span><br><span class="line"> arr[i] = col;</span><br><span class="line"> }</span><br><span class="line"> return arr;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="keyword">var</span> nums = Array.matrix(<span class="number">5</span>,<span class="number">5</span>,<span class="number">0</span>);</span><br><span class="line">console.log(nums[<span class="number">1</span>][<span class="number">1</span>]); // <span class="number">0</span></span><br><span class="line"><span class="keyword">var</span> strs = Array.matrix(<span class="number">5</span>,<span class="number">5</span>,<span class="variable">""</span>);</span><br><span class="line">strs[<span class="number">1</span>][<span class="number">2</span>] = <span class="variable">"iDarker"</span>;</span><br><span class="line">console.log(strs);</span><br><span class="line"> /* [ [ <span class="string">''</span>, <span class="string">''</span>, <span class="string">''</span>, <span class="string">''</span>, <span class="string">''</span> ],</span><br><span class="line"> [ <span class="string">''</span>, <span class="string">''</span>, <span class="string">'iDarker'</span>, <span class="string">''</span>, <span class="string">''</span></span><br><span class="line"> [ <span class="string">''</span>, <span class="string">''</span>, <span class="string">''</span>, <span class="string">''</span>, <span class="string">''</span> ],</span><br><span class="line"> [ <span class="string">''</span>, <span class="string">''</span>, <span class="string">''</span>, <span class="string">''</span>, <span class="string">''</span> ],</span><br><span class="line"> [ <span class="string">''</span>, <span class="string">''</span>, <span class="string">''</span>, <span class="string">''</span>, <span class="string">''</span> ] ]</span><br><span class="line">*/</span><br></pre></td></tr></table></figure></p>
+<h3 id="对象数组">对象数组</h3><figure class="highlight javascript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br><span class="line">49</span><br><span class="line">50</span><br><span class="line">51</span><br><span class="line">52</span><br><span class="line">53</span><br><span class="line">54</span><br><span class="line">55</span><br><span class="line">56</span><br><span class="line">57</span><br><span class="line">58</span><br><span class="line">59</span><br></pre></td><td class="code"><pre><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">Point</span>(<span class="params">x,y</span>)</span>{</span><br><span class="line"> <span class="keyword">this</span>.x = x;</span><br><span class="line"> <span class="keyword">this</span>.y = y;</span><br><span class="line">}</span><br><span class="line"><span class="keyword">var</span> p1 = <span class="keyword">new</span> Point(<span class="number">1</span>,<span class="number">1</span>);</span><br><span class="line"><span class="keyword">var</span> p2 = <span class="keyword">new</span> Point(<span class="number">2</span>,<span class="number">2</span>);</span><br><span class="line"><span class="keyword">var</span> p3 = <span class="keyword">new</span> Point(<span class="number">3</span>,<span class="number">3</span>);</span><br><span class="line"><span class="keyword">var</span> p4 = <span class="keyword">new</span> Point(<span class="number">4</span>,<span class="number">4</span>);</span><br><span class="line"><span class="keyword">var</span> points = [p1,p2,p3,p4];</span><br><span class="line">points.forEach(<span class="function"><span class="keyword">function</span>(<span class="params">point</span>)</span>{</span><br><span class="line"> <span class="built_in">console</span>.log(<span class="string">'Point x:'</span> + point.x + <span class="string">' y:'</span> + point.y);</span><br><span class="line">});</span><br><span class="line"><span class="comment">/*</span><br><span class="line">Point x:1 y:1</span><br><span class="line">Point x:2 y:2</span><br><span class="line">Point x:3 y:3</span><br><span class="line">Point x:4 y:4</span><br><span class="line">*/</span></span><br><span class="line"><span class="keyword">var</span> p5 = <span class="keyword">new</span> Point(<span class="number">5</span>,<span class="number">5</span>);</span><br><span class="line">points.push(p5);</span><br><span class="line"><span class="built_in">console</span>.log(points);</span><br><span class="line"><span class="comment">/*</span><br><span class="line">[ { x: 1, y: 1 },</span><br><span class="line"> { x: 2, y: 2 },</span><br><span class="line"> { x: 3, y: 3 },</span><br><span class="line"> { x: 4, y: 4 },</span><br><span class="line"> { x: 5, y: 5 } ]</span><br><span class="line">*/</span></span><br><span class="line">points.pop();</span><br><span class="line"><span class="built_in">console</span>.log(points);</span><br><span class="line"><span class="comment">/*</span><br><span class="line">[ { x: 1, y: 1 },</span><br><span class="line"> { x: 2, y: 2 },</span><br><span class="line"> { x: 3, y: 3 },</span><br><span class="line"> { x: 4, y: 4 } ]</span><br><span class="line">*/</span></span><br><span class="line">points.unshift(p5);</span><br><span class="line"><span class="built_in">console</span>.log(points);</span><br><span class="line"><span class="comment">/*</span><br><span class="line">[ { x: 5, y: 5 },</span><br><span class="line"> { x: 1, y: 1 },</span><br><span class="line"> { x: 2, y: 2 },</span><br><span class="line"> { x: 3, y: 3 },</span><br><span class="line"> { x: 4, y: 4 } ]</span><br><span class="line">*/</span></span><br><span class="line">points.shift();</span><br><span class="line"><span class="built_in">console</span>.log(points);</span><br><span class="line"><span class="comment">/*</span><br><span class="line">[ { x: 1, y: 1 },</span><br><span class="line"> { x: 2, y: 2 },</span><br><span class="line"> { x: 3, y: 3 },</span><br><span class="line"> { x: 4, y: 4 } ]</span><br><span class="line">*/</span></span><br><span class="line"><span class="keyword">var</span> filter = <span class="keyword">new</span> Point(<span class="number">2</span>,<span class="number">2</span>);</span><br><span class="line"><span class="keyword">var</span> newPoints = points.filter(<span class="function"><span class="keyword">function</span>(<span class="params">point</span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> (point.x == filter.x) && (point.y == filter.y);</span><br><span class="line">});</span><br><span class="line"><span class="built_in">console</span>.log(newPoints );</span><br><span class="line"><span class="comment">/* [ { x: 2, y: 2 } ] */</span></span><br></pre></td></tr></table></figure>
+
+ </div>
+
+ <div class="post-footer">
+
+ <div class="post-tags">
+
+ <a href="/tags/JavaScript/"> #JavaScript </a>
+
+ </div>
+
+
+
+ <div class="post-nav">
+ <div class="post-nav-prev post-nav-item">
+
+ <a href="/2015/05/29/javascript-note-03/">JavaScript学习笔记-数组练习题</a>
+
+ </div>
+
+ <div class="post-nav-next post-nav-item">
+
+ <a href="/2015/05/29/javascript-note-04/">JavaScript学习笔记-列表</a>
+
+ </div>
+ </div>
+
+
+
+
+ </div>
+ </div>
+
+
+
+
+
+
+ <div class="comments" id="comments">
+
+ <div class="ds-thread" data-thread-key="2015/05/29/javascript-note-02/"
+ data-title="JavaScript学习笔记-数组2" data-url="http://archerding.github.io/2015/05/29/javascript-note-02/">
+ </div>
+
+ </div>
+
+ </div>
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+ <ul class="sidebar-nav motion-element">
+ <li class="sidebar-nav-toc sidebar-nav-active" data-target="post-toc-wrap">
+ 文章目录
+ </li>
+ <li class="sidebar-nav-overview" data-target="site-overview">
+ 站点概览
+ </li>
+ </ul>
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+ <div class="post-toc-wrap sidebar-panel-active">
+ <div class="post-toc-indicator-top post-toc-indicator"></div>
+ <div class="post-toc">
+
+
+ <div class="post-toc-content"><ol class="nav"><li class="nav-item nav-level-3"><a class="nav-link" href="#二维数组"><span class="nav-number">1.</span> <span class="nav-text">二维数组</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#创建二维数组"><span class="nav-number">2.</span> <span class="nav-text">创建二维数组</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#对象数组"><span class="nav-number">3.</span> <span class="nav-text">对象数组</span></a></li></ol></div>
+
+ </div>
+ <div class="post-toc-indicator-bottom post-toc-indicator"></div>
+ </div>
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+<script type="text/javascript" src="/js/bootstrap.scrollspy.js?v=0.4.3" id="bootstrap.scrollspy.custom"></script>
+
+
+<script type="text/javascript" id="sidebar.toc.highlight">
+ $(document).ready(function () {
+ var tocSelector = '.post-toc';
+ var $tocSelector = $(tocSelector);
+ var activeCurrentSelector = '.active-current';
+
+ $tocSelector
+ .on('activate.bs.scrollspy', function () {
+ var $currentActiveElement = $(tocSelector + ' .active').last();
+
+ removeCurrentActiveClass();
+ $currentActiveElement.addClass('active-current');
+
+ $tocSelector[0].scrollTop = $currentActiveElement.position().top;
+ })
+ .on('clear.bs.scrollspy', function () {
+ removeCurrentActiveClass();
+ });
+
+ function removeCurrentActiveClass () {
+ $(tocSelector + ' ' + activeCurrentSelector)
+ .removeClass(activeCurrentSelector.substring(1));
+ }
+
+ function processTOC () {
+ getTOCMaxHeight();
+ toggleTOCOverflowIndicators();
+ }
+
+ function getTOCMaxHeight () {
+ var $sidebarInner = $('.sidebar-inner');
+ var height = $('.sidebar').height() -
+ $tocSelector.position().top -
+ $('.post-toc-indicator-bottom').height();
+
+ $tocSelector.css('height', height);
+
+ return height;
+ }
+
+ function toggleTOCOverflowIndicators () {
+ tocOverflowIndicator(
+ '.post-toc-indicator-top',
+ $tocSelector.scrollTop() > 0 ? 'show' : 'hide'
+ );
+
+ tocOverflowIndicator(
+ '.post-toc-indicator-bottom',
+ $tocSelector.scrollTop() >= $tocSelector.find('ol').height() - $tocSelector.height() ? 'hide' : 'show'
+ )
+ }
+
+ $(document).on('sidebar.didShow', function () {
+ processTOC();
+ });
+
+ $('body').scrollspy({ target: tocSelector });
+ $(window).on('resize', function () {
+ if ( $('.sidebar').hasClass('sidebar-active') ) {
+ processTOC();
+ }
+ });
+
+ onScroll($tocSelector);
+
+ function onScroll (element) {
+ element.on('mousewheel DOMMouseScroll', function (event) {
+ var oe = event.originalEvent;
+ var delta = oe.wheelDelta || -oe.detail;
+ var self = this;
+
+ this.scrollTop += ( delta < 0 ? 1 : -1 ) * 30;
+ event.preventDefault();
+
+ toggleTOCOverflowIndicators();
+ });
+ }
+
+ function tocOverflowIndicator (indicator, action) {
+ $(indicator).velocity('stop').velocity({
+ opacity: action === 'show' ? 0.4 : 0
+ }, { duration: 100 });
+ }
+
+ });
+</script>
+
+
+ <script type="text/javascript" id="sidebar.nav">
+ $(document).ready(function () {
+ var html = $('html');
+
+ $('.sidebar-nav li').on('click', function () {
+ var item = $(this);
+ var activeTabClassName = 'sidebar-nav-active';
+ var activePanelClassName = 'sidebar-panel-active';
+ if (item.hasClass(activeTabClassName)) {
+ return;
+ }
+
+ var currentTarget = $('.' + activePanelClassName);
+ var target = $('.' + item.data('target'));
+
+ currentTarget.velocity('transition.slideUpOut', 200, function () {
+ target
+ .velocity('stop')
+ .velocity('transition.slideDownIn', 200)
+ .addClass(activePanelClassName);
+ });
+
+ item.siblings().removeClass(activeTabClassName);
+ item.addClass(activeTabClassName);
+ });
+
+ $('.post-toc a').on('click', function (e) {
+ e.preventDefault();
+ var offset = $(escapeSelector(this.getAttribute('href'))).offset().top;
+ html.velocity('stop').velocity('scroll', {
+ offset: offset + 'px',
+ mobileHA: false
+ });
+ });
+
+ // Expand sidebar on post detail page by default, when post has a toc.
+ var $tocContent = $('.post-toc-content');
+ if (isDesktop() && CONFIG.sidebar === 'post') {
+ if ($tocContent.length > 0 && $tocContent.html().trim().length > 0) {
+ displaySidebar();
+ }
+ }
+ });
+ </script>
+
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+
+
+ <script type="text/javascript">
+ var duoshuoQuery = {short_name:"archerding"};
+ (function() {
+ var ds = document.createElement('script');
+ ds.type = 'text/javascript';ds.async = true;
+ ds.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') + '//static.duoshuo.com/embed.js';
+ ds.charset = 'UTF-8';
+ (document.getElementsByTagName('head')[0]
+ || document.getElementsByTagName('body')[0]).appendChild(ds);
+ })();
+ </script>
+
+
+
+
+
+
+
+</body>
+</html>
diff --git a/2015/05/29/javascript-note-03/index.html b/2015/05/29/javascript-note-03/index.html
new file mode 100644
index 0000000..e3b98fb
--- /dev/null
+++ b/2015/05/29/javascript-note-03/index.html
@@ -0,0 +1,606 @@
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="JavaScript," />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
+</script>
+
+
+
+
+ <title> JavaScript学习笔记-数组练习题 // ArcherDing's Notes </title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column page-post-detail">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
+<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
+
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
+
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
+
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-expand">
+
+
+ <div class="post post-type-normal ">
+ <div class="post-header">
+
+
+
+ <h1 class="post-title">
+
+
+
+ JavaScript学习笔记-数组练习题
+
+
+ </h1>
+
+
+ <div class="post-meta">
+ <span class="post-time">
+ 发表于 2015-05-29
+ </span>
+
+
+ <span class="post-category">
+ | 分类于
+
+ <a href="/categories/JavaScript/">JavaScript</a>
+
+
+
+
+
+ </span>
+
+
+
+
+ <span class="post-comments-count">
+ |
+ <a href="/2015/05/29/javascript-note-03/#comments" >
+ <span class="post-comments-count ds-thread-count" data-thread-key="2015/05/29/javascript-note-03/"></span>
+ </a>
+ </span>
+
+
+ </div>
+ </div>
+
+ <div class="post-body">
+
+
+
+
+
+ <h4 id="1-_创建一个记录学生成绩的对象,提供一个添加成绩的方法,以及一个显示学生平均成绩的方法。">1. 创建一个记录学生成绩的对象,提供一个添加成绩的方法,以及一个显示学生平均成绩的方法。</h4><figure class="highlight javascript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br><span class="line">49</span><br></pre></td><td class="code"><pre><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">Grade</span>(<span class="params">chinese,english,math</span>)</span>{</span><br><span class="line"> <span class="keyword">this</span>.dataStore = [chinese,english,math]</span><br><span class="line"> <span class="keyword">this</span>.average = <span class="function"><span class="keyword">function</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">var</span> total = <span class="keyword">this</span>.dataStore.reduce(<span class="function"><span class="keyword">function</span>(<span class="params">currenTotal,currenNum</span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> currenTotal + currenNum;</span><br><span class="line"> });</span><br><span class="line"> <span class="keyword">return</span> total/<span class="keyword">this</span>.dataStore.length;</span><br><span class="line"> }</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">Grades</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">this</span>.dataStore = [];</span><br><span class="line"> <span class="keyword">this</span>.add = <span class="function"><span class="keyword">function</span>(<span class="params">grade</span>)</span>{</span><br><span class="line"> <span class="keyword">this</span>.dataStore.push(grade);</span><br><span class="line"> };</span><br><span class="line"> <span class="keyword">this</span>.average = <span class="function"><span class="keyword">function</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">var</span> averages = <span class="keyword">this</span>.dataStore.map(<span class="function"><span class="keyword">function</span>(<span class="params">grade</span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> grade.average();</span><br><span class="line"> });</span><br><span class="line"> <span class="built_in">console</span>.log(averages);</span><br><span class="line"> <span class="keyword">var</span> total = averages.reduce(<span class="function"><span class="keyword">function</span>(<span class="params">currenTotal,currenNum</span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> currenTotal + currenNum;</span><br><span class="line"> });</span><br><span class="line"> <span class="keyword">return</span> total/<span class="keyword">this</span>.dataStore.length;</span><br><span class="line"> };</span><br><span class="line"> </span><br><span class="line"> <span class="keyword">this</span>.englishAverage = <span class="function"><span class="keyword">function</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">var</span> englishs = <span class="keyword">this</span>.dataStore.map(<span class="function"><span class="keyword">function</span>(<span class="params">grade</span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> grade.dataStore[<span class="number">0</span>];</span><br><span class="line"> });</span><br><span class="line"> <span class="built_in">console</span>.log(englishs);</span><br><span class="line"> <span class="keyword">var</span> total = englishs.reduce(<span class="function"><span class="keyword">function</span>(<span class="params">currenTotal,currenNum</span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> currenTotal + currenNum;</span><br><span class="line"> });</span><br><span class="line"> <span class="keyword">return</span> total/<span class="keyword">this</span>.dataStore.length;</span><br><span class="line"> };</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="keyword">var</span> g1 = <span class="keyword">new</span> Grade(<span class="number">90</span>,<span class="number">98</span>,<span class="number">95</span>);</span><br><span class="line"><span class="keyword">var</span> g2 = <span class="keyword">new</span> Grade(<span class="number">83</span>,<span class="number">79</span>,<span class="number">82</span>);</span><br><span class="line"><span class="keyword">var</span> g3 = <span class="keyword">new</span> Grade(<span class="number">46</span>,<span class="number">53</span>,<span class="number">22</span>);</span><br><span class="line"></span><br><span class="line"><span class="keyword">var</span> grades = <span class="keyword">new</span> Grades();</span><br><span class="line">grades.add(g1);</span><br><span class="line">grades.add(g2);</span><br><span class="line">grades.add(g3);</span><br><span class="line"></span><br><span class="line"><span class="built_in">console</span>.log(grades.average());</span><br><span class="line"><span class="built_in">console</span>.log(grades.englishAverage());</span><br></pre></td></tr></table></figure>
+<h4 id="2-_将一组单词存储在一个数组中,并按正序和倒序分别显示这些单词。">2. 将一组单词存储在一个数组中,并按正序和倒序分别显示这些单词。</h4><figure class="highlight applescript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><span class="line">var <span class="property">words</span> = ['one','two','three','four'];</span><br><span class="line"><span class="property">words</span>.sort();</span><br><span class="line">console.<span class="command">log</span>(<span class="property">words</span>);</span><br><span class="line"><span class="property">words</span>.<span class="property">reverse</span>();</span><br><span class="line">console.<span class="command">log</span>(<span class="property">words</span>);</span><br></pre></td></tr></table></figure>
+<h4 id="3-_创建这样一个对象,它将字母存储在一个数组中,并且用一个方法可以将字母连在一起,显示成一个单词。">3. 创建这样一个对象,它将字母存储在一个数组中,并且用一个方法可以将字母连在一起,显示成一个单词。</h4><figure class="highlight javascript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br></pre></td><td class="code"><pre><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">Word</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">this</span>.dataStore = [];</span><br><span class="line"> <span class="keyword">this</span>.add = <span class="function"><span class="keyword">function</span>(<span class="params">char</span>)</span>{</span><br><span class="line"> <span class="keyword">this</span>.dataStore.push(char);</span><br><span class="line"> };</span><br><span class="line"> <span class="keyword">this</span>.toString = <span class="function"><span class="keyword">function</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> <span class="keyword">this</span>.dataStore.join(<span class="string">""</span>);</span><br><span class="line"> }</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="keyword">var</span> word = <span class="keyword">new</span> Word();</span><br><span class="line">word.add(<span class="string">'g'</span>);</span><br><span class="line">word.add(<span class="string">'o'</span>);</span><br><span class="line">word.add(<span class="string">'o'</span>);</span><br><span class="line">word.add(<span class="string">'d'</span>);</span><br><span class="line"><span class="built_in">console</span>.log(word.toString());</span><br></pre></td></tr></table></figure>
+
+ </div>
+
+ <div class="post-footer">
+
+ <div class="post-tags">
+
+ <a href="/tags/JavaScript/"> #JavaScript </a>
+
+ </div>
+
+
+
+ <div class="post-nav">
+ <div class="post-nav-prev post-nav-item">
+
+ <a href="/2015/05/29/javascript-note-01/">JavaScript学习笔记-数组</a>
+
+ </div>
+
+ <div class="post-nav-next post-nav-item">
+
+ <a href="/2015/05/29/javascript-note-02/">JavaScript学习笔记-数组2</a>
+
+ </div>
+ </div>
+
+
+
+
+ </div>
+ </div>
+
+
+
+
+
+
+ <div class="comments" id="comments">
+
+ <div class="ds-thread" data-thread-key="2015/05/29/javascript-note-03/"
+ data-title="JavaScript学习笔记-数组练习题" data-url="http://archerding.github.io/2015/05/29/javascript-note-03/">
+ </div>
+
+ </div>
+
+ </div>
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+ <ul class="sidebar-nav motion-element">
+ <li class="sidebar-nav-toc sidebar-nav-active" data-target="post-toc-wrap">
+ 文章目录
+ </li>
+ <li class="sidebar-nav-overview" data-target="site-overview">
+ 站点概览
+ </li>
+ </ul>
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+ <div class="post-toc-wrap sidebar-panel-active">
+ <div class="post-toc-indicator-top post-toc-indicator"></div>
+ <div class="post-toc">
+
+
+ <div class="post-toc-content"><ol class="nav"><li class="nav-item nav-level-4"><a class="nav-link" href="#1-_创建一个记录学生成绩的对象,提供一个添加成绩的方法,以及一个显示学生平均成绩的方法。"><span class="nav-number">1.</span> <span class="nav-text">1. 创建一个记录学生成绩的对象,提供一个添加成绩的方法,以及一个显示学生平均成绩的方法。</span></a></li><li class="nav-item nav-level-4"><a class="nav-link" href="#2-_将一组单词存储在一个数组中,并按正序和倒序分别显示这些单词。"><span class="nav-number">2.</span> <span class="nav-text">2. 将一组单词存储在一个数组中,并按正序和倒序分别显示这些单词。</span></a></li><li class="nav-item nav-level-4"><a class="nav-link" href="#3-_创建这样一个对象,它将字母存储在一个数组中,并且用一个方法可以将字母连在一起,显示成一个单词。"><span class="nav-number">3.</span> <span class="nav-text">3. 创建这样一个对象,它将字母存储在一个数组中,并且用一个方法可以将字母连在一起,显示成一个单词。</span></a></li></ol></div>
+
+ </div>
+ <div class="post-toc-indicator-bottom post-toc-indicator"></div>
+ </div>
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+<script type="text/javascript" src="/js/bootstrap.scrollspy.js?v=0.4.3" id="bootstrap.scrollspy.custom"></script>
+
+
+<script type="text/javascript" id="sidebar.toc.highlight">
+ $(document).ready(function () {
+ var tocSelector = '.post-toc';
+ var $tocSelector = $(tocSelector);
+ var activeCurrentSelector = '.active-current';
+
+ $tocSelector
+ .on('activate.bs.scrollspy', function () {
+ var $currentActiveElement = $(tocSelector + ' .active').last();
+
+ removeCurrentActiveClass();
+ $currentActiveElement.addClass('active-current');
+
+ $tocSelector[0].scrollTop = $currentActiveElement.position().top;
+ })
+ .on('clear.bs.scrollspy', function () {
+ removeCurrentActiveClass();
+ });
+
+ function removeCurrentActiveClass () {
+ $(tocSelector + ' ' + activeCurrentSelector)
+ .removeClass(activeCurrentSelector.substring(1));
+ }
+
+ function processTOC () {
+ getTOCMaxHeight();
+ toggleTOCOverflowIndicators();
+ }
+
+ function getTOCMaxHeight () {
+ var $sidebarInner = $('.sidebar-inner');
+ var height = $('.sidebar').height() -
+ $tocSelector.position().top -
+ $('.post-toc-indicator-bottom').height();
+
+ $tocSelector.css('height', height);
+
+ return height;
+ }
+
+ function toggleTOCOverflowIndicators () {
+ tocOverflowIndicator(
+ '.post-toc-indicator-top',
+ $tocSelector.scrollTop() > 0 ? 'show' : 'hide'
+ );
+
+ tocOverflowIndicator(
+ '.post-toc-indicator-bottom',
+ $tocSelector.scrollTop() >= $tocSelector.find('ol').height() - $tocSelector.height() ? 'hide' : 'show'
+ )
+ }
+
+ $(document).on('sidebar.didShow', function () {
+ processTOC();
+ });
+
+ $('body').scrollspy({ target: tocSelector });
+ $(window).on('resize', function () {
+ if ( $('.sidebar').hasClass('sidebar-active') ) {
+ processTOC();
+ }
+ });
+
+ onScroll($tocSelector);
+
+ function onScroll (element) {
+ element.on('mousewheel DOMMouseScroll', function (event) {
+ var oe = event.originalEvent;
+ var delta = oe.wheelDelta || -oe.detail;
+ var self = this;
+
+ this.scrollTop += ( delta < 0 ? 1 : -1 ) * 30;
+ event.preventDefault();
+
+ toggleTOCOverflowIndicators();
+ });
+ }
+
+ function tocOverflowIndicator (indicator, action) {
+ $(indicator).velocity('stop').velocity({
+ opacity: action === 'show' ? 0.4 : 0
+ }, { duration: 100 });
+ }
+
+ });
+</script>
+
+
+ <script type="text/javascript" id="sidebar.nav">
+ $(document).ready(function () {
+ var html = $('html');
+
+ $('.sidebar-nav li').on('click', function () {
+ var item = $(this);
+ var activeTabClassName = 'sidebar-nav-active';
+ var activePanelClassName = 'sidebar-panel-active';
+ if (item.hasClass(activeTabClassName)) {
+ return;
+ }
+
+ var currentTarget = $('.' + activePanelClassName);
+ var target = $('.' + item.data('target'));
+
+ currentTarget.velocity('transition.slideUpOut', 200, function () {
+ target
+ .velocity('stop')
+ .velocity('transition.slideDownIn', 200)
+ .addClass(activePanelClassName);
+ });
+
+ item.siblings().removeClass(activeTabClassName);
+ item.addClass(activeTabClassName);
+ });
+
+ $('.post-toc a').on('click', function (e) {
+ e.preventDefault();
+ var offset = $(escapeSelector(this.getAttribute('href'))).offset().top;
+ html.velocity('stop').velocity('scroll', {
+ offset: offset + 'px',
+ mobileHA: false
+ });
+ });
+
+ // Expand sidebar on post detail page by default, when post has a toc.
+ var $tocContent = $('.post-toc-content');
+ if (isDesktop() && CONFIG.sidebar === 'post') {
+ if ($tocContent.length > 0 && $tocContent.html().trim().length > 0) {
+ displaySidebar();
+ }
+ }
+ });
+ </script>
+
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+
+
+ <script type="text/javascript">
+ var duoshuoQuery = {short_name:"archerding"};
+ (function() {
+ var ds = document.createElement('script');
+ ds.type = 'text/javascript';ds.async = true;
+ ds.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') + '//static.duoshuo.com/embed.js';
+ ds.charset = 'UTF-8';
+ (document.getElementsByTagName('head')[0]
+ || document.getElementsByTagName('body')[0]).appendChild(ds);
+ })();
+ </script>
+
+
+
+
+
+
+
+</body>
+</html>
diff --git a/2015/05/29/javascript-note-04/index.html b/2015/05/29/javascript-note-04/index.html
new file mode 100644
index 0000000..70cc9d9
--- /dev/null
+++ b/2015/05/29/javascript-note-04/index.html
@@ -0,0 +1,604 @@
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="JavaScript," />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
+</script>
+
+
+
+
+ <title> JavaScript学习笔记-列表 // ArcherDing's Notes </title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column page-post-detail">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
+<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
+
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
+
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
+
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-expand">
+
+
+ <div class="post post-type-normal ">
+ <div class="post-header">
+
+
+
+ <h1 class="post-title">
+
+
+
+ JavaScript学习笔记-列表
+
+
+ </h1>
+
+
+ <div class="post-meta">
+ <span class="post-time">
+ 发表于 2015-05-29
+ </span>
+
+
+ <span class="post-category">
+ | 分类于
+
+ <a href="/categories/JavaScript/">JavaScript</a>
+
+
+
+
+
+ </span>
+
+
+
+
+ <span class="post-comments-count">
+ |
+ <a href="/2015/05/29/javascript-note-04/#comments" >
+ <span class="post-comments-count ds-thread-count" data-thread-key="2015/05/29/javascript-note-04/"></span>
+ </a>
+ </span>
+
+
+ </div>
+ </div>
+
+ <div class="post-body">
+
+
+
+
+
+ <h4 id="JavaScript学习笔记-列表">JavaScript学习笔记-列表</h4><figure class="highlight javascript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br><span class="line">49</span><br><span class="line">50</span><br><span class="line">51</span><br><span class="line">52</span><br><span class="line">53</span><br><span class="line">54</span><br><span class="line">55</span><br><span class="line">56</span><br><span class="line">57</span><br><span class="line">58</span><br><span class="line">59</span><br><span class="line">60</span><br><span class="line">61</span><br><span class="line">62</span><br><span class="line">63</span><br><span class="line">64</span><br><span class="line">65</span><br><span class="line">66</span><br><span class="line">67</span><br><span class="line">68</span><br><span class="line">69</span><br><span class="line">70</span><br><span class="line">71</span><br><span class="line">72</span><br><span class="line">73</span><br><span class="line">74</span><br><span class="line">75</span><br><span class="line">76</span><br><span class="line">77</span><br><span class="line">78</span><br><span class="line">79</span><br><span class="line">80</span><br><span class="line">81</span><br><span class="line">82</span><br><span class="line">83</span><br><span class="line">84</span><br><span class="line">85</span><br><span class="line">86</span><br><span class="line">87</span><br><span class="line">88</span><br><span class="line">89</span><br><span class="line">90</span><br><span class="line">91</span><br><span class="line">92</span><br><span class="line">93</span><br><span class="line">94</span><br><span class="line">95</span><br><span class="line">96</span><br><span class="line">97</span><br><span class="line">98</span><br><span class="line">99</span><br><span class="line">100</span><br><span class="line">101</span><br><span class="line">102</span><br><span class="line">103</span><br><span class="line">104</span><br><span class="line">105</span><br><span class="line">106</span><br><span class="line">107</span><br><span class="line">108</span><br><span class="line">109</span><br><span class="line">110</span><br><span class="line">111</span><br><span class="line">112</span><br><span class="line">113</span><br></pre></td><td class="code"><pre><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">List</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">this</span>.listSize = <span class="number">0</span>;</span><br><span class="line"> <span class="keyword">this</span>.pos = <span class="number">0</span>;</span><br><span class="line"> <span class="keyword">this</span>.dataStore = [];</span><br><span class="line"> <span class="keyword">this</span>.clear = clear;</span><br><span class="line"> <span class="keyword">this</span>.find = find;</span><br><span class="line"> <span class="keyword">this</span>.toString = toString;</span><br><span class="line"> <span class="keyword">this</span>.insert = insert;</span><br><span class="line"> <span class="keyword">this</span>.append = append;</span><br><span class="line"> <span class="keyword">this</span>.remove = remove;</span><br><span class="line"> <span class="keyword">this</span>.front = front;</span><br><span class="line"> <span class="keyword">this</span>.end = end;</span><br><span class="line"> <span class="keyword">this</span>.prev = prev;</span><br><span class="line"> <span class="keyword">this</span>.next = next;</span><br><span class="line"> <span class="keyword">this</span>.length = length;</span><br><span class="line"> <span class="keyword">this</span>.currPos = currPos;</span><br><span class="line"> <span class="keyword">this</span>.moveTo = moveTo;</span><br><span class="line"> <span class="keyword">this</span>.getElement = getElement;</span><br><span class="line"> <span class="keyword">this</span>.contains = contains;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">clear</span>(<span class="params">element</span>)</span>{</span><br><span class="line"> <span class="keyword">delete</span> <span class="keyword">this</span>.dataStore;</span><br><span class="line"> <span class="keyword">this</span>.dataStore = [];</span><br><span class="line"> <span class="keyword">this</span>.listSize = <span class="keyword">this</span>.pos = <span class="number">0</span>;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">insert</span>(<span class="params">element,after</span>)</span>{</span><br><span class="line"> <span class="keyword">var</span> index = <span class="keyword">this</span>.find(element);</span><br><span class="line"> <span class="keyword">if</span>(index > -<span class="number">1</span>){</span><br><span class="line"> <span class="keyword">this</span>.dataStore.splice(index + <span class="number">1</span>, <span class="number">0</span>, element);</span><br><span class="line"> ++<span class="keyword">this</span>.listSize;</span><br><span class="line"> <span class="keyword">return</span> <span class="literal">true</span>;</span><br><span class="line"> }</span><br><span class="line"> <span class="keyword">return</span> <span class="literal">false</span>;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">front</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">this</span>.pos = <span class="number">0</span>;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">end</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">this</span>.pos = <span class="keyword">this</span>.listSize - <span class="number">1</span>;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">prev</span>(<span class="params"></span>)</span>{</span><br><span class="line"> --<span class="keyword">this</span>.pos;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">next</span>(<span class="params">element</span>)</span>{</span><br><span class="line"> ++<span class="keyword">this</span>.pos;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">currPos</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> <span class="keyword">this</span>.pos;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">moveTo</span>(<span class="params">position</span>)</span>{</span><br><span class="line"> <span class="keyword">this</span>.pos = position;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">getElement</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> <span class="keyword">this</span>.dataStore[<span class="keyword">this</span>.pos];</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">contains</span>(<span class="params">element</span>)</span>{</span><br><span class="line"> <span class="keyword">if</span>(<span class="keyword">this</span>.find(element) > -<span class="number">1</span>)</span><br><span class="line"> {</span><br><span class="line"> <span class="keyword">return</span> <span class="literal">true</span>;</span><br><span class="line"> }</span><br><span class="line"> <span class="keyword">return</span> <span class="literal">false</span>;</span><br><span class="line">}</span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">find</span>(<span class="params">element</span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> <span class="keyword">this</span>.dataStore.indexOf(element);</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">append</span>(<span class="params">element</span>)</span>{</span><br><span class="line"> <span class="keyword">this</span>.dataStore[<span class="keyword">this</span>.listSize++] = element;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">remove</span>(<span class="params">element</span>)</span>{</span><br><span class="line"> <span class="keyword">var</span> index = <span class="keyword">this</span>.find(element);</span><br><span class="line"> <span class="keyword">if</span>(index > -<span class="number">1</span>){</span><br><span class="line"> <span class="keyword">this</span>.dataStore.splice(index,<span class="number">1</span>);</span><br><span class="line"> --<span class="keyword">this</span>.listSize;</span><br><span class="line"> <span class="keyword">return</span> <span class="literal">true</span>;</span><br><span class="line"> }</span><br><span class="line"> <span class="keyword">return</span> <span class="literal">false</span>;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">length</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> <span class="keyword">this</span>.listSize;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">toString</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">return</span> <span class="keyword">this</span>.dataStore;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="keyword">var</span> names = <span class="keyword">new</span> List();</span><br><span class="line">names.append(<span class="string">"Clayton"</span>);</span><br><span class="line">names.append(<span class="string">"Raymond"</span>);</span><br><span class="line">names.append(<span class="string">"Cynthia"</span>);</span><br><span class="line">names.append(<span class="string">"Jennifer"</span>);</span><br><span class="line">names.append(<span class="string">"Bryan"</span>);</span><br><span class="line">names.append(<span class="string">"Danny"</span>);</span><br><span class="line"></span><br><span class="line"><span class="keyword">for</span>(names.front(); names.currPos() < names.length(); names.next()) {</span><br><span class="line"> <span class="built_in">console</span>.log(names.getElement());</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="keyword">for</span>(names.end(); names.currPos() >= <span class="number">0</span>; names.prev()) {</span><br><span class="line"> <span class="built_in">console</span>.log(names.getElement());</span><br><span class="line">}</span><br></pre></td></tr></table></figure>
+
+ </div>
+
+ <div class="post-footer">
+
+ <div class="post-tags">
+
+ <a href="/tags/JavaScript/"> #JavaScript </a>
+
+ </div>
+
+
+
+ <div class="post-nav">
+ <div class="post-nav-prev post-nav-item">
+
+ <a href="/2015/05/29/javascript-note-02/">JavaScript学习笔记-数组2</a>
+
+ </div>
+
+ <div class="post-nav-next post-nav-item">
+
+ <a href="/2015/05/29/javascript-note-05/">JavaScript学习笔记-栈</a>
+
+ </div>
+ </div>
+
+
+
+
+ </div>
+ </div>
+
+
+
+
+
+
+ <div class="comments" id="comments">
+
+ <div class="ds-thread" data-thread-key="2015/05/29/javascript-note-04/"
+ data-title="JavaScript学习笔记-列表" data-url="http://archerding.github.io/2015/05/29/javascript-note-04/">
+ </div>
+
+ </div>
+
+ </div>
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+ <ul class="sidebar-nav motion-element">
+ <li class="sidebar-nav-toc sidebar-nav-active" data-target="post-toc-wrap">
+ 文章目录
+ </li>
+ <li class="sidebar-nav-overview" data-target="site-overview">
+ 站点概览
+ </li>
+ </ul>
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+ <div class="post-toc-wrap sidebar-panel-active">
+ <div class="post-toc-indicator-top post-toc-indicator"></div>
+ <div class="post-toc">
+
+
+ <div class="post-toc-content"><ol class="nav"><li class="nav-item nav-level-4"><a class="nav-link" href="#JavaScript学习笔记-列表"><span class="nav-number">1.</span> <span class="nav-text">JavaScript学习笔记-列表</span></a></li></ol></div>
+
+ </div>
+ <div class="post-toc-indicator-bottom post-toc-indicator"></div>
+ </div>
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+<script type="text/javascript" src="/js/bootstrap.scrollspy.js?v=0.4.3" id="bootstrap.scrollspy.custom"></script>
+
+
+<script type="text/javascript" id="sidebar.toc.highlight">
+ $(document).ready(function () {
+ var tocSelector = '.post-toc';
+ var $tocSelector = $(tocSelector);
+ var activeCurrentSelector = '.active-current';
+
+ $tocSelector
+ .on('activate.bs.scrollspy', function () {
+ var $currentActiveElement = $(tocSelector + ' .active').last();
+
+ removeCurrentActiveClass();
+ $currentActiveElement.addClass('active-current');
+
+ $tocSelector[0].scrollTop = $currentActiveElement.position().top;
+ })
+ .on('clear.bs.scrollspy', function () {
+ removeCurrentActiveClass();
+ });
+
+ function removeCurrentActiveClass () {
+ $(tocSelector + ' ' + activeCurrentSelector)
+ .removeClass(activeCurrentSelector.substring(1));
+ }
+
+ function processTOC () {
+ getTOCMaxHeight();
+ toggleTOCOverflowIndicators();
+ }
+
+ function getTOCMaxHeight () {
+ var $sidebarInner = $('.sidebar-inner');
+ var height = $('.sidebar').height() -
+ $tocSelector.position().top -
+ $('.post-toc-indicator-bottom').height();
+
+ $tocSelector.css('height', height);
+
+ return height;
+ }
+
+ function toggleTOCOverflowIndicators () {
+ tocOverflowIndicator(
+ '.post-toc-indicator-top',
+ $tocSelector.scrollTop() > 0 ? 'show' : 'hide'
+ );
+
+ tocOverflowIndicator(
+ '.post-toc-indicator-bottom',
+ $tocSelector.scrollTop() >= $tocSelector.find('ol').height() - $tocSelector.height() ? 'hide' : 'show'
+ )
+ }
+
+ $(document).on('sidebar.didShow', function () {
+ processTOC();
+ });
+
+ $('body').scrollspy({ target: tocSelector });
+ $(window).on('resize', function () {
+ if ( $('.sidebar').hasClass('sidebar-active') ) {
+ processTOC();
+ }
+ });
+
+ onScroll($tocSelector);
+
+ function onScroll (element) {
+ element.on('mousewheel DOMMouseScroll', function (event) {
+ var oe = event.originalEvent;
+ var delta = oe.wheelDelta || -oe.detail;
+ var self = this;
+
+ this.scrollTop += ( delta < 0 ? 1 : -1 ) * 30;
+ event.preventDefault();
+
+ toggleTOCOverflowIndicators();
+ });
+ }
+
+ function tocOverflowIndicator (indicator, action) {
+ $(indicator).velocity('stop').velocity({
+ opacity: action === 'show' ? 0.4 : 0
+ }, { duration: 100 });
+ }
+
+ });
+</script>
+
+
+ <script type="text/javascript" id="sidebar.nav">
+ $(document).ready(function () {
+ var html = $('html');
+
+ $('.sidebar-nav li').on('click', function () {
+ var item = $(this);
+ var activeTabClassName = 'sidebar-nav-active';
+ var activePanelClassName = 'sidebar-panel-active';
+ if (item.hasClass(activeTabClassName)) {
+ return;
+ }
+
+ var currentTarget = $('.' + activePanelClassName);
+ var target = $('.' + item.data('target'));
+
+ currentTarget.velocity('transition.slideUpOut', 200, function () {
+ target
+ .velocity('stop')
+ .velocity('transition.slideDownIn', 200)
+ .addClass(activePanelClassName);
+ });
+
+ item.siblings().removeClass(activeTabClassName);
+ item.addClass(activeTabClassName);
+ });
+
+ $('.post-toc a').on('click', function (e) {
+ e.preventDefault();
+ var offset = $(escapeSelector(this.getAttribute('href'))).offset().top;
+ html.velocity('stop').velocity('scroll', {
+ offset: offset + 'px',
+ mobileHA: false
+ });
+ });
+
+ // Expand sidebar on post detail page by default, when post has a toc.
+ var $tocContent = $('.post-toc-content');
+ if (isDesktop() && CONFIG.sidebar === 'post') {
+ if ($tocContent.length > 0 && $tocContent.html().trim().length > 0) {
+ displaySidebar();
+ }
+ }
+ });
+ </script>
+
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+
+
+ <script type="text/javascript">
+ var duoshuoQuery = {short_name:"archerding"};
+ (function() {
+ var ds = document.createElement('script');
+ ds.type = 'text/javascript';ds.async = true;
+ ds.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') + '//static.duoshuo.com/embed.js';
+ ds.charset = 'UTF-8';
+ (document.getElementsByTagName('head')[0]
+ || document.getElementsByTagName('body')[0]).appendChild(ds);
+ })();
+ </script>
+
+
+
+
+
+
+
+</body>
+</html>
diff --git a/2015/05/29/javascript-note-05/index.html b/2015/05/29/javascript-note-05/index.html
new file mode 100644
index 0000000..a844b2b
--- /dev/null
+++ b/2015/05/29/javascript-note-05/index.html
@@ -0,0 +1,636 @@
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="JavaScript," />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
+</script>
+
+
+
+
+ <title> JavaScript学习笔记-栈 // ArcherDing's Notes </title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column page-post-detail">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
+<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
+
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
+
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
+
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-expand">
+
+
+ <div class="post post-type-normal ">
+ <div class="post-header">
+
+
+
+ <h1 class="post-title">
+
+
+
+ JavaScript学习笔记-栈
+
+
+ </h1>
+
+
+ <div class="post-meta">
+ <span class="post-time">
+ 发表于 2015-05-29
+ </span>
+
+
+ <span class="post-category">
+ | 分类于
+
+ <a href="/categories/JavaScript/">JavaScript</a>
+
+
+
+
+
+ </span>
+
+
+
+
+ <span class="post-comments-count">
+ |
+ <a href="/2015/05/29/javascript-note-05/#comments" >
+ <span class="post-comments-count ds-thread-count" data-thread-key="2015/05/29/javascript-note-05/"></span>
+ </a>
+ </span>
+
+
+ </div>
+ </div>
+
+ <div class="post-body">
+
+
+
+
+
+ <h3 id="什么是栈">什么是栈</h3><p>栈是一种被称为后入先出(LIFO,last in first out)的数据结构.是一个特殊的列表,栈内的元素只能通过一端访问,这个端被称为栈顶.</p>
+<h3 id="如何定义栈">如何定义栈</h3><ul>
+<li>方法:将一个元素压入栈push(element)</li>
+<li>方法:将一个元素弹出栈pop()->element 被弹出的元素从栈中永久性删除</li>
+<li>方法:预览栈顶元素peek()->element 只返回栈顶元素,不删除该元素</li>
+<li>方法:清除栈内所有元素clear() 可以将top=0快速清空栈</li>
+<li>方法:栈内元素的个数:length()->number //可以使用top获取</li>
+<li>属性:栈顶元素位置number:top</li>
+<li>属性:栈内是否有元素boolean:empty //可以使用top=0进行判断,</li>
+</ul>
+<figure class="highlight actionscript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br></pre></td><td class="code"><pre><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">Stack</span><span class="params">()</span></span>{</span><br><span class="line"> <span class="keyword">this</span>.dataStore = [];</span><br><span class="line"> <span class="keyword">this</span>.top = <span class="number">0</span>;</span><br><span class="line"> <span class="keyword">this</span>.push = <span class="function"><span class="keyword">function</span><span class="params">(element)</span></span>{</span><br><span class="line"> <span class="keyword">this</span>.dataStore[<span class="keyword">this</span>.top++] = element;</span><br><span class="line"> };</span><br><span class="line"> <span class="keyword">this</span>.pop = <span class="function"><span class="keyword">function</span><span class="params">()</span></span>{</span><br><span class="line"> <span class="keyword">return</span> <span class="keyword">this</span>.dataStore[--<span class="keyword">this</span>.top];</span><br><span class="line"> };</span><br><span class="line"> <span class="keyword">this</span>.peek = <span class="function"><span class="keyword">function</span><span class="params">()</span></span>{</span><br><span class="line"> <span class="keyword">return</span> <span class="keyword">this</span>.dataStore[<span class="keyword">this</span>.top - <span class="number">1</span>];</span><br><span class="line"> };</span><br><span class="line"> <span class="keyword">this</span>.length = <span class="function"><span class="keyword">function</span><span class="params">()</span></span>{</span><br><span class="line"> <span class="keyword">return</span> <span class="keyword">this</span>.top;</span><br><span class="line"> };</span><br><span class="line"> <span class="keyword">this</span>.clear = <span class="function"><span class="keyword">function</span><span class="params">()</span></span>{</span><br><span class="line"> <span class="keyword">this</span>.top = <span class="number">0</span>;</span><br><span class="line"> };</span><br><span class="line">}</span><br></pre></td></tr></table></figure>
+<h3 id="使用栈">使用栈</h3><figure class="highlight openscad"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br></pre></td><td class="code"><pre><span class="line">var s = new Stack<span class="params">()</span>;</span><br><span class="line">s.push<span class="params">('iDarker')</span>;</span><br><span class="line">s.push<span class="params">('xiachuan')</span>;</span><br><span class="line">s.push<span class="params">('qianxia')</span>;</span><br><span class="line">console.<span class="built_in">log</span><span class="params">('length:' + s.length<span class="params">()</span>)</span>; <span class="comment">//length:3</span></span><br><span class="line">console.<span class="built_in">log</span><span class="params">('peek:' + s.peek<span class="params">()</span>)</span>; <span class="comment">//peek: qianxia</span></span><br><span class="line">var poped = s.pop<span class="params">()</span>;</span><br><span class="line">console.<span class="built_in">log</span><span class="params">('poped :' + poped)</span>; <span class="comment">//poped : qianxia</span></span><br><span class="line">console.<span class="built_in">log</span><span class="params">('peek:' + s.peek<span class="params">()</span>)</span>; <span class="comment">//peek: xiachuan</span></span><br><span class="line">s.push<span class="params">('love')</span>;</span><br><span class="line">console.<span class="built_in">log</span><span class="params">('peek:' + s.peek<span class="params">()</span>)</span>; <span class="comment">//peek: love</span></span><br><span class="line">s.clear<span class="params">()</span>;</span><br><span class="line">console.<span class="built_in">log</span><span class="params">('length:' + s.length<span class="params">()</span>)</span>; <span class="comment">//length:0</span></span><br><span class="line">console.<span class="built_in">log</span><span class="params">('peek:' + s.peek<span class="params">()</span>)</span>; <span class="comment">//peek:undefined</span></span><br></pre></td></tr></table></figure>
+<h3 id="栈能解决什么问题">栈能解决什么问题</h3><p><strong>使用栈进行进制转换</strong></p>
+<ul>
+<li>十六进制转为十进制 (这个问题不应该用栈解决,数组本身比这更好,想岔了 (ˇˍˇ))</li>
+</ul>
+<figure class="highlight stata"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br></pre></td><td class="code"><pre><span class="line">function Hex2Dec(hex){</span><br><span class="line"> <span class="keyword">var</span> chars = hex.toUpperCase().<span class="keyword">split</span>('').<span class="literal">reverse</span>(); <span class="comment">//统一转换为大写-->分割成字符数组-->倒序排列</span></span><br><span class="line"> <span class="keyword">var</span> <span class="keyword">stack</span> = new <span class="keyword">Stack</span>();</span><br><span class="line"> chars.<span class="keyword">forEach</span>(function(<span class="keyword">char</span>){</span><br><span class="line"> <span class="keyword">var</span> code = <span class="keyword">char</span>.charCodeAt(); <span class="comment">//获取字符串第一个元素的ascii码(实际上是Unicode码)</span></span><br><span class="line"> <span class="keyword">var</span> num = 0;</span><br><span class="line"> <span class="keyword">if</span>(code > 64){ <span class="comment">//判断是否大于'A'=65</span></span><br><span class="line"> num = code - 55; <span class="comment">//'A'->10 'B'->11</span></span><br><span class="line"> <span class="keyword">stack</span>.push(num);</span><br><span class="line"> }<span class="keyword">else</span>{</span><br><span class="line"> num = code - 48; <span class="comment">//char('0')=ascii(48)</span></span><br><span class="line"> <span class="keyword">stack</span>.push(num);</span><br><span class="line"> }</span><br><span class="line"> });</span><br><span class="line"> <span class="keyword">var</span> converted = 0;</span><br><span class="line"> <span class="keyword">while</span>(<span class="keyword">stack</span>.<span class="literal">length</span>()>0){</span><br><span class="line"> converted = converted*16 + <span class="keyword">stack</span>.pop();</span><br><span class="line"> }</span><br><span class="line"> <span class="keyword">return</span> converted;</span><br><span class="line">}</span><br><span class="line">console.<span class="literal">log</span>(Hex2Dec('123')); <span class="comment">// 291</span></span><br><span class="line">console.<span class="literal">log</span>(Hex2Dec('ABC')); <span class="comment">//2748</span></span><br><span class="line">console.<span class="literal">log</span>(Hex2Dec('121ABCcd')); <span class="comment">// 303742157</span></span><br></pre></td></tr></table></figure>
+<ul>
+<li>十进制转为十六进制/二进制/8进制</li>
+</ul>
+<figure class="highlight openscad"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br></pre></td><td class="code"><pre><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">convert</span><span class="params">(num,base)</span>{</span></span><br><span class="line"> var s = new Stack<span class="params">()</span>;</span><br><span class="line"> do{</span><br><span class="line"> s.push<span class="params">(num % base)</span>;</span><br><span class="line"> num = Math.<span class="built_in">floor</span><span class="params">(num / base)</span>;</span><br><span class="line"> }while<span class="params">(num > <span class="number">0</span>)</span>;</span><br><span class="line"> </span><br><span class="line"> var converted =<span class="string">""</span>;</span><br><span class="line"> while<span class="params">(s.length<span class="params">()</span> > <span class="number">0</span>)</span>{</span><br><span class="line"> var poped = s.pop<span class="params">()</span>;</span><br><span class="line"> <span class="keyword">if</span><span class="params">(poped > <span class="number">9</span>)</span>{</span><br><span class="line"> converted += String.fromCharCode<span class="params">(poped+<span class="number">55</span>)</span>;</span><br><span class="line"> }<span class="keyword">else</span>{</span><br><span class="line"> converted += poped;</span><br><span class="line"> }</span><br><span class="line"> }</span><br><span class="line"> return converted;</span><br><span class="line">}</span><br><span class="line">console.<span class="built_in">log</span><span class="params">(convert<span class="params">(<span class="number">303742157</span>,<span class="number">16</span>)</span>)</span>; <span class="comment">//121ABCCD</span></span><br><span class="line">console.<span class="built_in">log</span><span class="params">(convert<span class="params">(<span class="number">100</span>,<span class="number">16</span>)</span>)</span>; <span class="comment">//64</span></span><br><span class="line">console.<span class="built_in">log</span><span class="params">(convert<span class="params">(<span class="number">100</span>,<span class="number">10</span>)</span>)</span>; <span class="comment">//100</span></span><br><span class="line">console.<span class="built_in">log</span><span class="params">(convert<span class="params">(<span class="number">100</span>,<span class="number">8</span>)</span>)</span>; <span class="comment">//144</span></span><br><span class="line">console.<span class="built_in">log</span><span class="params">(convert<span class="params">(<span class="number">100</span>,<span class="number">2</span>)</span>)</span>; <span class="comment">//1100100</span></span><br><span class="line">console.<span class="built_in">log</span><span class="params">(convert<span class="params">(<span class="number">303742157</span>,<span class="number">20</span>)</span>)</span>; <span class="comment">//4EI7F7H (ˇˍˇ) ~</span></span><br></pre></td></tr></table></figure>
+<ul>
+<li>数组的reverse函数</li>
+</ul>
+<figure class="highlight javascript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br></pre></td><td class="code"><pre><span class="line"><span class="built_in">Array</span>.prototype.myReverse = <span class="function"><span class="keyword">function</span>(<span class="params"></span>)</span>{</span><br><span class="line"> <span class="keyword">var</span> s = <span class="keyword">new</span> Stack();</span><br><span class="line"> <span class="keyword">this</span>.forEach(<span class="function"><span class="keyword">function</span>(<span class="params">element</span>)</span>{</span><br><span class="line"> s.push(element);</span><br><span class="line"> });</span><br><span class="line"> </span><br><span class="line"> <span class="keyword">for</span>(<span class="keyword">var</span> i = <span class="number">0</span>;i< <span class="keyword">this</span>.length;i++){</span><br><span class="line"> <span class="keyword">this</span>[i] = s.pop();</span><br><span class="line"> }</span><br><span class="line"> <span class="keyword">return</span> <span class="keyword">this</span>;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="keyword">var</span> nums = [<span class="number">1</span>,<span class="number">2</span>,<span class="number">3</span>,<span class="number">4</span>,<span class="number">5</span>];</span><br><span class="line"><span class="built_in">console</span>.log(nums.myReverse()); <span class="comment">// [ 5, 4, 3, 2, 1 ]</span></span><br><span class="line"><span class="built_in">console</span>.log(nums); <span class="comment">// [ 5, 4, 3, 2, 1 ]</span></span><br></pre></td></tr></table></figure>
+<ul>
+<li>判断字符串是否为回文<br>回文是指这样一种现象: 一个单词、 短语或数字, 从前往后写和从后往前写都是一样的。</li>
+</ul>
+<figure class="highlight openscad"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br></pre></td><td class="code"><pre><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">isPalindrome</span><span class="params">(word)</span> {</span></span><br><span class="line"> var s = new Stack<span class="params">()</span>;</span><br><span class="line"> <span class="keyword">for</span> <span class="params">(var i = <span class="number">0</span>; i < word. length; ++i)</span> {</span><br><span class="line"> s. push<span class="params">(word[i] )</span>;</span><br><span class="line"> }</span><br><span class="line"> var rword = <span class="string">""</span>;</span><br><span class="line"> while <span class="params">(s. length<span class="params">()</span> > <span class="number">0</span>)</span> {</span><br><span class="line"> rword += s. pop<span class="params">()</span>;</span><br><span class="line"> }</span><br><span class="line"> <span class="keyword">if</span> <span class="params">(word == rword)</span> {</span><br><span class="line"> return <span class="literal">true</span>;</span><br><span class="line"> }<span class="keyword">else</span> {</span><br><span class="line"> return <span class="literal">false</span>;</span><br><span class="line"> }</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line">var word = <span class="string">"hello"</span> ;</span><br><span class="line"><span class="keyword">if</span> <span class="params">(isPalindrome<span class="params">(word)</span>)</span> {</span><br><span class="line"> console.<span class="built_in">log</span><span class="params">(word + <span class="string">" is a palindrome. "</span> )</span>;</span><br><span class="line">}<span class="keyword">else</span> {</span><br><span class="line"> console.<span class="built_in">log</span><span class="params">(word + <span class="string">" is not a palindrome. "</span> )</span>;</span><br><span class="line">}</span><br><span class="line">word = <span class="string">"racecar"</span></span><br><span class="line"><span class="keyword">if</span> <span class="params">(isPalindrome<span class="params">(word)</span>)</span> {</span><br><span class="line"> console.<span class="built_in">log</span><span class="params">(word + <span class="string">" is a palindrome. "</span> )</span>;</span><br><span class="line">}<span class="keyword">else</span> {</span><br><span class="line"> console.<span class="built_in">log</span><span class="params">(word + <span class="string">" is not a palindrome. "</span> )</span>;</span><br><span class="line">}</span><br></pre></td></tr></table></figure>
+<ul>
+<li>用栈实现函数的递归调用<br>求阶乘5! = 5<em>4</em>3<em>2</em>1 = 120</li>
+</ul>
+<figure class="highlight openscad"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br></pre></td><td class="code"><pre><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">factorial</span><span class="params">(n)</span>{</span></span><br><span class="line"> <span class="keyword">if</span><span class="params">(n == <span class="number">0</span>)</span>{</span><br><span class="line"> return <span class="number">1</span>;</span><br><span class="line"> }<span class="keyword">else</span>{</span><br><span class="line"> return n <span class="built_in">*</span> factorial<span class="params">(n-<span class="number">1</span>)</span>;</span><br><span class="line"> }</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">function</span> <span class="title">fact</span><span class="params">(n)</span>{</span></span><br><span class="line"> var s = new Stack<span class="params">()</span>;</span><br><span class="line"> while<span class="params">(n><span class="number">1</span>)</span>{</span><br><span class="line"> s.push<span class="params">(n--)</span>;</span><br><span class="line"> }</span><br><span class="line"> var product = <span class="number">1</span>;</span><br><span class="line"> while<span class="params">(s.length<span class="params">()</span> > <span class="number">0</span>)</span>{</span><br><span class="line"> product <span class="built_in">*</span>= s.pop<span class="params">()</span>;</span><br><span class="line"> }</span><br><span class="line"> return product;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line">console.<span class="built_in">log</span><span class="params">(factorial<span class="params">(<span class="number">5</span>)</span>)</span>;</span><br><span class="line">console.<span class="built_in">log</span><span class="params">(fact<span class="params">(<span class="number">5</span>)</span>)</span>;</span><br></pre></td></tr></table></figure>
+
+ </div>
+
+ <div class="post-footer">
+
+ <div class="post-tags">
+
+ <a href="/tags/JavaScript/"> #JavaScript </a>
+
+ </div>
+
+
+
+ <div class="post-nav">
+ <div class="post-nav-prev post-nav-item">
+
+ <a href="/2015/05/29/javascript-note-04/">JavaScript学习笔记-列表</a>
+
+ </div>
+
+ <div class="post-nav-next post-nav-item">
+
+ <a href="/2015/05/29/netmapping-01/">分布式端口映射NetMapping的设计与实现</a>
+
+ </div>
+ </div>
+
+
+
+
+ </div>
+ </div>
+
+
+
+
+
+
+ <div class="comments" id="comments">
+
+ <div class="ds-thread" data-thread-key="2015/05/29/javascript-note-05/"
+ data-title="JavaScript学习笔记-栈" data-url="http://archerding.github.io/2015/05/29/javascript-note-05/">
+ </div>
+
+ </div>
+
+ </div>
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+ <ul class="sidebar-nav motion-element">
+ <li class="sidebar-nav-toc sidebar-nav-active" data-target="post-toc-wrap">
+ 文章目录
+ </li>
+ <li class="sidebar-nav-overview" data-target="site-overview">
+ 站点概览
+ </li>
+ </ul>
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+ <div class="post-toc-wrap sidebar-panel-active">
+ <div class="post-toc-indicator-top post-toc-indicator"></div>
+ <div class="post-toc">
+
+
+ <div class="post-toc-content"><ol class="nav"><li class="nav-item nav-level-3"><a class="nav-link" href="#什么是栈"><span class="nav-number">1.</span> <span class="nav-text">什么是栈</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#如何定义栈"><span class="nav-number">2.</span> <span class="nav-text">如何定义栈</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#使用栈"><span class="nav-number">3.</span> <span class="nav-text">使用栈</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#栈能解决什么问题"><span class="nav-number">4.</span> <span class="nav-text">栈能解决什么问题</span></a></li></ol></div>
+
+ </div>
+ <div class="post-toc-indicator-bottom post-toc-indicator"></div>
+ </div>
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+<script type="text/javascript" src="/js/bootstrap.scrollspy.js?v=0.4.3" id="bootstrap.scrollspy.custom"></script>
+
+
+<script type="text/javascript" id="sidebar.toc.highlight">
+ $(document).ready(function () {
+ var tocSelector = '.post-toc';
+ var $tocSelector = $(tocSelector);
+ var activeCurrentSelector = '.active-current';
+
+ $tocSelector
+ .on('activate.bs.scrollspy', function () {
+ var $currentActiveElement = $(tocSelector + ' .active').last();
+
+ removeCurrentActiveClass();
+ $currentActiveElement.addClass('active-current');
+
+ $tocSelector[0].scrollTop = $currentActiveElement.position().top;
+ })
+ .on('clear.bs.scrollspy', function () {
+ removeCurrentActiveClass();
+ });
+
+ function removeCurrentActiveClass () {
+ $(tocSelector + ' ' + activeCurrentSelector)
+ .removeClass(activeCurrentSelector.substring(1));
+ }
+
+ function processTOC () {
+ getTOCMaxHeight();
+ toggleTOCOverflowIndicators();
+ }
+
+ function getTOCMaxHeight () {
+ var $sidebarInner = $('.sidebar-inner');
+ var height = $('.sidebar').height() -
+ $tocSelector.position().top -
+ $('.post-toc-indicator-bottom').height();
+
+ $tocSelector.css('height', height);
+
+ return height;
+ }
+
+ function toggleTOCOverflowIndicators () {
+ tocOverflowIndicator(
+ '.post-toc-indicator-top',
+ $tocSelector.scrollTop() > 0 ? 'show' : 'hide'
+ );
+
+ tocOverflowIndicator(
+ '.post-toc-indicator-bottom',
+ $tocSelector.scrollTop() >= $tocSelector.find('ol').height() - $tocSelector.height() ? 'hide' : 'show'
+ )
+ }
+
+ $(document).on('sidebar.didShow', function () {
+ processTOC();
+ });
+
+ $('body').scrollspy({ target: tocSelector });
+ $(window).on('resize', function () {
+ if ( $('.sidebar').hasClass('sidebar-active') ) {
+ processTOC();
+ }
+ });
+
+ onScroll($tocSelector);
+
+ function onScroll (element) {
+ element.on('mousewheel DOMMouseScroll', function (event) {
+ var oe = event.originalEvent;
+ var delta = oe.wheelDelta || -oe.detail;
+ var self = this;
+
+ this.scrollTop += ( delta < 0 ? 1 : -1 ) * 30;
+ event.preventDefault();
+
+ toggleTOCOverflowIndicators();
+ });
+ }
+
+ function tocOverflowIndicator (indicator, action) {
+ $(indicator).velocity('stop').velocity({
+ opacity: action === 'show' ? 0.4 : 0
+ }, { duration: 100 });
+ }
+
+ });
+</script>
+
+
+ <script type="text/javascript" id="sidebar.nav">
+ $(document).ready(function () {
+ var html = $('html');
+
+ $('.sidebar-nav li').on('click', function () {
+ var item = $(this);
+ var activeTabClassName = 'sidebar-nav-active';
+ var activePanelClassName = 'sidebar-panel-active';
+ if (item.hasClass(activeTabClassName)) {
+ return;
+ }
+
+ var currentTarget = $('.' + activePanelClassName);
+ var target = $('.' + item.data('target'));
+
+ currentTarget.velocity('transition.slideUpOut', 200, function () {
+ target
+ .velocity('stop')
+ .velocity('transition.slideDownIn', 200)
+ .addClass(activePanelClassName);
+ });
+
+ item.siblings().removeClass(activeTabClassName);
+ item.addClass(activeTabClassName);
+ });
+
+ $('.post-toc a').on('click', function (e) {
+ e.preventDefault();
+ var offset = $(escapeSelector(this.getAttribute('href'))).offset().top;
+ html.velocity('stop').velocity('scroll', {
+ offset: offset + 'px',
+ mobileHA: false
+ });
+ });
+
+ // Expand sidebar on post detail page by default, when post has a toc.
+ var $tocContent = $('.post-toc-content');
+ if (isDesktop() && CONFIG.sidebar === 'post') {
+ if ($tocContent.length > 0 && $tocContent.html().trim().length > 0) {
+ displaySidebar();
+ }
+ }
+ });
+ </script>
+
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+
+
+ <script type="text/javascript">
+ var duoshuoQuery = {short_name:"archerding"};
+ (function() {
+ var ds = document.createElement('script');
+ ds.type = 'text/javascript';ds.async = true;
+ ds.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') + '//static.duoshuo.com/embed.js';
+ ds.charset = 'UTF-8';
+ (document.getElementsByTagName('head')[0]
+ || document.getElementsByTagName('body')[0]).appendChild(ds);
+ })();
+ </script>
+
+
+
+
+
+
+
+</body>
+</html>
diff --git a/2015/05/29/netmapping-01/index.html b/2015/05/29/netmapping-01/index.html
new file mode 100644
index 0000000..2ac4e79
--- /dev/null
+++ b/2015/05/29/netmapping-01/index.html
@@ -0,0 +1,603 @@
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="Golang," />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
+</script>
+
+
+
+
+ <title> 分布式端口映射NetMapping的设计与实现 // ArcherDing's Notes </title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column page-post-detail">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
+<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
+
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
+
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
+
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-expand">
+
+
+ <div class="post post-type-normal ">
+ <div class="post-header">
+
+
+
+ <h1 class="post-title">
+
+
+
+ 分布式端口映射NetMapping的设计与实现
+
+
+ </h1>
+
+
+ <div class="post-meta">
+ <span class="post-time">
+ 发表于 2015-05-29
+ </span>
+
+
+ <span class="post-category">
+ | 分类于
+
+ <a href="/categories/Golang/">Golang</a>
+
+
+
+
+
+ </span>
+
+
+
+
+ <span class="post-comments-count">
+ |
+ <a href="/2015/05/29/netmapping-01/#comments" >
+ <span class="post-comments-count ds-thread-count" data-thread-key="2015/05/29/netmapping-01/"></span>
+ </a>
+ </span>
+
+
+ </div>
+ </div>
+
+ <div class="post-body">
+
+
+
+
+
+ <h4 id="架构设计">架构设计</h4><p><img src="/images/netmapping-01/NetMapping.png" alt="这是一张图片"><br><img src="/images/netmapping-01/UseCase.png" alt="这是一张图片"></p>
+
+
+ </div>
+
+ <div class="post-footer">
+
+ <div class="post-tags">
+
+ <a href="/tags/Golang/"> #Golang </a>
+
+ </div>
+
+
+
+ <div class="post-nav">
+ <div class="post-nav-prev post-nav-item">
+
+ <a href="/2015/05/29/javascript-note-05/">JavaScript学习笔记-栈</a>
+
+ </div>
+
+ <div class="post-nav-next post-nav-item">
+
+ </div>
+ </div>
+
+
+
+
+ </div>
+ </div>
+
+
+
+
+
+
+ <div class="comments" id="comments">
+
+ <div class="ds-thread" data-thread-key="2015/05/29/netmapping-01/"
+ data-title="分布式端口映射NetMapping的设计与实现" data-url="http://archerding.github.io/2015/05/29/netmapping-01/">
+ </div>
+
+ </div>
+
+ </div>
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+ <ul class="sidebar-nav motion-element">
+ <li class="sidebar-nav-toc sidebar-nav-active" data-target="post-toc-wrap">
+ 文章目录
+ </li>
+ <li class="sidebar-nav-overview" data-target="site-overview">
+ 站点概览
+ </li>
+ </ul>
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+ <div class="post-toc-wrap sidebar-panel-active">
+ <div class="post-toc-indicator-top post-toc-indicator"></div>
+ <div class="post-toc">
+
+
+ <div class="post-toc-content"><ol class="nav"><li class="nav-item nav-level-4"><a class="nav-link" href="#架构设计"><span class="nav-number">1.</span> <span class="nav-text">架构设计</span></a></li></ol></div>
+
+ </div>
+ <div class="post-toc-indicator-bottom post-toc-indicator"></div>
+ </div>
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+<script type="text/javascript" src="/js/bootstrap.scrollspy.js?v=0.4.3" id="bootstrap.scrollspy.custom"></script>
+
+
+<script type="text/javascript" id="sidebar.toc.highlight">
+ $(document).ready(function () {
+ var tocSelector = '.post-toc';
+ var $tocSelector = $(tocSelector);
+ var activeCurrentSelector = '.active-current';
+
+ $tocSelector
+ .on('activate.bs.scrollspy', function () {
+ var $currentActiveElement = $(tocSelector + ' .active').last();
+
+ removeCurrentActiveClass();
+ $currentActiveElement.addClass('active-current');
+
+ $tocSelector[0].scrollTop = $currentActiveElement.position().top;
+ })
+ .on('clear.bs.scrollspy', function () {
+ removeCurrentActiveClass();
+ });
+
+ function removeCurrentActiveClass () {
+ $(tocSelector + ' ' + activeCurrentSelector)
+ .removeClass(activeCurrentSelector.substring(1));
+ }
+
+ function processTOC () {
+ getTOCMaxHeight();
+ toggleTOCOverflowIndicators();
+ }
+
+ function getTOCMaxHeight () {
+ var $sidebarInner = $('.sidebar-inner');
+ var height = $('.sidebar').height() -
+ $tocSelector.position().top -
+ $('.post-toc-indicator-bottom').height();
+
+ $tocSelector.css('height', height);
+
+ return height;
+ }
+
+ function toggleTOCOverflowIndicators () {
+ tocOverflowIndicator(
+ '.post-toc-indicator-top',
+ $tocSelector.scrollTop() > 0 ? 'show' : 'hide'
+ );
+
+ tocOverflowIndicator(
+ '.post-toc-indicator-bottom',
+ $tocSelector.scrollTop() >= $tocSelector.find('ol').height() - $tocSelector.height() ? 'hide' : 'show'
+ )
+ }
+
+ $(document).on('sidebar.didShow', function () {
+ processTOC();
+ });
+
+ $('body').scrollspy({ target: tocSelector });
+ $(window).on('resize', function () {
+ if ( $('.sidebar').hasClass('sidebar-active') ) {
+ processTOC();
+ }
+ });
+
+ onScroll($tocSelector);
+
+ function onScroll (element) {
+ element.on('mousewheel DOMMouseScroll', function (event) {
+ var oe = event.originalEvent;
+ var delta = oe.wheelDelta || -oe.detail;
+ var self = this;
+
+ this.scrollTop += ( delta < 0 ? 1 : -1 ) * 30;
+ event.preventDefault();
+
+ toggleTOCOverflowIndicators();
+ });
+ }
+
+ function tocOverflowIndicator (indicator, action) {
+ $(indicator).velocity('stop').velocity({
+ opacity: action === 'show' ? 0.4 : 0
+ }, { duration: 100 });
+ }
+
+ });
+</script>
+
+
+ <script type="text/javascript" id="sidebar.nav">
+ $(document).ready(function () {
+ var html = $('html');
+
+ $('.sidebar-nav li').on('click', function () {
+ var item = $(this);
+ var activeTabClassName = 'sidebar-nav-active';
+ var activePanelClassName = 'sidebar-panel-active';
+ if (item.hasClass(activeTabClassName)) {
+ return;
+ }
+
+ var currentTarget = $('.' + activePanelClassName);
+ var target = $('.' + item.data('target'));
+
+ currentTarget.velocity('transition.slideUpOut', 200, function () {
+ target
+ .velocity('stop')
+ .velocity('transition.slideDownIn', 200)
+ .addClass(activePanelClassName);
+ });
+
+ item.siblings().removeClass(activeTabClassName);
+ item.addClass(activeTabClassName);
+ });
+
+ $('.post-toc a').on('click', function (e) {
+ e.preventDefault();
+ var offset = $(escapeSelector(this.getAttribute('href'))).offset().top;
+ html.velocity('stop').velocity('scroll', {
+ offset: offset + 'px',
+ mobileHA: false
+ });
+ });
+
+ // Expand sidebar on post detail page by default, when post has a toc.
+ var $tocContent = $('.post-toc-content');
+ if (isDesktop() && CONFIG.sidebar === 'post') {
+ if ($tocContent.length > 0 && $tocContent.html().trim().length > 0) {
+ displaySidebar();
+ }
+ }
+ });
+ </script>
+
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+
+
+ <script type="text/javascript">
+ var duoshuoQuery = {short_name:"archerding"};
+ (function() {
+ var ds = document.createElement('script');
+ ds.type = 'text/javascript';ds.async = true;
+ ds.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') + '//static.duoshuo.com/embed.js';
+ ds.charset = 'UTF-8';
+ (document.getElementsByTagName('head')[0]
+ || document.getElementsByTagName('body')[0]).appendChild(ds);
+ })();
+ </script>
+
+
+
+
+
+
+
+</body>
+</html>
diff --git a/2015/06/06/coredump-01/index.html b/2015/06/06/coredump-01/index.html
new file mode 100644
index 0000000..47190f0
--- /dev/null
+++ b/2015/06/06/coredump-01/index.html
@@ -0,0 +1,622 @@
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="coredump," />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
+</script>
+
+
+
+
+ <title> 使用gdb解析core dump-概念篇 // ArcherDing's Notes </title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column page-post-detail">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
+<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
+
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
+
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
+
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-expand">
+
+
+ <div class="post post-type-normal ">
+ <div class="post-header">
+
+
+
+ <h1 class="post-title">
+
+
+
+ 使用gdb解析core dump-概念篇
+
+
+ </h1>
+
+
+ <div class="post-meta">
+ <span class="post-time">
+ 发表于 2015-06-06
+ </span>
+
+
+ <span class="post-category">
+ | 分类于
+
+ <a href="/categories/coredump/">coredump</a>
+
+
+
+
+
+ </span>
+
+
+
+
+ <span class="post-comments-count">
+ |
+ <a href="/2015/06/06/coredump-01/#comments" >
+ <span class="post-comments-count ds-thread-count" data-thread-key="2015/06/06/coredump-01/"></span>
+ </a>
+ </span>
+
+
+ </div>
+ </div>
+
+ <div class="post-body">
+
+
+
+
+
+ <h3 id="Core_dump是什么?">Core dump是什么?</h3><p>当一个程序在运行的过程中发生了错误,导致<strong>程序崩溃</strong>或者<strong>异常终止</strong>的时候,操作系统会将这个程序在问题发生时的一些信息以文件的形式保存起来,以便维护人员进行调查,解析问题发生的原因,这个文件就是Core dump文件。<br>从字面上理解,Core dump(核心转储)就是将core信息以dump格式保存在文件中。<br>Core信息包括了进程信息、内存信息、寄存器信息、堆栈信息等。</p>
+<h3 id="Core_dump保存在哪里?">Core dump保存在哪里?</h3><p><strong>开启core dump功能</strong></p>
+<p>要想获得Coredump文件就必须先开启保存该文件的功能。<br>使用<code>ulimit -c</code>可以查看是否开启。如果输出0说明没有开启,使用<code>ulimit -c unlimited</code>可以开启,这种方式不会限制core文件的大小;使用<code>ulimit -c size</code>可以设置core文件大小,单位是KB。但是这种方式只能设置当前终端有效,如果希望永久开启,可以在<code>/etc/profile</code>中追加<code>ulimit -c unlimited</code>。</p>
+<p><strong>修改core文件位置</strong></p>
+<p>默认情况下会在程序所在目录生成文件名为<code>core</code>的core文件;<br>使用<code>echo 1 > /proc/sys/kernel/core_uses_pid</code>可以在生成带进程PID的core文件,文件形式为<code>core.pid</code>;<br>使用<code>echo "/tmp/core/core-%e.%p" > /proc/sys/kernel/core_pattern</code>可以在<code>/tmp/core</code>中生成格式为<code>core-程序名.pid</code>的core文件。</p>
+<h3 id="Core_dump如何产生?">Core dump如何产生?</h3><p>我们知道了程序在<strong>程序崩溃</strong>或者<strong>异常终止</strong>的时候会产生core文件呢?那么使用<code>kill -9</code>会产生core文件吗?<br>我们不妨做个试验。我们给helloword程序加上死循环来进行测试。</p>
+<figure class="highlight cpp"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br></pre></td><td class="code"><pre><span class="line"><span class="preprocessor">#<span class="keyword">include</span> <stdio.h></span></span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">int</span> <span class="title">main</span><span class="params">(<span class="keyword">int</span> argc, <span class="keyword">char</span> **argv)</span></span><br><span class="line"></span>{</span><br><span class="line"> <span class="keyword">while</span>(<span class="number">1</span>){</span><br><span class="line"> <span class="built_in">fprintf</span>(stdout,<span class="string">"Hello World!\n"</span>);</span><br><span class="line"> fflush(stdout);</span><br><span class="line"> sleep(<span class="number">5</span>);</span><br><span class="line"> }</span><br><span class="line"> <span class="keyword">return</span> <span class="number">0</span>;</span><br><span class="line">}</span><br></pre></td></tr></table></figure>
+<figure class="highlight elixir"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br></pre></td><td class="code"><pre><span class="line"><span class="variable">$ </span>gcc hello.c -o hello</span><br><span class="line"><span class="variable">$ </span>./hello</span><br><span class="line"><span class="constant">Hello World!</span></span><br><span class="line"><span class="constant">Hello World!</span></span><br><span class="line"><span class="variable">$ </span>ps -ef | grep hello</span><br><span class="line">archerd+ <span class="number">2890</span> <span class="number">2044</span> <span class="number">0</span> <span class="number">20</span><span class="symbol">:</span><span class="number">55</span> pts/<span class="number">1</span> <span class="number">00</span><span class="symbol">:</span><span class="number">00</span><span class="symbol">:</span><span class="number">00</span> ./hello</span><br></pre></td></tr></table></figure>
+<p>接下来我们使用下面的命令结束进程,发现没有生成core文件。</p>
+<blockquote>
+<p>pkill -9 hello</p>
+</blockquote>
+<p>我们继续使用下面的命令结束进程,发现产生core文件。</p>
+<blockquote>
+<p>kill -s 11 `pgrep hello`</p>
+</blockquote>
+<p>我们可以得出一个结论,并非所有的中断信号都产生core文件。那么什么信号会产生core文件呢??<br>我们使用<code>man 7 signal</code>来查看一下,原来下表中Action为core的信号才会产生core文件。</p>
+<figure class="highlight sql"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br></pre></td><td class="code"><pre><span class="line">Signal Value Action Comment</span><br><span class="line">──────────────────────────────────────────────────────────────────────</span><br><span class="line">SIGHUP 1 Term Hangup detected on controlling terminal</span><br><span class="line"> or death of controlling process</span><br><span class="line">SIGINT 2 Term Interrupt from keyboard</span><br><span class="line">SIGQUIT 3 Core Quit from keyboard</span><br><span class="line">SIGILL 4 Core Illegal Instruction</span><br><span class="line">SIGABRT 6 Core Abort signal from abort(3)</span><br><span class="line">SIGFPE 8 Core Floating point exception</span><br><span class="line">SIGKILL 9 Term <span class="operator"><span class="keyword">Kill</span> signal</span><br><span class="line">SIGSEGV <span class="number">11</span> Core Invalid memory reference</span><br><span class="line">SIGPIPE <span class="number">13</span> Term Broken pipe: <span class="keyword">write</span> <span class="keyword">to</span> pipe <span class="keyword">with</span> <span class="keyword">no</span></span><br><span class="line"> readers</span><br><span class="line">SIGALRM <span class="number">14</span> Term Timer signal <span class="keyword">from</span> alarm(<span class="number">2</span>)</span><br><span class="line">SIGTERM <span class="number">15</span> Term Termination signal</span><br><span class="line">SIGUSR1 <span class="number">30</span>,<span class="number">10</span>,<span class="number">16</span> Term <span class="keyword">User</span>-defined signal <span class="number">1</span></span><br><span class="line">SIGUSR2 <span class="number">31</span>,<span class="number">12</span>,<span class="number">17</span> Term <span class="keyword">User</span>-defined signal <span class="number">2</span></span><br><span class="line">SIGCHLD <span class="number">20</span>,<span class="number">17</span>,<span class="number">18</span> Ign Child stopped <span class="keyword">or</span> <span class="keyword">terminated</span></span><br><span class="line">SIGCONT <span class="number">19</span>,<span class="number">18</span>,<span class="number">25</span> Cont <span class="keyword">Continue</span> <span class="keyword">if</span> stopped</span><br><span class="line">SIGSTOP <span class="number">17</span>,<span class="number">19</span>,<span class="number">23</span> <span class="keyword">Stop</span> <span class="keyword">Stop</span> process</span><br><span class="line">SIGTSTP <span class="number">18</span>,<span class="number">20</span>,<span class="number">24</span> <span class="keyword">Stop</span> <span class="keyword">Stop</span> typed <span class="keyword">at</span> terminal</span><br><span class="line">SIGTTIN <span class="number">21</span>,<span class="number">21</span>,<span class="number">26</span> <span class="keyword">Stop</span> Terminal <span class="keyword">input</span> <span class="keyword">for</span> background process</span><br><span class="line">SIGTTOU <span class="number">22</span>,<span class="number">22</span>,<span class="number">27</span> <span class="keyword">Stop</span> Terminal <span class="keyword">output</span> <span class="keyword">for</span> background process</span></span><br></pre></td></tr></table></figure>
+
+
+ </div>
+
+ <div class="post-footer">
+
+ <div class="post-tags">
+
+ <a href="/tags/coredump/"> #coredump </a>
+
+ </div>
+
+
+
+ <div class="post-nav">
+ <div class="post-nav-prev post-nav-item">
+
+ <a href="/2015/06/11/coredump-02/">使用gdb解析core dump-解析篇</a>
+
+ </div>
+
+ <div class="post-nav-next post-nav-item">
+
+ <a href="/2015/05/29/javascript-note-01/">JavaScript学习笔记-数组</a>
+
+ </div>
+ </div>
+
+
+
+
+ </div>
+ </div>
+
+
+
+
+
+
+ <div class="comments" id="comments">
+
+ <div class="ds-thread" data-thread-key="2015/06/06/coredump-01/"
+ data-title="使用gdb解析core dump-概念篇" data-url="http://archerding.github.io/2015/06/06/coredump-01/">
+ </div>
+
+ </div>
+
+ </div>
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+ <ul class="sidebar-nav motion-element">
+ <li class="sidebar-nav-toc sidebar-nav-active" data-target="post-toc-wrap">
+ 文章目录
+ </li>
+ <li class="sidebar-nav-overview" data-target="site-overview">
+ 站点概览
+ </li>
+ </ul>
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+ <div class="post-toc-wrap sidebar-panel-active">
+ <div class="post-toc-indicator-top post-toc-indicator"></div>
+ <div class="post-toc">
+
+
+ <div class="post-toc-content"><ol class="nav"><li class="nav-item nav-level-3"><a class="nav-link" href="#Core_dump是什么?"><span class="nav-number">1.</span> <span class="nav-text">Core dump是什么?</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#Core_dump保存在哪里?"><span class="nav-number">2.</span> <span class="nav-text">Core dump保存在哪里?</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#Core_dump如何产生?"><span class="nav-number">3.</span> <span class="nav-text">Core dump如何产生?</span></a></li></ol></div>
+
+ </div>
+ <div class="post-toc-indicator-bottom post-toc-indicator"></div>
+ </div>
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+<script type="text/javascript" src="/js/bootstrap.scrollspy.js?v=0.4.3" id="bootstrap.scrollspy.custom"></script>
+
+
+<script type="text/javascript" id="sidebar.toc.highlight">
+ $(document).ready(function () {
+ var tocSelector = '.post-toc';
+ var $tocSelector = $(tocSelector);
+ var activeCurrentSelector = '.active-current';
+
+ $tocSelector
+ .on('activate.bs.scrollspy', function () {
+ var $currentActiveElement = $(tocSelector + ' .active').last();
+
+ removeCurrentActiveClass();
+ $currentActiveElement.addClass('active-current');
+
+ $tocSelector[0].scrollTop = $currentActiveElement.position().top;
+ })
+ .on('clear.bs.scrollspy', function () {
+ removeCurrentActiveClass();
+ });
+
+ function removeCurrentActiveClass () {
+ $(tocSelector + ' ' + activeCurrentSelector)
+ .removeClass(activeCurrentSelector.substring(1));
+ }
+
+ function processTOC () {
+ getTOCMaxHeight();
+ toggleTOCOverflowIndicators();
+ }
+
+ function getTOCMaxHeight () {
+ var $sidebarInner = $('.sidebar-inner');
+ var height = $('.sidebar').height() -
+ $tocSelector.position().top -
+ $('.post-toc-indicator-bottom').height();
+
+ $tocSelector.css('height', height);
+
+ return height;
+ }
+
+ function toggleTOCOverflowIndicators () {
+ tocOverflowIndicator(
+ '.post-toc-indicator-top',
+ $tocSelector.scrollTop() > 0 ? 'show' : 'hide'
+ );
+
+ tocOverflowIndicator(
+ '.post-toc-indicator-bottom',
+ $tocSelector.scrollTop() >= $tocSelector.find('ol').height() - $tocSelector.height() ? 'hide' : 'show'
+ )
+ }
+
+ $(document).on('sidebar.didShow', function () {
+ processTOC();
+ });
+
+ $('body').scrollspy({ target: tocSelector });
+ $(window).on('resize', function () {
+ if ( $('.sidebar').hasClass('sidebar-active') ) {
+ processTOC();
+ }
+ });
+
+ onScroll($tocSelector);
+
+ function onScroll (element) {
+ element.on('mousewheel DOMMouseScroll', function (event) {
+ var oe = event.originalEvent;
+ var delta = oe.wheelDelta || -oe.detail;
+ var self = this;
+
+ this.scrollTop += ( delta < 0 ? 1 : -1 ) * 30;
+ event.preventDefault();
+
+ toggleTOCOverflowIndicators();
+ });
+ }
+
+ function tocOverflowIndicator (indicator, action) {
+ $(indicator).velocity('stop').velocity({
+ opacity: action === 'show' ? 0.4 : 0
+ }, { duration: 100 });
+ }
+
+ });
+</script>
+
+
+ <script type="text/javascript" id="sidebar.nav">
+ $(document).ready(function () {
+ var html = $('html');
+
+ $('.sidebar-nav li').on('click', function () {
+ var item = $(this);
+ var activeTabClassName = 'sidebar-nav-active';
+ var activePanelClassName = 'sidebar-panel-active';
+ if (item.hasClass(activeTabClassName)) {
+ return;
+ }
+
+ var currentTarget = $('.' + activePanelClassName);
+ var target = $('.' + item.data('target'));
+
+ currentTarget.velocity('transition.slideUpOut', 200, function () {
+ target
+ .velocity('stop')
+ .velocity('transition.slideDownIn', 200)
+ .addClass(activePanelClassName);
+ });
+
+ item.siblings().removeClass(activeTabClassName);
+ item.addClass(activeTabClassName);
+ });
+
+ $('.post-toc a').on('click', function (e) {
+ e.preventDefault();
+ var offset = $(escapeSelector(this.getAttribute('href'))).offset().top;
+ html.velocity('stop').velocity('scroll', {
+ offset: offset + 'px',
+ mobileHA: false
+ });
+ });
+
+ // Expand sidebar on post detail page by default, when post has a toc.
+ var $tocContent = $('.post-toc-content');
+ if (isDesktop() && CONFIG.sidebar === 'post') {
+ if ($tocContent.length > 0 && $tocContent.html().trim().length > 0) {
+ displaySidebar();
+ }
+ }
+ });
+ </script>
+
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+
+
+ <script type="text/javascript">
+ var duoshuoQuery = {short_name:"archerding"};
+ (function() {
+ var ds = document.createElement('script');
+ ds.type = 'text/javascript';ds.async = true;
+ ds.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') + '//static.duoshuo.com/embed.js';
+ ds.charset = 'UTF-8';
+ (document.getElementsByTagName('head')[0]
+ || document.getElementsByTagName('body')[0]).appendChild(ds);
+ })();
+ </script>
+
+
+
+
+
+
+
+</body>
+</html>
diff --git a/2015/06/11/coredump-02/index.html b/2015/06/11/coredump-02/index.html
new file mode 100644
index 0000000..c383891
--- /dev/null
+++ b/2015/06/11/coredump-02/index.html
@@ -0,0 +1,626 @@
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="coredump," />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
+</script>
+
+
+
+
+ <title> 使用gdb解析core dump-解析篇 // ArcherDing's Notes </title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column page-post-detail">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
+<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
+
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
+
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
+
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-expand">
+
+
+ <div class="post post-type-normal ">
+ <div class="post-header">
+
+
+
+ <h1 class="post-title">
+
+
+
+ 使用gdb解析core dump-解析篇
+
+
+ </h1>
+
+
+ <div class="post-meta">
+ <span class="post-time">
+ 发表于 2015-06-11
+ </span>
+
+
+ <span class="post-category">
+ | 分类于
+
+ <a href="/categories/coredump/">coredump</a>
+
+
+
+
+
+ </span>
+
+
+
+
+ <span class="post-comments-count">
+ |
+ <a href="/2015/06/11/coredump-02/#comments" >
+ <span class="post-comments-count ds-thread-count" data-thread-key="2015/06/11/coredump-02/"></span>
+ </a>
+ </span>
+
+
+ </div>
+ </div>
+
+ <div class="post-body">
+
+
+
+
+
+ <h3 id="Core_dump如何解析?">Core dump如何解析?</h3><p><code>man 7 signal</code>的结果给了我们一些提示,不妨我们来验证一下。</p>
+<h3 id="SIGQUIT信号下的Core_dump解析">SIGQUIT信号下的Core dump解析</h3><p><code>SIGABRT</code>信号表示用户在终端上按了退出键(一般采用Ctrl-\);使用之前用的helloworld程序,运行以后输入Ctrl+\;</p>
+<figure class="highlight elixir"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br></pre></td><td class="code"><pre><span class="line">archerding<span class="variable">@ubuntu</span><span class="symbol">:~</span><span class="variable">$ </span>./hello </span><br><span class="line"><span class="constant">Hello World!</span></span><br><span class="line"><span class="constant">Hello World!</span></span><br><span class="line"><span class="constant">Hello World!</span></span><br><span class="line"><span class="constant">Hello World!</span></span><br><span class="line">^\<span class="constant">Quit </span>(core dumped)</span><br><span class="line">archerding<span class="variable">@ubuntu</span><span class="symbol">:~</span><span class="variable">$ </span>ls /tmp/core/</span><br><span class="line">core-hello.<span class="number">2213</span></span><br></pre></td></tr></table></figure>
+<p>接下来开始解析这个core文件;错误提示非常明显<code>Program terminated with signal SIGQUIT, Quit.</code>;</p>
+<figure class="highlight nimrod"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br></pre></td><td class="code"><pre><span class="line">archerding@ubuntu:/tmp/core$ gdb ~/hello core-hello.<span class="number">2213</span></span><br><span class="line"><span class="type">GNU</span> gdb (<span class="type">Ubuntu</span> <span class="number">7</span>.<span class="number">9</span>-<span class="number">1</span>ubuntu1) <span class="number">7</span>.<span class="number">9</span></span><br><span class="line"><span class="type">Copyright</span> (C) <span class="number">2015</span> <span class="type">Free</span> <span class="type">Software</span> <span class="type">Foundation</span>, <span class="type">Inc</span>.</span><br><span class="line"><span class="type">License</span> <span class="type">GPLv3</span>+: <span class="type">GNU</span> <span class="type">GPL</span> version <span class="number">3</span> <span class="keyword">or</span> later <http://gnu.org/licenses/gpl.html></span><br><span class="line"><span class="type">This</span> <span class="keyword">is</span> free software: you are free to change <span class="keyword">and</span> redistribute it.</span><br><span class="line"><span class="type">There</span> <span class="keyword">is</span> <span class="type">NO</span> <span class="type">WARRANTY</span>, to the extent permitted by law. <span class="type">Type</span> <span class="string">"show copying"</span></span><br><span class="line"><span class="keyword">and</span> <span class="string">"show warranty"</span> <span class="keyword">for</span> details.</span><br><span class="line"><span class="type">This</span> <span class="type">GDB</span> was configured <span class="keyword">as</span> <span class="string">"x86_64-linux-gnu"</span>.</span><br><span class="line"><span class="type">Type</span> <span class="string">"show configuration"</span> <span class="keyword">for</span> configuration details.</span><br><span class="line"><span class="type">For</span> bug reporting instructions, please see:</span><br><span class="line"><http://www.gnu.org/software/gdb/bugs/>.</span><br><span class="line"><span class="type">Find</span> the <span class="type">GDB</span> manual <span class="keyword">and</span> other documentation resources online at:</span><br><span class="line"><http://www.gnu.org/software/gdb/documentation/>.</span><br><span class="line"><span class="type">For</span> help, <span class="keyword">type</span> <span class="string">"help"</span>.</span><br><span class="line"><span class="type">Type</span> <span class="string">"apropos word"</span> to search <span class="keyword">for</span> commands related to <span class="string">"word"</span>...</span><br><span class="line"><span class="type">Reading</span> symbols <span class="keyword">from</span> /home/archerding/hello...(no debugging symbols found)...done.</span><br><span class="line">[<span class="type">New</span> <span class="type">LWP</span> <span class="number">2213</span>]</span><br><span class="line"><span class="type">Core</span> was generated by `./hello'.</span><br><span class="line"><span class="type">Program</span> terminated <span class="keyword">with</span> signal <span class="type">SIGQUIT</span>, <span class="type">Quit</span>.</span><br><span class="line"><span class="comment">#0 0x00007f4e7d2a2c30 in __nanosleep_nocancel ()</span></span><br><span class="line"> at ../sysdeps/unix/syscall-<span class="keyword">template</span>.S:<span class="number">81</span></span><br><span class="line"><span class="number">81</span> ../sysdeps/unix/syscall-<span class="keyword">template</span>.S: <span class="type">No</span> such file <span class="keyword">or</span> directory.</span><br><span class="line">(gdb)</span><br></pre></td></tr></table></figure>
+<h3 id="SIGABRT信号下的Core_dump解析">SIGABRT信号下的Core dump解析</h3><p><code>SIGABRT</code>信号表示调用abort函数;编写新的测试程序,尝试调用一下<code>abort()</code>函数验证一下;</p>
+<figure class="highlight cpp"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br></pre></td><td class="code"><pre><span class="line"><span class="preprocessor">#<span class="keyword">include</span> <stdlib.h></span></span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">int</span> <span class="title">main</span><span class="params">()</span></span><br><span class="line"></span>{</span><br><span class="line"> <span class="built_in">abort</span>();</span><br><span class="line"> <span class="keyword">return</span> <span class="number">0</span>;</span><br><span class="line">}</span><br></pre></td></tr></table></figure>
+<p>编译执行,果真产生了core文件;</p>
+<figure class="highlight elixir"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><span class="line">archerding<span class="variable">@ubuntu</span><span class="symbol">:~</span><span class="variable">$ </span>gcc sigabort.c -o sigabort</span><br><span class="line">archerding<span class="variable">@ubuntu</span><span class="symbol">:~</span><span class="variable">$ </span>./sigabort </span><br><span class="line"><span class="constant">Aborted </span>(core dumped)</span><br><span class="line">archerding<span class="variable">@ubuntu</span><span class="symbol">:~</span><span class="variable">$ </span>ls /tmp/core/</span><br><span class="line">core-sigabort.<span class="number">2594</span></span><br></pre></td></tr></table></figure>
+<p>接下来开始解析这个core文件;错误提示非常明显<code>Program terminated with signal SIGABRT, Aborted.</code>;<br>使用<code>bt</code>打印栈信息,定位错误调用了<code>abort()</code>函数。</p>
+<figure class="highlight vhdl"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br></pre></td><td class="code"><pre><span class="line">archerding@ubuntu:/tmp/core$ gdb ~/sigabort core-sigabort.<span class="number">2594</span></span><br><span class="line">GNU gdb (Ubuntu <span class="number">7.9</span>-<span class="number">1</span>ubuntu1) <span class="number">7.9</span></span><br><span class="line">Copyright (C) <span class="number">2015</span> Free Software Foundation, Inc.</span><br><span class="line">License GPLv3+: GNU GPL version <span class="number">3</span> <span class="keyword">or</span> later <http://gnu.org/licenses/gpl.html></span><br><span class="line">This <span class="keyword">is</span> free software: you are free <span class="keyword">to</span> change <span class="keyword">and</span> redistribute it.</span><br><span class="line">There <span class="keyword">is</span> NO WARRANTY, <span class="keyword">to</span> the extent permitted by law. <span class="keyword">Type</span> <span class="string">"show copying"</span></span><br><span class="line"><span class="keyword">and</span> <span class="string">"show warranty"</span> <span class="keyword">for</span> details.</span><br><span class="line">This GDB was configured as <span class="string">"x86_64-linux-gnu"</span>.</span><br><span class="line"><span class="keyword">Type</span> <span class="string">"show configuration"</span> <span class="keyword">for</span> <span class="keyword">configuration</span> details.</span><br><span class="line"><span class="keyword">For</span> bug reporting instructions, please see:</span><br><span class="line"><http://www.gnu.org/software/gdb/bugs/>.</span><br><span class="line">Find the GDB manual <span class="keyword">and</span> other documentation resources online at:</span><br><span class="line"><http://www.gnu.org/software/gdb/documentation/>.</span><br><span class="line"><span class="keyword">For</span> help, <span class="keyword">type</span> <span class="string">"help"</span>.</span><br><span class="line"><span class="keyword">Type</span> <span class="string">"apropos word"</span> <span class="keyword">to</span> search <span class="keyword">for</span> commands related <span class="keyword">to</span> <span class="string">"word"</span>...</span><br><span class="line">Reading symbols from /home/archerding/sigabort...(no debugging symbols found)...done.</span><br><span class="line"></span><br><span class="line">warning: exec <span class="keyword">file</span> <span class="keyword">is</span> newer than core <span class="keyword">file</span>.</span><br><span class="line">[<span class="keyword">New</span> LWP <span class="number">2594</span>]</span><br><span class="line">Core was generated by `./sigabort'.</span><br><span class="line">Program terminated <span class="keyword">with</span> <span class="keyword">signal</span> SIGABRT, Aborted.</span><br><span class="line">#<span class="number">0</span> <span class="number">0</span>x00007ff6657bd267 <span class="keyword">in</span> __GI_raise (sig=sig@entry=<span class="number">6</span>)</span><br><span class="line"> at ../sysdeps/unix/sysv/linux/raise.c:<span class="number">55</span></span><br><span class="line"><span class="number">55</span> ../sysdeps/unix/sysv/linux/raise.c: No such <span class="keyword">file</span> <span class="keyword">or</span> directory.</span><br><span class="line">(gdb) bt</span><br><span class="line">#<span class="number">0</span> <span class="number">0</span>x00007ff6657bd267 <span class="keyword">in</span> __GI_raise (sig=sig@entry=<span class="number">6</span>)</span><br><span class="line"> at ../sysdeps/unix/sysv/linux/raise.c:<span class="number">55</span></span><br><span class="line">#<span class="number">1</span> <span class="number">0</span>x00007ff6657beeca <span class="keyword">in</span> __GI_abort () at abort.c:<span class="number">89</span></span><br><span class="line">#<span class="number">2</span> <span class="number">0</span>x000000000040053f <span class="keyword">in</span> main ()</span><br><span class="line">Print backtrace <span class="keyword">of</span> <span class="keyword">all</span> stack frames, <span class="keyword">or</span> innermost COUNT frames.</span><br><span class="line"><span class="keyword">With</span> a negative argument, print outermost -COUNT frames.</span><br><span class="line"><span class="keyword">Use</span> <span class="keyword">of</span> the <span class="attribute">'full</span>' qualifier also prints the values <span class="keyword">of</span> the local variables.</span><br><span class="line"><span class="keyword">Use</span> <span class="keyword">of</span> the <span class="attribute">'no</span>-filters' qualifier prohibits frame filters from executing</span><br><span class="line"><span class="keyword">on</span> this backtrace.</span><br><span class="line"></span><br><span class="line">(gdb)</span><br></pre></td></tr></table></figure>
+<h3 id="SIGFPE信号下的Core_dump解析">SIGFPE信号下的Core dump解析</h3><p><code>SIGFPE</code>信号表示一个算术运算异常,例如除以0,浮点溢出等;编写新的测试程序,尝试产生<code>SIGFPE</code>信号;</p>
+<figure class="highlight nimrod"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br></pre></td><td class="code"><pre><span class="line"><span class="comment">#include <stdlib.h></span></span><br><span class="line"></span><br><span class="line"><span class="type">int</span> calc(<span class="type">int</span> num)</span><br><span class="line">{</span><br><span class="line"> <span class="type">int</span> divider = <span class="number">0</span>;</span><br><span class="line"> <span class="type">int</span> <span class="literal">result</span> = <span class="number">0</span>;</span><br><span class="line"> <span class="literal">result</span> = num / divider;</span><br><span class="line"> <span class="keyword">return</span> <span class="literal">result</span>;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="type">int</span> main()</span><br><span class="line">{</span><br><span class="line"> calc(<span class="number">10</span>);</span><br><span class="line"> <span class="keyword">return</span> <span class="number">0</span>;</span><br><span class="line">}</span><br></pre></td></tr></table></figure>
+<p>编译执行,果真产生了core文件;</p>
+<figure class="highlight elixir"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><span class="line">archerding<span class="variable">@ubuntu</span><span class="symbol">:~</span><span class="variable">$ </span>gcc sigfpe.c -o sigfpe</span><br><span class="line">archerding<span class="variable">@ubuntu</span><span class="symbol">:~</span><span class="variable">$ </span>./sigfpe </span><br><span class="line"><span class="constant">Floating </span>point exception (core dumped)</span><br><span class="line">archerding<span class="variable">@ubuntu</span><span class="symbol">:~</span><span class="variable">$ </span>ls /tmp/core/</span><br><span class="line">core-sigfpe.<span class="number">2722</span></span><br></pre></td></tr></table></figure>
+<p>接下来开始解析这个core文件;错误提示<code>Program terminated with signal SIGFPE, Arithmetic exception.</code>;<br>使用<code>bt</code>打印栈信息,定位错误函数是<code>calc ()</code>函数;<br>使用<code>i r</code>打印寄存器信息,发现在调用到汇编指令地址<code>rip 0x40050f 0x40050f <calc+25></code>时出现异常;<br>使用<code>disas</code>反汇编问题函数,发现在调用<code>idivl -0x8(%rbp)</code>时出错,该汇编指令是做除法运算;<br>使用<code>x $rbp-0x8</code>打印除数,发现除数为0。</p>
+<figure class="highlight stata"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br><span class="line">49</span><br><span class="line">50</span><br><span class="line">51</span><br><span class="line">52</span><br><span class="line">53</span><br><span class="line">54</span><br><span class="line">55</span><br><span class="line">56</span><br><span class="line">57</span><br><span class="line">58</span><br><span class="line">59</span><br><span class="line">60</span><br><span class="line">61</span><br><span class="line">62</span><br><span class="line">63</span><br><span class="line">64</span><br><span class="line">65</span><br><span class="line">66</span><br></pre></td><td class="code"><pre><span class="line">archerding@ubuntu:/tmp/core$ gdb ~/sigfpe core-sigfpe.2722</span><br><span class="line">GNU gdb (Ubuntu 7.9-1ubuntu1) 7.9</span><br><span class="line"><span class="keyword">Copyright</span> (C) 2015 Free Software Foundation, Inc.</span><br><span class="line">License GPLv3+: GNU GPL <span class="keyword">version</span> 3 or later <http:<span class="comment">//gnu.org/licenses/gpl.html></span></span><br><span class="line">This is free software: you are free to change and redistribute it.</span><br><span class="line">There is <span class="keyword">NO</span> WARRANTY, to the extent permitted <span class="keyword">by</span> law. <span class="keyword">Type</span> <span class="string">"show copying"</span></span><br><span class="line">and <span class="string">"show warranty"</span> <span class="keyword">for</span> details.</span><br><span class="line">This GDB was configured <span class="keyword">as</span> <span class="string">"x86_64-linux-gnu"</span>.</span><br><span class="line"><span class="keyword">Type</span> <span class="string">"show configuration"</span> <span class="keyword">for</span> configuration details.</span><br><span class="line"><span class="keyword">For</span> bug reporting instructions, please see:</span><br><span class="line"><http:<span class="comment">//www.gnu.org/software/gdb/bugs/>.</span></span><br><span class="line">Find the GDB manual and other documentation resources online at:</span><br><span class="line"><http:<span class="comment">//www.gnu.org/software/gdb/documentation/>.</span></span><br><span class="line"><span class="keyword">For</span> <span class="keyword">help</span>, <span class="keyword">type</span> <span class="string">"help"</span>.</span><br><span class="line"><span class="keyword">Type</span> <span class="string">"apropos word"</span> to <span class="keyword">search</span> <span class="keyword">for</span> commands related to <span class="string">"word"</span>...</span><br><span class="line">Reading symbols from /home/archerding/sigfpe...(<span class="keyword">no</span> debugging symbols found)...done.</span><br><span class="line">[New LWP 2722]</span><br><span class="line">Core was generated <span class="keyword">by</span> `./sigfpe'.</span><br><span class="line"><span class="keyword">Program</span> terminated with signal SIGFPE, Arithmetic exception.</span><br><span class="line">#0 0x000000000040050f <span class="keyword">in</span> calc ()</span><br><span class="line">(gdb) bt</span><br><span class="line">#0 0x000000000040050f <span class="keyword">in</span> calc ()</span><br><span class="line">#1 0x0000000000400528 <span class="keyword">in</span> main ()</span><br><span class="line">(gdb) i <span class="literal">r</span></span><br><span class="line">rax 0xa 10</span><br><span class="line">rbx 0x0 0</span><br><span class="line">rcx 0x0 0</span><br><span class="line">rdx 0x0 0</span><br><span class="line">rsi 0x7ffcb45b2198 140723334357400</span><br><span class="line">rdi 0xa 10</span><br><span class="line">rbp 0x7ffcb45b20a0 0x7ffcb45b20a0</span><br><span class="line">rsp 0x7ffcb45b20a0 0x7ffcb45b20a0</span><br><span class="line">r8 0x7ff8d052ddd0 140706623708624</span><br><span class="line">r9 0x7ff8d05489d0 140706623818192</span><br><span class="line">r10 0x833 2099</span><br><span class="line">r11 0x7ff8d0188950 140706619885904</span><br><span class="line">r12 0x400400 4195328</span><br><span class="line">r13 0x7ffcb45b2190 140723334357392</span><br><span class="line">r14 0x0 0</span><br><span class="line">r15 0x0 0</span><br><span class="line">rip 0x40050f 0x40050f <calc+25></span><br><span class="line">eflags 0x10246 [ PF ZF <span class="keyword">IF</span> RF ]</span><br><span class="line"><span class="keyword">cs</span> 0x33 51</span><br><span class="line">ss 0x2b 43</span><br><span class="line"><span class="keyword">ds</span> 0x0 0</span><br><span class="line">es 0x0 0</span><br><span class="line">fs 0x0 0</span><br><span class="line">---<span class="keyword">Type</span> <<span class="keyword">return</span>> to <span class="keyword">continue</span>, or q <<span class="keyword">return</span>> to quit---</span><br><span class="line">gs 0x0 0</span><br><span class="line">(gdb) disas</span><br><span class="line">Dump of assembler code <span class="keyword">for</span> function calc:</span><br><span class="line"> 0x00000000004004f6 <+0>: push %rbp</span><br><span class="line"> 0x00000000004004f7 <+1>: <span class="keyword">mov</span> %rsp,%rbp</span><br><span class="line"> 0x00000000004004fa <+4>: <span class="keyword">mov</span> %<span class="keyword">edi</span>,-0x14(%rbp)</span><br><span class="line"> 0x00000000004004fd <+7>: movl <span class="label">$0x0</span>,-0x8(%rbp)</span><br><span class="line"> 0x0000000000400504 <+14>: movl <span class="label">$0x0</span>,-0x4(%rbp)</span><br><span class="line"> 0x000000000040050b <+21>: <span class="keyword">mov</span> -0x14(%rbp),%eax</span><br><span class="line"> 0x000000000040050e <+24>: cltd </span><br><span class="line">=> 0x000000000040050f <+25>: idivl -0x8(%rbp)</span><br><span class="line"> 0x0000000000400512 <+28>: <span class="keyword">mov</span> %eax,-0x4(%rbp)</span><br><span class="line"> 0x0000000000400515 <+31>: <span class="keyword">mov</span> -0x4(%rbp),%eax</span><br><span class="line"> 0x0000000000400518 <+34>: pop %rbp</span><br><span class="line"> 0x0000000000400519 <+35>: retq </span><br><span class="line">End of assembler dump.</span><br><span class="line">(gdb) x <span class="label">$rbp</span>-0x8</span><br><span class="line">0x7ffcb45b2098: 0x00000000</span><br></pre></td></tr></table></figure>
+<h3 id="SIGSEGV信号下的Core_dump解析">SIGSEGV信号下的Core dump解析</h3><p><code>SIGSEGV</code>信号表示进程进行了一次无效的存储访问,EGV表示段违例(segmentation violation);编写新的测试程序,尝试产生<code>SIGSEGV</code>信号;</p>
+<figure class="highlight cpp"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br></pre></td><td class="code"><pre><span class="line"><span class="preprocessor">#<span class="keyword">include</span> <stdlib.h></span></span><br><span class="line"></span><br><span class="line"><span class="keyword">const</span> <span class="keyword">char</span> *str = <span class="string">"hello World!"</span>;</span><br><span class="line"> </span><br><span class="line"><span class="function"><span class="keyword">void</span> <span class="title">mod_str</span><span class="params">()</span></span><br><span class="line"></span>{</span><br><span class="line"> str[<span class="number">0</span>] = <span class="string">'H'</span>;</span><br><span class="line">}</span><br><span class="line"></span><br><span class="line"><span class="function"><span class="keyword">int</span> <span class="title">main</span><span class="params">()</span></span><br><span class="line"></span>{</span><br><span class="line"> mod_str();</span><br><span class="line"> <span class="keyword">return</span> <span class="number">0</span>;</span><br><span class="line">}</span><br></pre></td></tr></table></figure>
+<p>编译执行,果真产生了core文件;</p>
+<figure class="highlight elixir"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><span class="line">archerding<span class="variable">@ubuntu</span><span class="symbol">:~</span><span class="variable">$ </span>gcc sigsegv.c -o sigsegv</span><br><span class="line">archerding<span class="variable">@ubuntu</span><span class="symbol">:~</span><span class="variable">$ </span>./sigsegv </span><br><span class="line"><span class="constant">Segmentation </span>fault (core dumped)</span><br><span class="line">archerding<span class="variable">@ubuntu</span><span class="symbol">:~</span><span class="variable">$ </span>ls /tmp/core/</span><br><span class="line">core-sigsegv.<span class="number">2856</span></span><br></pre></td></tr></table></figure>
+<p>接下来开始解析这个core文件;错误提示<code>Program terminated with signal SIGSEGV, Segmentation fault.</code>;<br>使用<code>bt</code>打印栈信息,定位错误函数是<code>mod_str()</code>函数;<br>使用<code>i r</code>打印寄存器信息,发现在调用到汇编指令地址<code>rip 0x400509 0x400509 <mod_str+19></code>时出现异常;<br>使用<code>disas</code>反汇编问题函数,发现在调用<code>movb $0x48,(%rax)</code>时出错;<br>使用<code>x /16s $rax</code>打印错误地址指向的内存,发现改地址是<code>0x4005b4</code>指向了字符串<code>hello World!</code>;<br>使用<code>info proc map</code>查看内存映射,处于第一个区域内。</p>
+<figure class="highlight dns"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br><span class="line">49</span><br><span class="line">50</span><br><span class="line">51</span><br><span class="line">52</span><br><span class="line">53</span><br><span class="line">54</span><br><span class="line">55</span><br><span class="line">56</span><br><span class="line">57</span><br><span class="line">58</span><br><span class="line">59</span><br><span class="line">60</span><br><span class="line">61</span><br><span class="line">62</span><br><span class="line">63</span><br><span class="line">64</span><br><span class="line">65</span><br><span class="line">66</span><br><span class="line">67</span><br><span class="line">68</span><br><span class="line">69</span><br><span class="line">70</span><br><span class="line">71</span><br><span class="line">72</span><br><span class="line">73</span><br><span class="line">74</span><br><span class="line">75</span><br><span class="line">76</span><br><span class="line">77</span><br><span class="line">78</span><br><span class="line">79</span><br><span class="line">80</span><br><span class="line">81</span><br><span class="line">82</span><br><span class="line">83</span><br><span class="line">84</span><br><span class="line">85</span><br><span class="line">86</span><br><span class="line">87</span><br><span class="line">88</span><br><span class="line">89</span><br><span class="line">90</span><br><span class="line">91</span><br></pre></td><td class="code"><pre><span class="line">archerding@ubuntu:/tmp/core$ gdb ~/sigsegv core-sigsegv.2856</span><br><span class="line">GNU gdb (Ubuntu 7.9-1ubuntu1) 7.9</span><br><span class="line">Copyright (C) 2015 Free Software Foundation, Inc.</span><br><span class="line">License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html></span><br><span class="line">This is free software: you are free to change and redistribute it.</span><br><span class="line">There is NO WARRANTY, to the extent permitted by law. Type "show copying"</span><br><span class="line">and "show warranty" for details.</span><br><span class="line">This GDB was configured as "x86_64-linux-gnu".</span><br><span class="line">Type "show configuration" for configuration details.</span><br><span class="line">For bug reporting instructions, please see:</span><br><span class="line"><http://www.gnu.org/software/gdb/bugs/>.</span><br><span class="line">Find the GDB manual and other documentation resources online at:</span><br><span class="line"><http://www.gnu.org/software/gdb/documentation/>.</span><br><span class="line">For help, type "help".</span><br><span class="line">Type "apropos word" to search for commands related to "word"...</span><br><span class="line">Reading symbols from /home/archerding/sigsegv...(no debugging symbols found)...done.</span><br><span class="line">[New LWP 2856]</span><br><span class="line">Core was generated by `./sigsegv'.</span><br><span class="line">Program terminated with signal SIGSEGV, Segmentation fault.</span><br><span class="line">#0 <span class="number">0x00000000</span><span class="number">00400509</span> in mod_str ()</span><br><span class="line">(gdb) bt</span><br><span class="line">#0 <span class="number">0x00000000</span><span class="number">00400509</span> in mod_str ()</span><br><span class="line">#1 <span class="number">0x00000000</span><span class="number">0040051</span>c in main ()</span><br><span class="line">(gdb) i r</span><br><span class="line">rax <span class="number">0x4005b4</span> <span class="number">4195764</span></span><br><span class="line">rbx 0x0 0</span><br><span class="line">rcx 0x0 0</span><br><span class="line">rdx 0x7fff284dc<span class="number">488 140733</span><span class="number">869573256</span></span><br><span class="line">rsi 0x7fff284dc<span class="number">478 140733</span><span class="number">869573240</span></span><br><span class="line">rdi 0x1 1</span><br><span class="line">rbp 0x7fff284dc<span class="number">380 0x7</span>fff284dc380</span><br><span class="line">rsp 0x7fff284dc<span class="number">380 0x7</span>fff284dc380</span><br><span class="line">r8 <span class="number">0x7f590</span>a295dd<span class="number">0 1400203993</span>00048</span><br><span class="line">r9 <span class="number">0x7f590</span>a<span class="number">2b09d0 140</span><span class="number">02039940961</span>6</span><br><span class="line">r10 <span class="number">0x833 209</span>9</span><br><span class="line">r11 <span class="number">0x7f5909</span>ef<span class="number">0950 1400203</span><span class="number">95477328</span></span><br><span class="line">r12 <span class="number">0x400400</span> <span class="number">4195328</span></span><br><span class="line">r13 0x7fff284dc<span class="number">470 140733</span><span class="number">869573232</span></span><br><span class="line">r14 0x0 0</span><br><span class="line">r15 0x0 0</span><br><span class="line">rip <span class="number">0x400509</span> <span class="number">0x400509</span> <mod_str+19></span><br><span class="line">eflags <span class="number">0x10246</span> [ PF ZF IF RF ]</span><br><span class="line">cs 0x33 51</span><br><span class="line">ss 0x2b 43</span><br><span class="line">ds 0x0 0</span><br><span class="line">es 0x0 0</span><br><span class="line">fs 0x0 0</span><br><span class="line">---Type <return> to continue, or q <return> to quit---</span><br><span class="line">gs 0x0 0</span><br><span class="line">(gdb) disas</span><br><span class="line">Dump of assembler code for function mod_str:</span><br><span class="line"> <span class="number">0x00000000</span><span class="number">004004f6</span> <+0>: push %rbp</span><br><span class="line"> <span class="number">0x00000000</span><span class="number">004004f7</span> <+1>: mov %rsp,%rbp</span><br><span class="line"> <span class="number">0x00000000</span>004004fa <+4>: mov <span class="number">0x200b37</span>(%rip),%rax # <span class="number">0x601038</span> <str></span><br><span class="line"> <span class="number">0x00000000</span><span class="number">00400501</span> <+11>: mov %rax,-0x8(%rbp)</span><br><span class="line"> <span class="number">0x00000000</span><span class="number">00400505</span> <+15>: mov -0x8(%rbp),%rax</span><br><span class="line">=> <span class="number">0x00000000</span><span class="number">00400509</span> <+19>: movb $0x48,(%rax)</span><br><span class="line"> <span class="number">0x00000000</span><span class="number">0040050</span>c <+22>: pop %rbp</span><br><span class="line"> <span class="number">0x00000000</span><span class="number">0040050</span>d <+23>: retq </span><br><span class="line">End of assembler dump.</span><br><span class="line">(gdb) x /16s $rax</span><br><span class="line"><span class="number">0x4005b4</span>: "hello World!"</span><br><span class="line"><span class="number">0x4005c1</span>: ""</span><br><span class="line"><span class="number">0x4005c2</span>: ""</span><br><span class="line"><span class="number">0x4005c3</span>: ""</span><br><span class="line"><span class="number">0x4005c4</span>: "\<span class="number">001\033</span>\003<span class="comment">;8"</span></span><br><span class="line">0x4005ca: ""</span><br><span class="line">0x4005cb: ""</span><br><span class="line">0x4005cc: "\006"</span><br><span class="line">0x4005ce: ""</span><br><span class="line">0x4005cf: ""</span><br><span class="line"><span class="number">0x4005d0</span>: "\f\<span class="number">376\377</span>\<span class="number">377\204</span>"</span><br><span class="line"><span class="number">0x4005d6</span>: ""</span><br><span class="line"><span class="number">0x4005d7</span>: ""</span><br><span class="line"><span class="number">0x4005d8</span>: "<\<span class="number">376\377</span>\377T"</span><br><span class="line">0x4005de: ""</span><br><span class="line">0x4005df: ""</span><br><span class="line">(gdb) info proc map</span><br><span class="line">Mapped address spaces:</span><br><span class="line"></span><br><span class="line"> Start Addr End Addr Size Offset objfile</span><br><span class="line"> <span class="number">0x400000</span> <span class="number">0x401000</span> 0x1000 0x0 /home/archerding/sigsegv</span><br><span class="line"> <span class="number">0x600000</span> <span class="number">0x601000</span> 0x1000 0x0 /home/archerding/sigsegv</span><br><span class="line"> <span class="number">0x601000</span> <span class="number">0x602000</span> 0x1000 0x1000 /home/archerding/sigsegv</span><br><span class="line"> <span class="number">0x7f5909</span>ed0000 <span class="number">0x7f590</span>a090000 <span class="number">0x1c0000</span> 0x0 /lib/x86_64-linux-gnu/libc-2.21.so</span><br><span class="line"> <span class="number">0x7f590</span>a090000 <span class="number">0x7f590</span>a290000 <span class="number">0x200000</span> <span class="number">0x1c0000</span> /lib/x86_64-linux-gnu/libc-2.21.so</span><br><span class="line"> <span class="number">0x7f590</span>a290000 <span class="number">0x7f590</span>a294000 0x4000 <span class="number">0x1c0000</span> /lib/x86_64-linux-gnu/libc-2.21.so</span><br><span class="line"> <span class="number">0x7f590</span>a294000 <span class="number">0x7f590</span>a296000 0x2000 <span class="number">0x1c4000</span> /lib/x86_64-linux-gnu/libc-2.21.so</span><br><span class="line"> <span class="number">0x7f590</span>a2a0000 <span class="number">0x7f590</span>a2c4000 <span class="number">0x24000</span> 0x0 /lib/x86_64-linux-gnu/ld-2.21.so</span><br><span class="line"> <span class="number">0x7f590</span>a4c3000 <span class="number">0x7f590</span>a4c4000 0x1000 <span class="number">0x23000</span> /lib/x86_64-linux-gnu/ld-2.21.so</span><br><span class="line">(gdb)</span><br></pre></td></tr></table></figure>
+<p>接下来使用<code>objdump -t ~/sigsegv</code>进一步确认,发现在修改<code>.rodata</code>段时出错,该段用来保存常量。</p>
+<figure class="highlight dns"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br><span class="line">49</span><br><span class="line">50</span><br><span class="line">51</span><br><span class="line">52</span><br><span class="line">53</span><br><span class="line">54</span><br><span class="line">55</span><br><span class="line">56</span><br><span class="line">57</span><br><span class="line">58</span><br><span class="line">59</span><br><span class="line">60</span><br><span class="line">61</span><br><span class="line">62</span><br><span class="line">63</span><br><span class="line">64</span><br><span class="line">65</span><br><span class="line">66</span><br><span class="line">67</span><br><span class="line">68</span><br><span class="line">69</span><br><span class="line">70</span><br></pre></td><td class="code"><pre><span class="line">archerding@ubuntu:/tmp/core$ objdump -t ~/sigsegv</span><br><span class="line"></span><br><span class="line">/home/archerding/sigsegv: file format elf64-x86-64</span><br><span class="line"></span><br><span class="line">SYMBOL TABLE:</span><br><span class="line"><span class="number">00000000004</span>00238 l d .interp <span class="number">00000000000</span>00000 .interp</span><br><span class="line"><span class="number">00000000004</span>00254 l d .note.ABI-tag <span class="number">00000000000</span>00000 .note.ABI-tag</span><br><span class="line"><span class="number">00000000004</span>00274 l d .note.gnu.build-id <span class="number">00000000000</span>00000 .note.gnu.build-id</span><br><span class="line"><span class="number">00000000004</span>00298 l d .gnu.hash <span class="number">00000000000</span>00000 .gnu.hash</span><br><span class="line"><span class="number">00000000004</span>002b8 l d .dynsym <span class="number">00000000000</span>00000 .dynsym</span><br><span class="line"><span class="number">00000000004</span>00300 l d .dynstr <span class="number">00000000000</span>00000 .dynstr</span><br><span class="line"><span class="number">00000000004</span>00338 l d .gnu.version <span class="number">00000000000</span>00000 .gnu.version</span><br><span class="line"><span class="number">00000000004</span>00340 l d .gnu.version_r <span class="number">00000000000</span>00000 .gnu.version_r</span><br><span class="line"><span class="number">00000000004</span>00360 l d .rela.dyn <span class="number">00000000000</span>00000 .rela.dyn</span><br><span class="line"><span class="number">00000000004</span>00378 l d .rela.plt <span class="number">00000000000</span>00000 .rela.plt</span><br><span class="line"><span class="number">00000000004</span>003a8 l d .init <span class="number">00000000000</span>00000 .init</span><br><span class="line"><span class="number">00000000004</span>003d0 l d .plt <span class="number">00000000000</span>00000 .plt</span><br><span class="line"><span class="number">00000000004</span>00400 l d .text <span class="number">00000000000</span>00000 .text</span><br><span class="line"><span class="number">00000000004</span>005a4 l d .fini <span class="number">00000000000</span>00000 .fini</span><br><span class="line"><span class="number">00000000004</span>005b0 l d .rodata <span class="number">00000000000</span>00000 .rodata</span><br><span class="line"><span class="number">00000000004</span>005c4 l d .eh_frame_hdr <span class="number">00000000000</span>00000 .eh_frame_hdr</span><br><span class="line"><span class="number">00000000004</span>00600 l d .eh_frame <span class="number">00000000000</span>00000 .eh_frame</span><br><span class="line"><span class="number">00000000006</span>00e10 l d .init_array <span class="number">00000000000</span>00000 .init_array</span><br><span class="line"><span class="number">00000000006</span>00e18 l d .fini_array <span class="number">00000000000</span>00000 .fini_array</span><br><span class="line"><span class="number">00000000006</span>00e20 l d .jcr <span class="number">00000000000</span>00000 .jcr</span><br><span class="line"><span class="number">00000000006</span>00e28 l d .dynamic <span class="number">00000000000</span>00000 .dynamic</span><br><span class="line"><span class="number">00000000006</span>00ff8 l d .got <span class="number">00000000000</span>00000 .got</span><br><span class="line"><span class="number">00000000006</span>01000 l d .got.plt <span class="number">00000000000</span>00000 .got.plt</span><br><span class="line"><span class="number">00000000006</span>01028 l d .data <span class="number">00000000000</span>00000 .data</span><br><span class="line"><span class="number">00000000006</span>01040 l d .bss <span class="number">00000000000</span>00000 .bss</span><br><span class="line"><span class="number">00000000000</span>00000 l d .comment <span class="number">00000000000</span>00000 .comment</span><br><span class="line"><span class="number">00000000000</span>00000 l df *ABS* <span class="number">00000000000</span>00000 crtstuff.c</span><br><span class="line"><span class="number">00000000006</span>00e20 l O .jcr <span class="number">00000000000</span>00000 __JCR_LIST__</span><br><span class="line"><span class="number">00000000004</span>00430 l F .text <span class="number">00000000000</span>00000 deregister_tm_clones</span><br><span class="line"><span class="number">00000000004</span>00470 l F .text <span class="number">00000000000</span>00000 register_tm_clones</span><br><span class="line"><span class="number">00000000004</span>004b0 l F .text <span class="number">00000000000</span>00000 __do_global_dtors_aux</span><br><span class="line"><span class="number">00000000006</span>01040 l O .bss <span class="number">00000000000</span>00001 completed.7291</span><br><span class="line"><span class="number">00000000006</span>00e18 l O .fini_array <span class="number">00000000000</span>00000 __do_global_dtors_aux_fini_array_entry</span><br><span class="line"><span class="number">00000000004</span>004d0 l F .text <span class="number">00000000000</span>00000 frame_dummy</span><br><span class="line"><span class="number">00000000006</span>00e10 l O .init_array <span class="number">00000000000</span>00000 __frame_dummy_init_array_entry</span><br><span class="line"><span class="number">00000000000</span>00000 l df *ABS* <span class="number">00000000000</span>00000 sigsegv.c</span><br><span class="line"><span class="number">00000000000</span>00000 l df *ABS* <span class="number">00000000000</span>00000 crtstuff.c</span><br><span class="line"><span class="number">00000000004</span>00710 l O .eh_frame <span class="number">00000000000</span>00000 __FRAME_END__</span><br><span class="line"><span class="number">00000000006</span>00e20 l O .jcr <span class="number">00000000000</span>00000 __JCR_END__</span><br><span class="line"><span class="number">00000000000</span>00000 l df *ABS* <span class="number">00000000000</span>00000 </span><br><span class="line"><span class="number">00000000006</span>00e18 l .init_array <span class="number">00000000000</span>00000 __init_array_end</span><br><span class="line"><span class="number">00000000006</span>00e28 l O .dynamic <span class="number">00000000000</span>00000 _DYNAMIC</span><br><span class="line"><span class="number">00000000006</span>00e10 l .init_array <span class="number">00000000000</span>00000 __init_array_start</span><br><span class="line"><span class="number">00000000006</span>01000 l O .got.plt <span class="number">00000000000</span>00000 _GLOBAL_OFFSET_TABLE_</span><br><span class="line"><span class="number">00000000004</span>005a0 g F .text <span class="number">00000000000</span>00002 __libc_csu_fini</span><br><span class="line"><span class="number">00000000000</span>00000 w *UND* <span class="number">00000000000</span>00000 _ITM_deregisterTMCloneTable</span><br><span class="line"><span class="number">00000000006</span>01028 w .data <span class="number">00000000000</span>00000 data_start</span><br><span class="line"><span class="number">00000000006</span>01040 g .data <span class="number">00000000000</span>00000 _edata</span><br><span class="line"><span class="number">00000000004</span>005a4 g F .fini <span class="number">00000000000</span>00000 _fini</span><br><span class="line"><span class="number">00000000000</span>00000 F *UND* <span class="number">00000000000</span>00000 __libc_start_main@@GLIBC_2.2.5</span><br><span class="line"><span class="number">00000000006</span>01028 g .data <span class="number">00000000000</span>00000 __data_start</span><br><span class="line"><span class="number">00000000000</span>00000 w *UND* <span class="number">00000000000</span>00000 __gmon_start__</span><br><span class="line"><span class="number">00000000006</span>01030 g O .data <span class="number">00000000000</span>00000 .hidden __dso_handle</span><br><span class="line"><span class="number">00000000004</span>004f6 g F .text <span class="number">00000000000</span>00018 mod_str</span><br><span class="line"><span class="number">00000000004</span>005b0 g O .rodata <span class="number">00000000000</span>00004 _IO_stdin_used</span><br><span class="line"><span class="number">00000000004</span>00530 g F .text <span class="number">00000000000</span>00065 __libc_csu_init</span><br><span class="line"><span class="number">00000000006</span>01048 g .bss <span class="number">00000000000</span>00000 _end</span><br><span class="line"><span class="number">00000000004</span>00400 g F .text <span class="number">00000000000</span>0002a _start</span><br><span class="line"><span class="number">00000000006</span>01038 g O .data <span class="number">00000000000</span>00008 str</span><br><span class="line"><span class="number">00000000006</span>01040 g .bss <span class="number">00000000000</span>00000 __bss_start</span><br><span class="line"><span class="number">00000000004</span>0050e g F .text <span class="number">00000000000</span>00015 main</span><br><span class="line"><span class="number">00000000000</span>00000 w *UND* <span class="number">00000000000</span>00000 _Jv_RegisterClasses</span><br><span class="line"><span class="number">00000000006</span>01040 g O .data <span class="number">00000000000</span>00000 .hidden __TMC_END__</span><br><span class="line"><span class="number">00000000000</span>00000 w *UND* <span class="number">00000000000</span>00000 _ITM_registerTMCloneTable</span><br><span class="line"><span class="number">00000000004</span>003a8 g F .init <span class="number">00000000000</span>00000 _init</span><br></pre></td></tr></table></figure>
+
+ </div>
+
+ <div class="post-footer">
+
+ <div class="post-tags">
+
+ <a href="/tags/coredump/"> #coredump </a>
+
+ </div>
+
+
+
+ <div class="post-nav">
+ <div class="post-nav-prev post-nav-item">
+
+ </div>
+
+ <div class="post-nav-next post-nav-item">
+
+ <a href="/2015/06/06/coredump-01/">使用gdb解析core dump-概念篇</a>
+
+ </div>
+ </div>
+
+
+
+
+ </div>
+ </div>
+
+
+
+
+
+
+ <div class="comments" id="comments">
+
+ <div class="ds-thread" data-thread-key="2015/06/11/coredump-02/"
+ data-title="使用gdb解析core dump-解析篇" data-url="http://archerding.github.io/2015/06/11/coredump-02/">
+ </div>
+
+ </div>
+
+ </div>
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+ <ul class="sidebar-nav motion-element">
+ <li class="sidebar-nav-toc sidebar-nav-active" data-target="post-toc-wrap">
+ 文章目录
+ </li>
+ <li class="sidebar-nav-overview" data-target="site-overview">
+ 站点概览
+ </li>
+ </ul>
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+ <div class="post-toc-wrap sidebar-panel-active">
+ <div class="post-toc-indicator-top post-toc-indicator"></div>
+ <div class="post-toc">
+
+
+ <div class="post-toc-content"><ol class="nav"><li class="nav-item nav-level-3"><a class="nav-link" href="#Core_dump如何解析?"><span class="nav-number">1.</span> <span class="nav-text">Core dump如何解析?</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#SIGQUIT信号下的Core_dump解析"><span class="nav-number">2.</span> <span class="nav-text">SIGQUIT信号下的Core dump解析</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#SIGABRT信号下的Core_dump解析"><span class="nav-number">3.</span> <span class="nav-text">SIGABRT信号下的Core dump解析</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#SIGFPE信号下的Core_dump解析"><span class="nav-number">4.</span> <span class="nav-text">SIGFPE信号下的Core dump解析</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#SIGSEGV信号下的Core_dump解析"><span class="nav-number">5.</span> <span class="nav-text">SIGSEGV信号下的Core dump解析</span></a></li></ol></div>
+
+ </div>
+ <div class="post-toc-indicator-bottom post-toc-indicator"></div>
+ </div>
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+<script type="text/javascript" src="/js/bootstrap.scrollspy.js?v=0.4.3" id="bootstrap.scrollspy.custom"></script>
+
+
+<script type="text/javascript" id="sidebar.toc.highlight">
+ $(document).ready(function () {
+ var tocSelector = '.post-toc';
+ var $tocSelector = $(tocSelector);
+ var activeCurrentSelector = '.active-current';
+
+ $tocSelector
+ .on('activate.bs.scrollspy', function () {
+ var $currentActiveElement = $(tocSelector + ' .active').last();
+
+ removeCurrentActiveClass();
+ $currentActiveElement.addClass('active-current');
+
+ $tocSelector[0].scrollTop = $currentActiveElement.position().top;
+ })
+ .on('clear.bs.scrollspy', function () {
+ removeCurrentActiveClass();
+ });
+
+ function removeCurrentActiveClass () {
+ $(tocSelector + ' ' + activeCurrentSelector)
+ .removeClass(activeCurrentSelector.substring(1));
+ }
+
+ function processTOC () {
+ getTOCMaxHeight();
+ toggleTOCOverflowIndicators();
+ }
+
+ function getTOCMaxHeight () {
+ var $sidebarInner = $('.sidebar-inner');
+ var height = $('.sidebar').height() -
+ $tocSelector.position().top -
+ $('.post-toc-indicator-bottom').height();
+
+ $tocSelector.css('height', height);
+
+ return height;
+ }
+
+ function toggleTOCOverflowIndicators () {
+ tocOverflowIndicator(
+ '.post-toc-indicator-top',
+ $tocSelector.scrollTop() > 0 ? 'show' : 'hide'
+ );
+
+ tocOverflowIndicator(
+ '.post-toc-indicator-bottom',
+ $tocSelector.scrollTop() >= $tocSelector.find('ol').height() - $tocSelector.height() ? 'hide' : 'show'
+ )
+ }
+
+ $(document).on('sidebar.didShow', function () {
+ processTOC();
+ });
+
+ $('body').scrollspy({ target: tocSelector });
+ $(window).on('resize', function () {
+ if ( $('.sidebar').hasClass('sidebar-active') ) {
+ processTOC();
+ }
+ });
+
+ onScroll($tocSelector);
+
+ function onScroll (element) {
+ element.on('mousewheel DOMMouseScroll', function (event) {
+ var oe = event.originalEvent;
+ var delta = oe.wheelDelta || -oe.detail;
+ var self = this;
+
+ this.scrollTop += ( delta < 0 ? 1 : -1 ) * 30;
+ event.preventDefault();
+
+ toggleTOCOverflowIndicators();
+ });
+ }
+
+ function tocOverflowIndicator (indicator, action) {
+ $(indicator).velocity('stop').velocity({
+ opacity: action === 'show' ? 0.4 : 0
+ }, { duration: 100 });
+ }
+
+ });
+</script>
+
+
+ <script type="text/javascript" id="sidebar.nav">
+ $(document).ready(function () {
+ var html = $('html');
+
+ $('.sidebar-nav li').on('click', function () {
+ var item = $(this);
+ var activeTabClassName = 'sidebar-nav-active';
+ var activePanelClassName = 'sidebar-panel-active';
+ if (item.hasClass(activeTabClassName)) {
+ return;
+ }
+
+ var currentTarget = $('.' + activePanelClassName);
+ var target = $('.' + item.data('target'));
+
+ currentTarget.velocity('transition.slideUpOut', 200, function () {
+ target
+ .velocity('stop')
+ .velocity('transition.slideDownIn', 200)
+ .addClass(activePanelClassName);
+ });
+
+ item.siblings().removeClass(activeTabClassName);
+ item.addClass(activeTabClassName);
+ });
+
+ $('.post-toc a').on('click', function (e) {
+ e.preventDefault();
+ var offset = $(escapeSelector(this.getAttribute('href'))).offset().top;
+ html.velocity('stop').velocity('scroll', {
+ offset: offset + 'px',
+ mobileHA: false
+ });
+ });
+
+ // Expand sidebar on post detail page by default, when post has a toc.
+ var $tocContent = $('.post-toc-content');
+ if (isDesktop() && CONFIG.sidebar === 'post') {
+ if ($tocContent.length > 0 && $tocContent.html().trim().length > 0) {
+ displaySidebar();
+ }
+ }
+ });
+ </script>
+
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+
+
+ <script type="text/javascript">
+ var duoshuoQuery = {short_name:"archerding"};
+ (function() {
+ var ds = document.createElement('script');
+ ds.type = 'text/javascript';ds.async = true;
+ ds.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') + '//static.duoshuo.com/embed.js';
+ ds.charset = 'UTF-8';
+ (document.getElementsByTagName('head')[0]
+ || document.getElementsByTagName('body')[0]).appendChild(ds);
+ })();
+ </script>
+
+
+
+
+
+
+
+</body>
+</html>
diff --git "a/Golang/\345\210\206\345\270\203\345\274\217\347\253\257\345\217\243\346\230\240\345\260\204NetMapping\347\232\204\350\256\276\350\256\241\344\270\216\345\256\236\347\216\260/index.html" "b/Golang/\345\210\206\345\270\203\345\274\217\347\253\257\345\217\243\346\230\240\345\260\204NetMapping\347\232\204\350\256\276\350\256\241\344\270\216\345\256\236\347\216\260/index.html"
deleted file mode 100644
index 28ccf09..0000000
--- "a/Golang/\345\210\206\345\270\203\345\274\217\347\253\257\345\217\243\346\230\240\345\260\204NetMapping\347\232\204\350\256\276\350\256\241\344\270\216\345\256\236\347\216\260/index.html"
+++ /dev/null
@@ -1,190 +0,0 @@
-<!DOCTYPE html>
-<html lang="en">
- <head>
- <meta charset="utf-8">
- <title>分布式端口映射NetMapping的设计与实现</title>
-
- <meta name="author" content="Archer Ding">
-
- <!-- Le HTML5 shim, for IE6-8 support of HTML elements -->
- <!--[if lt IE 9]>
- <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
-
- <!-- Le styles -->
- <link href="/assets/twitter/stylesheets/bootstrap.min.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/stylesheets/style.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/widgets/google_prettify/stylesheets/twitter-bootstrap.css" type="text/css" rel="stylesheet" media="all">
-
-
- <!-- Le fav and touch icons -->
- <!-- Update these with your own images
- <link rel="shortcut icon" href="images/favicon.ico">
- <link rel="apple-touch-icon" href="images/apple-touch-icon.png">
- <link rel="apple-touch-icon" sizes="72x72" href="images/apple-touch-icon-72x72.png">
- <link rel="apple-touch-icon" sizes="114x114" href="images/apple-touch-icon-114x114.png">
- -->
- </head>
-
- <body>
-
- <div class="navbar">
- <div class="navbar-inner">
- <div class="container">
- <a class="brand" href="/">ArcherDing's Blog</a>
- <ul class="nav">
-
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
-
-
-
-
- <li><a href="/tags">Tags</a></li>
-
-
-
-
-
-
- <li><a href="/categories">Categories</a></li>
-
-
-
-
-
-
- <li><a href="/pages">Pages</a></li>
-
-
-
-
-
-
- <li><a href="/about">About Me</a></li>
-
-
-
- </ul>
- </div>
- </div>
- </div>
-
- <div class="container">
-
- <div class="content">
- <div class="page-header">
- <h1>分布式端口映射NetMapping的设计与实现 </h1>
-</div>
-
-<div class="row">
- <div class="span8">
- <h4>架构设计</h4>
-
-<p><img src="/assets/media/2015-05-29-netmapping/NetMapping.png" alt="" width="600">
-<img src="/assets/media/2015-05-29-netmapping/UseCase.png" alt="" width="600"></p>
-
- <hr>
- <div class="pagination">
- <ul>
- <ul>
-
- <li class="prev"><a href="/coredump/%E4%BD%BF%E7%94%A8gdb%E8%A7%A3%E6%9E%90core-dump-%E6%A6%82%E5%BF%B5%E7%AF%87/" title="使用gdb解析core dump-概念篇">← Previous</a></li>
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
- <li class="next"><a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E6%A0%88/" title="JavaScript学习笔记-栈">Next →</a></li>
-
-
- </ul>
- </ul>
- </div>
- <hr>
-
-<div id="disqus_thread"></div>
-<script>
- var disqus_developer = 1;
- var disqus_shortname = 'jekyllbootstrap'; // required: replace example with your forum shortname
- /* * * DON'T EDIT BELOW THIS LINE * * */
- (function() {
- var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
- dsq.src = 'http://' + disqus_shortname + '.disqus.com/embed.js';
- (document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
- })();
-</script>
-<noscript>Please enable JavaScript to view the <a href="http://disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript>
-<a href="http://disqus.com" class="dsq-brlink">blog comments powered by <span class="logo-disqus">Disqus</span></a>
-
- </div>
-
- <div class="span4">
- <h4>Published</h4>
- <div class="date"><span>2015-05-29</span></div>
- <br>
- <h4>Categories</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/categories/#Golang-ref">Golang <span>1</span></a>
-</li>
-
- </ul>
- <br>
- <h4>Tags</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/tags/#Golang-ref">Golang <span>1</span></a>
-</li>
-
- </ul>
- </div>
-</div>
-
- </div>
-
- <footer>
- <p>© Archer Ding 2013
- with help from <a href="http://github.com/wendal/gor" target="_blank" title="Gor -- Fast Blog">Gor</a>
- and <a href="http://twitter.github.com/bootstrap/" target="_blank">Twitter Bootstrap</a>
- and Idea from <a href="http://ruhoh.com" target="_blank" title="The Definitive Technical Blogging Framework">ruhoh</a>
- </p>
- </footer>
-
- </div> <!-- /container -->
-
-
-<script src="//cdnjscn.b0.upaiyun.com/libs/prettify/r298/prettify.min.js"></script>
-<script>
- var pres = document.getElementsByTagName("pre");
- for (var i=0; i < pres.length; ++i) {
- pres[i].className = "prettyprint linenums";
- }
- prettyPrint();
-</script>
-
-
-<script type="text/javascript">
-
- var _gaq = _gaq || [];
- var pluginUrl = '//www.google-analytics.com/plugins/ga/inpage_linkid.js';
- _gaq.push(['_require', 'inpage_linkid', pluginUrl]);
- _gaq.push(['_setAccount', 'UA-123-12']);
- _gaq.push(['_trackPageview']);
-
- (function() {
- var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
- ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
- var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
- })();
-
-</script>
- </body>
-</html>
diff --git "a/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\345\210\227\350\241\250/index.html" "b/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\345\210\227\350\241\250/index.html"
deleted file mode 100644
index e81c1f8..0000000
--- "a/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\345\210\227\350\241\250/index.html"
+++ /dev/null
@@ -1,303 +0,0 @@
-<!DOCTYPE html>
-<html lang="en">
- <head>
- <meta charset="utf-8">
- <title>JavaScript学习笔记-列表</title>
-
- <meta name="author" content="Archer Ding">
-
- <!-- Le HTML5 shim, for IE6-8 support of HTML elements -->
- <!--[if lt IE 9]>
- <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
-
- <!-- Le styles -->
- <link href="/assets/twitter/stylesheets/bootstrap.min.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/stylesheets/style.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/widgets/google_prettify/stylesheets/twitter-bootstrap.css" type="text/css" rel="stylesheet" media="all">
-
-
- <!-- Le fav and touch icons -->
- <!-- Update these with your own images
- <link rel="shortcut icon" href="images/favicon.ico">
- <link rel="apple-touch-icon" href="images/apple-touch-icon.png">
- <link rel="apple-touch-icon" sizes="72x72" href="images/apple-touch-icon-72x72.png">
- <link rel="apple-touch-icon" sizes="114x114" href="images/apple-touch-icon-114x114.png">
- -->
- </head>
-
- <body>
-
- <div class="navbar">
- <div class="navbar-inner">
- <div class="container">
- <a class="brand" href="/">ArcherDing's Blog</a>
- <ul class="nav">
-
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
-
-
-
-
- <li><a href="/tags">Tags</a></li>
-
-
-
-
-
-
- <li><a href="/categories">Categories</a></li>
-
-
-
-
-
-
- <li><a href="/pages">Pages</a></li>
-
-
-
-
-
-
- <li><a href="/about">About Me</a></li>
-
-
-
- </ul>
- </div>
- </div>
- </div>
-
- <div class="container">
-
- <div class="content">
- <div class="page-header">
- <h1>JavaScript学习笔记-列表 </h1>
-</div>
-
-<div class="row">
- <div class="span8">
- <h4>JavaScript学习笔记-列表</h4>
-
-<pre><code>function List(){
- this.listSize = 0;
- this.pos = 0;
- this.dataStore = [];
- this.clear = clear;
- this.find = find;
- this.toString = toString;
- this.insert = insert;
- this.append = append;
- this.remove = remove;
- this.front = front;
- this.end = end;
- this.prev = prev;
- this.next = next;
- this.length = length;
- this.currPos = currPos;
- this.moveTo = moveTo;
- this.getElement = getElement;
- this.contains = contains;
-}
-
-function clear(element){
- delete this.dataStore;
- this.dataStore = [];
- this.listSize = this.pos = 0;
-}
-
-function insert(element,after){
- var index = this.find(element);
- if(index > -1){
- this.dataStore.splice(index + 1, 0, element);
- ++this.listSize;
- return true;
- }
- return false;
-}
-
-function front(){
- this.pos = 0;
-}
-
-function end(){
- this.pos = this.listSize - 1;
-}
-
-function prev(){
- --this.pos;
-}
-
-function next(element){
- ++this.pos;
-}
-
-function currPos(){
- return this.pos;
-}
-
-function moveTo(position){
- this.pos = position;
-}
-
-function getElement(){
- return this.dataStore[this.pos];
-}
-
-function contains(element){
- if(this.find(element) > -1)
- {
- return true;
- }
- return false;
-}
-function find(element){
- return this.dataStore.indexOf(element);
-}
-
-function append(element){
- this.dataStore[this.listSize++] = element;
-}
-
-function remove(element){
- var index = this.find(element);
- if(index > -1){
- this.dataStore.splice(index,1);
- --this.listSize;
- return true;
- }
- return false;
-}
-
-function length(){
- return this.listSize;
-}
-
-function toString(){
- return this.dataStore;
-}
-
-var names = new List();
-names.append("Clayton");
-names.append("Raymond");
-names.append("Cynthia");
-names.append("Jennifer");
-names.append("Bryan");
-names.append("Danny");
-
-for(names.front(); names.currPos() < names.length(); names.next()) {
- console.log(names.getElement());
-}
-
-for(names.end(); names.currPos() >= 0; names.prev()) {
- console.log(names.getElement());
-}
-
-</code></pre>
-
- <hr>
- <div class="pagination">
- <ul>
- <ul>
-
- <li class="prev"><a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E6%A0%88/" title="JavaScript学习笔记-栈">← Previous</a></li>
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
- <li class="next"><a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E6%95%B0%E7%BB%84%E7%BB%83%E4%B9%A0%E9%A2%98/" title="JavaScript学习笔记-数组练习题">Next →</a></li>
-
-
- </ul>
- </ul>
- </div>
- <hr>
-
-<div id="disqus_thread"></div>
-<script>
- var disqus_developer = 1;
- var disqus_shortname = 'jekyllbootstrap'; // required: replace example with your forum shortname
- /* * * DON'T EDIT BELOW THIS LINE * * */
- (function() {
- var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
- dsq.src = 'http://' + disqus_shortname + '.disqus.com/embed.js';
- (document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
- })();
-</script>
-<noscript>Please enable JavaScript to view the <a href="http://disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript>
-<a href="http://disqus.com" class="dsq-brlink">blog comments powered by <span class="logo-disqus">Disqus</span></a>
-
- </div>
-
- <div class="span4">
- <h4>Published</h4>
- <div class="date"><span>2015-05-29</span></div>
- <br>
- <h4>Categories</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/categories/#JavaScript-ref">JavaScript <span>5</span></a>
-</li>
-
- </ul>
- <br>
- <h4>Tags</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/tags/#JavaScript-ref">JavaScript <span>5</span></a>
-</li>
-
- </ul>
- </div>
-</div>
-
- </div>
-
- <footer>
- <p>© Archer Ding 2013
- with help from <a href="http://github.com/wendal/gor" target="_blank" title="Gor -- Fast Blog">Gor</a>
- and <a href="http://twitter.github.com/bootstrap/" target="_blank">Twitter Bootstrap</a>
- and Idea from <a href="http://ruhoh.com" target="_blank" title="The Definitive Technical Blogging Framework">ruhoh</a>
- </p>
- </footer>
-
- </div> <!-- /container -->
-
-
-<script src="//cdnjscn.b0.upaiyun.com/libs/prettify/r298/prettify.min.js"></script>
-<script>
- var pres = document.getElementsByTagName("pre");
- for (var i=0; i < pres.length; ++i) {
- pres[i].className = "prettyprint linenums";
- }
- prettyPrint();
-</script>
-
-
-<script type="text/javascript">
-
- var _gaq = _gaq || [];
- var pluginUrl = '//www.google-analytics.com/plugins/ga/inpage_linkid.js';
- _gaq.push(['_require', 'inpage_linkid', pluginUrl]);
- _gaq.push(['_setAccount', 'UA-123-12']);
- _gaq.push(['_trackPageview']);
-
- (function() {
- var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
- ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
- var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
- })();
-
-</script>
- </body>
-</html>
diff --git "a/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\346\225\260\347\273\204/index.html" "b/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\346\225\260\347\273\204/index.html"
deleted file mode 100644
index 745ae06..0000000
--- "a/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\346\225\260\347\273\204/index.html"
+++ /dev/null
@@ -1,409 +0,0 @@
-<!DOCTYPE html>
-<html lang="en">
- <head>
- <meta charset="utf-8">
- <title>JavaScript学习笔记-数组</title>
-
- <meta name="author" content="Archer Ding">
-
- <!-- Le HTML5 shim, for IE6-8 support of HTML elements -->
- <!--[if lt IE 9]>
- <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
-
- <!-- Le styles -->
- <link href="/assets/twitter/stylesheets/bootstrap.min.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/stylesheets/style.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/widgets/google_prettify/stylesheets/twitter-bootstrap.css" type="text/css" rel="stylesheet" media="all">
-
-
- <!-- Le fav and touch icons -->
- <!-- Update these with your own images
- <link rel="shortcut icon" href="images/favicon.ico">
- <link rel="apple-touch-icon" href="images/apple-touch-icon.png">
- <link rel="apple-touch-icon" sizes="72x72" href="images/apple-touch-icon-72x72.png">
- <link rel="apple-touch-icon" sizes="114x114" href="images/apple-touch-icon-114x114.png">
- -->
- </head>
-
- <body>
-
- <div class="navbar">
- <div class="navbar-inner">
- <div class="container">
- <a class="brand" href="/">ArcherDing's Blog</a>
- <ul class="nav">
-
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
-
-
-
-
- <li><a href="/tags">Tags</a></li>
-
-
-
-
-
-
- <li><a href="/categories">Categories</a></li>
-
-
-
-
-
-
- <li><a href="/pages">Pages</a></li>
-
-
-
-
-
-
- <li><a href="/about">About Me</a></li>
-
-
-
- </ul>
- </div>
- </div>
- </div>
-
- <div class="container">
-
- <div class="content">
- <div class="page-header">
- <h1>JavaScript学习笔记-数组 </h1>
-</div>
-
-<div class="row">
- <div class="span8">
- <h3>什么是数组</h3>
-
-<p>通常数组是一种线性结构,但是JavaScript中的数组是一个<strong>特殊的对象</strong>,其索引值在内部被转换成字符串处理。</p>
-
-<h3>创建数组</h3>
-
-<pre><code>var array = []; //length = 0
-var array = [10]; //length = 1
-var array = [1,2,3,4,5];//length = 5
-var array = new Array(); //length = 0
-var array = new Array(10); //length = 10
-var array = new Array(1,2,3,4,6); //length = 5
-</code></pre>
-
-<p><em>使用[]创建数组的效率高,因为字符少。</em></p>
-
-<h3>遍历数组</h3>
-
-<pre><code>var nums = [1,3,4,5,6];
-for(var i = 0; i < nums.length; ++i){
- console.log(nums[i]); //1 23 4 5 6
-}
-
-for(var i = 0; i < nums.length; ++i){
- nums[i] = i;
-}
-</code></pre>
-
-<p>length属性反映的是当前数组中元素的个数,使用它,可以确保循环遍历了数组中的所有元素。</p>
-
-<h3>字符串生成数组</h3>
-
-<pre><code>var sentence = "the quick brown fox jumped over the lazy dog";
-var words = sentence.split(" ");
-for (var i = 0; i < words.length; ++i)
- console.log("word " + i + ": " + words[i]);
-}
-</code></pre>
-
-<h3>数组的类方法</h3>
-
-<pre><code>bool = Array.isArray(var);//检查变量是否为数组
-</code></pre>
-
-<h3>数组的属性</h3>
-
-<p><strong>获取长度</strong>
-<code>
-var nums = [1,2,3,4,5];
-length = array.length;//length = 5
-</code></p>
-
-<h3>数组的对象方法</h3>
-
-<p><strong>查找元素</strong>
-<code>
-/*
-index:
-查找到返回下标
-查找失败返回-1
-*/
-index = array.indexOf(value);//从前往后找元素value,找到1个就返回
-index = array.lastIndexOf(value);// 从后往前找元素value,找到1个就返回
-</code>
-<strong>数组转字符串</strong>
-<code>
-string = array.join(); //1,2,3,4,5
-string = array.toString(); //1,2,3,4,5
-string = array.join('-');//1-2-3-4
-</code></p>
-
-<p><strong>拼接数组</strong>
-```
-var a = [1,2,3];
-var b = [4,5,6];</p>
-
-<p>var c = a.concat(b);
-//c = [ 1, 2, 3, 4, 5, 6 ]
-var c = b.concat(a);
-//c = [ 4, 5, 6, 1, 2, 3 ]
-<code>
-**添加元素**
-push和unshift都返回数组的新长度.
-</code>
-//push方法在数组的尾部添加元素
-//unshift方法在数组的头部添加元素
-var array = [1,2,3];
-array.push(4);//[1,2,3,4] rtn = length = 4
-array.unshift(0);//[0,1,2,3,4] rtn = length = 5
-```</p>
-
-<p><strong>删除元素</strong>
-pop和shift都返回被删除元素组成的数组
-<code>
-//pop方法在数组的尾部删除元素
-//shift方法在数组的头部删除元素
-var array = [0,1,2,3,4];
-array.pop();//[0,1,2,3] rtn = 4
-array.shift();//[1,2,3] rtn= 0
-</code>
-<strong>splice操作</strong>
-被删除元素数组 = splice(起始位置, 删除字符数, 插入的字符…)
-- 起始索引(也就是你希望开始添加元素的地方) ;
-- 需要删除的元素个数(添加元素时该参数设为 0) ;
-- 想要添加进数组的元素。</p>
-
-<p>先<strong>删除</strong>元素,再<strong>增加</strong>元素.
-<code>
-var nums = [1,2,3,4,5];
-nums.splice(2,0);//rtn = [] nums = [ 1, 2, 3, 4, 5 ]
-nums.splice(2,1);//rtn =[ 3 ] nums = [ 1, 2, 4, 5 ]
-nums.splice(2,2);//rtn = [ 4, 5 ] nums = [ 1, 2 ]
-nums.splice(2,0,10,20,30);//rtn = [] nums = [ 1, 2, 10, 20, 30 ]
-nums.splice(1,1,40);//rtn = [ 2 ] nums = [ 1, 40, 10, 20, 30 ]
-</code>
-<strong>数组排序</strong>
-reverse方法是将数组反转
-<code>
-var array = [1,2,3,4,5];
-array.reverse();//rtn = array = [ 5, 4, 3, 2, 1 ];
-</code>
-sort方法默认是按照字典顺序进行排序
-适用于字符串排序,对于数字排序不适用.
-<em>数组本身被改变</em>
-Array = sort([function compare]);
-<code>
-var words = ['one','two','three','four'];
-words.sort();//[ 'four', 'one', 'three', 'two' ]
-var nums = [4,5,2,20,11,1,10,11,23,42];
-nums.sort();//[ 1, 10, 11, 11, 2, 20, 23, 4, 42, 5 ]
-nums.sort(function(a,b){return a-b; });//[ 1, 2, 4, 5, 10, 11, 11, 20, 23, 42 ]
-nums.sort(function(a,b){return b-a; });//[ 42, 23, 20, 11, 11, 10, 5, 4, 2, 1 ]
-</code></p>
-
-<h3>迭代器</h3>
-
-<p>forEach() 该方法接受一个函数作为参数,对数组中的每个元素使用该函数.
-```
-function square(num){
- console.log(num, num* num);
-}</p>
-
-<p>var nums = [1,2,3,4,5];
-nums.forEach(square);
-<code>
-every(), 该方法接受一个返回值为布尔类型的函数, 对数组中的每个元素使用该函数。 如果对于所有的元素, 该函数均返回 true, 则该方法返回 true。
-</code>
-var nums = [2,4,6,8,10];
-var rtn = nums.every(function(num){
- return num%2==0;
-});
-console.log(rtn); // true
-<code>
-some() 方法也接受一个返回值为布尔类型的函数, 只要有一个元素使得该函数返回 true,该方法就返回 true。
-</code>
-var nums = [2,3,5,7,9];
-var rtn = nums.some(function(num){
- return num%2==0;
-});
-console.log(rtn); // true
-<code>
-reduce() 方法接受一个函数, 返回一个值。 该方法会从一个累加值开始, 不断对累加值和
-数组中的后续元素调用该函数, 直到数组中的最后一个元素, 最后返回得到的累加值。
-计算数组中元素的平方和.
-</code>
-var nums = [1,2,3,4];
-var sum = nums.reduce(function(sum,num){
- return sum + num<em>num;
-});
-console.log(sum);//30 1*1 + 2*2 + 3*3 + 4*4 =30
-<code>
-reduceRight() 方法, 和 reduce() 方法不同, 它是从右到左执行。
-</code>
-function concat(accumulatedString, item) {
- return accumulatedString + item;
-}
-var words = [” the “ , ” quick “ , ” brown “ , ” fox “ ] ;
-var sentence = words. reduceRight(concat);
-console.log(sentence); // 显示 “ fox brown quick the”
-<code>
-map() 和 forEach() 有点儿像, 对数组中的每个元素使用某个函数。 两者的区别是 map() 返回一个新的数组, 该数组的元素是对原有元素应用某个函数得到的结果。
-</code>
-function square(num){
- return num</em> num;
-}</p>
-
-<p>var nums = [1,2,3,4,5];
-var news = nums.map(square); //rtn = [ 1, 4, 9, 16, 25 ]
-console.log(nums);//[ 1, 2, 3, 4, 5 ]
-console.log(news);//[ 1, 4, 9, 16, 25 ]
-<code>
-给定一个字符串生成首字母缩写形式
-</code>
-var str = ‘Asynchronous Javascript And XML’;
-var arr = str.split(” “);
-var newArr = arr.map(function(word){return word.charAt(0);});
-var newStr = newArr.join(“”);
-console.log(str + ‘->’ + newStr); // Asynchronous Javascript And XML->AJAX
-```</p>
-
-<p>filter() 和 every() 类似, 传入一个返回值为布尔类型的函数。 和 every() 方法不同的是,当对数组中的所有元素应用该函数, 结果均为 true 时, 该方法并不返回 true, 而是返回一个新数组, 该数组包含应用该函数后结果为 true 的元素。
-随机生成20个数字,取出大于60的数字.
-<code>
-var nums = [];
-for(var i=0;i<20;i++){
- nums[i] = Math.floor(Math.random()*101);
-}
-var bigNums = nums.filter(function(num){return num >= 60;});
-console.log(nums);//[ 46, 56, 53, 65, 49, 3, 25, 26, 46, 25, 36, 73, 44, 43, 58, 97, 100, 65, 97, 47 ]
-console.log(bigNums);//[ 65, 73, 97, 100, 65, 97 ]
-</code></p>
-
-<pre><code>var words = ["recieve" , " deceive" , "percieve" , "deceit" , "concieve" ] ;
-var filter = 'cie';
-var misspelled = words.filter(function(word){
- if(word.indexOf(filter)>-1){
- return true;
- }else{
- return false;
- }
-});
-console.log(misspelled );//[ 'recieve', 'percieve', 'concieve' ]
-</code></pre>
-
- <hr>
- <div class="pagination">
- <ul>
- <ul>
-
- <li class="prev"><a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E6%95%B0%E7%BB%842/" title="JavaScript学习笔记-数组2">← Previous</a></li>
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
- <li class="next"><a href="/2013/new-born.html" title="你的第一篇博客">Next →</a></li>
-
-
- </ul>
- </ul>
- </div>
- <hr>
-
-<div id="disqus_thread"></div>
-<script>
- var disqus_developer = 1;
- var disqus_shortname = 'jekyllbootstrap'; // required: replace example with your forum shortname
- /* * * DON'T EDIT BELOW THIS LINE * * */
- (function() {
- var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
- dsq.src = 'http://' + disqus_shortname + '.disqus.com/embed.js';
- (document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
- })();
-</script>
-<noscript>Please enable JavaScript to view the <a href="http://disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript>
-<a href="http://disqus.com" class="dsq-brlink">blog comments powered by <span class="logo-disqus">Disqus</span></a>
-
- </div>
-
- <div class="span4">
- <h4>Published</h4>
- <div class="date"><span>2015-05-29</span></div>
- <br>
- <h4>Categories</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/categories/#JavaScript-ref">JavaScript <span>5</span></a>
-</li>
-
- </ul>
- <br>
- <h4>Tags</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/tags/#JavaScript-ref">JavaScript <span>5</span></a>
-</li>
-
- </ul>
- </div>
-</div>
-
- </div>
-
- <footer>
- <p>© Archer Ding 2013
- with help from <a href="http://github.com/wendal/gor" target="_blank" title="Gor -- Fast Blog">Gor</a>
- and <a href="http://twitter.github.com/bootstrap/" target="_blank">Twitter Bootstrap</a>
- and Idea from <a href="http://ruhoh.com" target="_blank" title="The Definitive Technical Blogging Framework">ruhoh</a>
- </p>
- </footer>
-
- </div> <!-- /container -->
-
-
-<script src="//cdnjscn.b0.upaiyun.com/libs/prettify/r298/prettify.min.js"></script>
-<script>
- var pres = document.getElementsByTagName("pre");
- for (var i=0; i < pres.length; ++i) {
- pres[i].className = "prettyprint linenums";
- }
- prettyPrint();
-</script>
-
-
-<script type="text/javascript">
-
- var _gaq = _gaq || [];
- var pluginUrl = '//www.google-analytics.com/plugins/ga/inpage_linkid.js';
- _gaq.push(['_require', 'inpage_linkid', pluginUrl]);
- _gaq.push(['_setAccount', 'UA-123-12']);
- _gaq.push(['_trackPageview']);
-
- (function() {
- var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
- ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
- var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
- })();
-
-</script>
- </body>
-</html>
diff --git "a/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\346\225\260\347\273\2042/index.html" "b/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\346\225\260\347\273\2042/index.html"
deleted file mode 100644
index a03c8c7..0000000
--- "a/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\346\225\260\347\273\2042/index.html"
+++ /dev/null
@@ -1,290 +0,0 @@
-<!DOCTYPE html>
-<html lang="en">
- <head>
- <meta charset="utf-8">
- <title>JavaScript学习笔记-数组2</title>
-
- <meta name="author" content="Archer Ding">
-
- <!-- Le HTML5 shim, for IE6-8 support of HTML elements -->
- <!--[if lt IE 9]>
- <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
-
- <!-- Le styles -->
- <link href="/assets/twitter/stylesheets/bootstrap.min.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/stylesheets/style.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/widgets/google_prettify/stylesheets/twitter-bootstrap.css" type="text/css" rel="stylesheet" media="all">
-
-
- <!-- Le fav and touch icons -->
- <!-- Update these with your own images
- <link rel="shortcut icon" href="images/favicon.ico">
- <link rel="apple-touch-icon" href="images/apple-touch-icon.png">
- <link rel="apple-touch-icon" sizes="72x72" href="images/apple-touch-icon-72x72.png">
- <link rel="apple-touch-icon" sizes="114x114" href="images/apple-touch-icon-114x114.png">
- -->
- </head>
-
- <body>
-
- <div class="navbar">
- <div class="navbar-inner">
- <div class="container">
- <a class="brand" href="/">ArcherDing's Blog</a>
- <ul class="nav">
-
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
-
-
-
-
- <li><a href="/tags">Tags</a></li>
-
-
-
-
-
-
- <li><a href="/categories">Categories</a></li>
-
-
-
-
-
-
- <li><a href="/pages">Pages</a></li>
-
-
-
-
-
-
- <li><a href="/about">About Me</a></li>
-
-
-
- </ul>
- </div>
- </div>
- </div>
-
- <div class="container">
-
- <div class="content">
- <div class="page-header">
- <h1>JavaScript学习笔记-数组2 </h1>
-</div>
-
-<div class="row">
- <div class="span8">
- <h3>二维数组</h3>
-
-<p>JavaScript只支持一维数组,但是通过在数组里保存数组元素的方式,可以轻松创建多维
-数组。</p>
-
-<h3>创建二维数组</h3>
-
-<pre><code>var twod = [];
-var rows = 5;
-for (var i = 0; i < rows; ++i) {
- twod[i] = [];
-}
-console.log(twod);//[ [], [], [], [], [] ]
-</code></pre>
-
-<p>为数组类添加方法matrix(行数,列数,初始值),用于创建二维数组并初始化.
-```
-Array.matrix = function(rows,cols,initial){
- var arr = [];
- for(var i = 0; i < rows; i++){
- var col = [];
- for(var j = 0; j < cols; j++){
- col[j] = initial;
- }
- arr[i] = col;
- }
- return arr;
-}</p>
-
-<p>var nums = Array.matrix(5,5,0);
-console.log(nums[1][1]); // 0
-var strs = Array.matrix(5,5,“”);
-strs[1][2] = “iDarker”;
-console.log(strs);
- /* [ [ “, “, “, “, ” ],
- [ “, “, ‘iDarker’, “, “
- [ “, “, “, “, ” ],
- [ “, “, “, “, ” ],
- [ “, “, “, “, ” ] ]
-*/
-```</p>
-
-<h3>对象数组</h3>
-
-<pre><code>function Point(x,y){
- this.x = x;
- this.y = y;
-}
-var p1 = new Point(1,1);
-var p2 = new Point(2,2);
-var p3 = new Point(3,3);
-var p4 = new Point(4,4);
-var points = [p1,p2,p3,p4];
-points.forEach(function(point){
- console.log('Point x:' + point.x + ' y:' + point.y);
-});
-/*
-Point x:1 y:1
-Point x:2 y:2
-Point x:3 y:3
-Point x:4 y:4
-*/
-var p5 = new Point(5,5);
-points.push(p5);
-console.log(points);
-/*
-[ { x: 1, y: 1 },
- { x: 2, y: 2 },
- { x: 3, y: 3 },
- { x: 4, y: 4 },
- { x: 5, y: 5 } ]
-*/
-points.pop();
-console.log(points);
-/*
-[ { x: 1, y: 1 },
- { x: 2, y: 2 },
- { x: 3, y: 3 },
- { x: 4, y: 4 } ]
-*/
-points.unshift(p5);
-console.log(points);
-/*
-[ { x: 5, y: 5 },
- { x: 1, y: 1 },
- { x: 2, y: 2 },
- { x: 3, y: 3 },
- { x: 4, y: 4 } ]
-*/
-points.shift();
-console.log(points);
-/*
-[ { x: 1, y: 1 },
- { x: 2, y: 2 },
- { x: 3, y: 3 },
- { x: 4, y: 4 } ]
-*/
-var filter = new Point(2,2);
-var newPoints = points.filter(function(point){
- return (point.x == filter.x) && (point.y == filter.y);
-});
-console.log(newPoints );
-/* [ { x: 2, y: 2 } ] */
-</code></pre>
-
- <hr>
- <div class="pagination">
- <ul>
- <ul>
-
- <li class="prev"><a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E6%95%B0%E7%BB%84%E7%BB%83%E4%B9%A0%E9%A2%98/" title="JavaScript学习笔记-数组练习题">← Previous</a></li>
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
- <li class="next"><a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E6%95%B0%E7%BB%84/" title="JavaScript学习笔记-数组">Next →</a></li>
-
-
- </ul>
- </ul>
- </div>
- <hr>
-
-<div id="disqus_thread"></div>
-<script>
- var disqus_developer = 1;
- var disqus_shortname = 'jekyllbootstrap'; // required: replace example with your forum shortname
- /* * * DON'T EDIT BELOW THIS LINE * * */
- (function() {
- var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
- dsq.src = 'http://' + disqus_shortname + '.disqus.com/embed.js';
- (document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
- })();
-</script>
-<noscript>Please enable JavaScript to view the <a href="http://disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript>
-<a href="http://disqus.com" class="dsq-brlink">blog comments powered by <span class="logo-disqus">Disqus</span></a>
-
- </div>
-
- <div class="span4">
- <h4>Published</h4>
- <div class="date"><span>2015-05-29</span></div>
- <br>
- <h4>Categories</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/categories/#JavaScript-ref">JavaScript <span>5</span></a>
-</li>
-
- </ul>
- <br>
- <h4>Tags</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/tags/#JavaScript-ref">JavaScript <span>5</span></a>
-</li>
-
- </ul>
- </div>
-</div>
-
- </div>
-
- <footer>
- <p>© Archer Ding 2013
- with help from <a href="http://github.com/wendal/gor" target="_blank" title="Gor -- Fast Blog">Gor</a>
- and <a href="http://twitter.github.com/bootstrap/" target="_blank">Twitter Bootstrap</a>
- and Idea from <a href="http://ruhoh.com" target="_blank" title="The Definitive Technical Blogging Framework">ruhoh</a>
- </p>
- </footer>
-
- </div> <!-- /container -->
-
-
-<script src="//cdnjscn.b0.upaiyun.com/libs/prettify/r298/prettify.min.js"></script>
-<script>
- var pres = document.getElementsByTagName("pre");
- for (var i=0; i < pres.length; ++i) {
- pres[i].className = "prettyprint linenums";
- }
- prettyPrint();
-</script>
-
-
-<script type="text/javascript">
-
- var _gaq = _gaq || [];
- var pluginUrl = '//www.google-analytics.com/plugins/ga/inpage_linkid.js';
- _gaq.push(['_require', 'inpage_linkid', pluginUrl]);
- _gaq.push(['_setAccount', 'UA-123-12']);
- _gaq.push(['_trackPageview']);
-
- (function() {
- var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
- ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
- var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
- })();
-
-</script>
- </body>
-</html>
diff --git "a/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\346\225\260\347\273\204\347\273\203\344\271\240\351\242\230/index.html" "b/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\346\225\260\347\273\204\347\273\203\344\271\240\351\242\230/index.html"
deleted file mode 100644
index a60c74e..0000000
--- "a/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\346\225\260\347\273\204\347\273\203\344\271\240\351\242\230/index.html"
+++ /dev/null
@@ -1,268 +0,0 @@
-<!DOCTYPE html>
-<html lang="en">
- <head>
- <meta charset="utf-8">
- <title>JavaScript学习笔记-数组练习题</title>
-
- <meta name="author" content="Archer Ding">
-
- <!-- Le HTML5 shim, for IE6-8 support of HTML elements -->
- <!--[if lt IE 9]>
- <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
-
- <!-- Le styles -->
- <link href="/assets/twitter/stylesheets/bootstrap.min.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/stylesheets/style.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/widgets/google_prettify/stylesheets/twitter-bootstrap.css" type="text/css" rel="stylesheet" media="all">
-
-
- <!-- Le fav and touch icons -->
- <!-- Update these with your own images
- <link rel="shortcut icon" href="images/favicon.ico">
- <link rel="apple-touch-icon" href="images/apple-touch-icon.png">
- <link rel="apple-touch-icon" sizes="72x72" href="images/apple-touch-icon-72x72.png">
- <link rel="apple-touch-icon" sizes="114x114" href="images/apple-touch-icon-114x114.png">
- -->
- </head>
-
- <body>
-
- <div class="navbar">
- <div class="navbar-inner">
- <div class="container">
- <a class="brand" href="/">ArcherDing's Blog</a>
- <ul class="nav">
-
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
-
-
-
-
- <li><a href="/tags">Tags</a></li>
-
-
-
-
-
-
- <li><a href="/categories">Categories</a></li>
-
-
-
-
-
-
- <li><a href="/pages">Pages</a></li>
-
-
-
-
-
-
- <li><a href="/about">About Me</a></li>
-
-
-
- </ul>
- </div>
- </div>
- </div>
-
- <div class="container">
-
- <div class="content">
- <div class="page-header">
- <h1>JavaScript学习笔记-数组练习题 </h1>
-</div>
-
-<div class="row">
- <div class="span8">
- <h4>1. 创建一个记录学生成绩的对象,提供一个添加成绩的方法,以及一个显示学生平均成绩的方法。</h4>
-
-<pre><code>function Grade(chinese,english,math){
- this.dataStore = [chinese,english,math]
- this.average = function(){
- var total = this.dataStore.reduce(function(currenTotal,currenNum){
- return currenTotal + currenNum;
- });
- return total/this.dataStore.length;
- }
-}
-
-function Grades(){
- this.dataStore = [];
- this.add = function(grade){
- this.dataStore.push(grade);
- };
- this.average = function(){
- var averages = this.dataStore.map(function(grade){
- return grade.average();
- });
- console.log(averages);
- var total = averages.reduce(function(currenTotal,currenNum){
- return currenTotal + currenNum;
- });
- return total/this.dataStore.length;
- };
-
- this.englishAverage = function(){
- var englishs = this.dataStore.map(function(grade){
- return grade.dataStore[0];
- });
- console.log(englishs);
- var total = englishs.reduce(function(currenTotal,currenNum){
- return currenTotal + currenNum;
- });
- return total/this.dataStore.length;
- };
-}
-
-var g1 = new Grade(90,98,95);
-var g2 = new Grade(83,79,82);
-var g3 = new Grade(46,53,22);
-
-var grades = new Grades();
-grades.add(g1);
-grades.add(g2);
-grades.add(g3);
-
-console.log(grades.average());
-console.log(grades.englishAverage());
-
-</code></pre>
-
-<h4>2. 将一组单词存储在一个数组中,并按正序和倒序分别显示这些单词。</h4>
-
-<pre><code>var words = ['one','two','three','four'];
-words.sort();
-console.log(words);
-words.reverse();
-console.log(words);
-</code></pre>
-
-<h4>3. 创建这样一个对象,它将字母存储在一个数组中,并且用一个方法可以将字母连在一起,显示成一个单词。</h4>
-
-<pre><code>function Word(){
- this.dataStore = [];
- this.add = function(char){
- this.dataStore.push(char);
- };
- this.toString = function(){
- return this.dataStore.join("");
- }
-}
-
-var word = new Word();
-word.add('g');
-word.add('o');
-word.add('o');
-word.add('d');
-console.log(word.toString());
-</code></pre>
-
- <hr>
- <div class="pagination">
- <ul>
- <ul>
-
- <li class="prev"><a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E5%88%97%E8%A1%A8/" title="JavaScript学习笔记-列表">← Previous</a></li>
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
- <li class="next"><a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E6%95%B0%E7%BB%842/" title="JavaScript学习笔记-数组2">Next →</a></li>
-
-
- </ul>
- </ul>
- </div>
- <hr>
-
-<div id="disqus_thread"></div>
-<script>
- var disqus_developer = 1;
- var disqus_shortname = 'jekyllbootstrap'; // required: replace example with your forum shortname
- /* * * DON'T EDIT BELOW THIS LINE * * */
- (function() {
- var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
- dsq.src = 'http://' + disqus_shortname + '.disqus.com/embed.js';
- (document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
- })();
-</script>
-<noscript>Please enable JavaScript to view the <a href="http://disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript>
-<a href="http://disqus.com" class="dsq-brlink">blog comments powered by <span class="logo-disqus">Disqus</span></a>
-
- </div>
-
- <div class="span4">
- <h4>Published</h4>
- <div class="date"><span>2015-05-29</span></div>
- <br>
- <h4>Categories</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/categories/#JavaScript-ref">JavaScript <span>5</span></a>
-</li>
-
- </ul>
- <br>
- <h4>Tags</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/tags/#JavaScript-ref">JavaScript <span>5</span></a>
-</li>
-
- </ul>
- </div>
-</div>
-
- </div>
-
- <footer>
- <p>© Archer Ding 2013
- with help from <a href="http://github.com/wendal/gor" target="_blank" title="Gor -- Fast Blog">Gor</a>
- and <a href="http://twitter.github.com/bootstrap/" target="_blank">Twitter Bootstrap</a>
- and Idea from <a href="http://ruhoh.com" target="_blank" title="The Definitive Technical Blogging Framework">ruhoh</a>
- </p>
- </footer>
-
- </div> <!-- /container -->
-
-
-<script src="//cdnjscn.b0.upaiyun.com/libs/prettify/r298/prettify.min.js"></script>
-<script>
- var pres = document.getElementsByTagName("pre");
- for (var i=0; i < pres.length; ++i) {
- pres[i].className = "prettyprint linenums";
- }
- prettyPrint();
-</script>
-
-
-<script type="text/javascript">
-
- var _gaq = _gaq || [];
- var pluginUrl = '//www.google-analytics.com/plugins/ga/inpage_linkid.js';
- _gaq.push(['_require', 'inpage_linkid', pluginUrl]);
- _gaq.push(['_setAccount', 'UA-123-12']);
- _gaq.push(['_trackPageview']);
-
- (function() {
- var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
- ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
- var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
- })();
-
-</script>
- </body>
-</html>
diff --git "a/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\346\240\210/index.html" "b/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\346\240\210/index.html"
deleted file mode 100644
index 0daae97..0000000
--- "a/JavaScript/JavaScript\345\255\246\344\271\240\347\254\224\350\256\260-\346\240\210/index.html"
+++ /dev/null
@@ -1,388 +0,0 @@
-<!DOCTYPE html>
-<html lang="en">
- <head>
- <meta charset="utf-8">
- <title>JavaScript学习笔记-栈</title>
-
- <meta name="author" content="Archer Ding">
-
- <!-- Le HTML5 shim, for IE6-8 support of HTML elements -->
- <!--[if lt IE 9]>
- <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
-
- <!-- Le styles -->
- <link href="/assets/twitter/stylesheets/bootstrap.min.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/stylesheets/style.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/widgets/google_prettify/stylesheets/twitter-bootstrap.css" type="text/css" rel="stylesheet" media="all">
-
-
- <!-- Le fav and touch icons -->
- <!-- Update these with your own images
- <link rel="shortcut icon" href="images/favicon.ico">
- <link rel="apple-touch-icon" href="images/apple-touch-icon.png">
- <link rel="apple-touch-icon" sizes="72x72" href="images/apple-touch-icon-72x72.png">
- <link rel="apple-touch-icon" sizes="114x114" href="images/apple-touch-icon-114x114.png">
- -->
- </head>
-
- <body>
-
- <div class="navbar">
- <div class="navbar-inner">
- <div class="container">
- <a class="brand" href="/">ArcherDing's Blog</a>
- <ul class="nav">
-
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
-
-
-
-
- <li><a href="/tags">Tags</a></li>
-
-
-
-
-
-
- <li><a href="/categories">Categories</a></li>
-
-
-
-
-
-
- <li><a href="/pages">Pages</a></li>
-
-
-
-
-
-
- <li><a href="/about">About Me</a></li>
-
-
-
- </ul>
- </div>
- </div>
- </div>
-
- <div class="container">
-
- <div class="content">
- <div class="page-header">
- <h1>JavaScript学习笔记-栈 </h1>
-</div>
-
-<div class="row">
- <div class="span8">
- <h3>什么是栈</h3>
-
-<p>栈是一种被称为后入先出(LIFO,last in first out)的数据结构.是一个特殊的列表,栈内的元素只能通过一端访问,这个端被称为栈顶.</p>
-
-<h3>如何定义栈</h3>
-
-<ul>
-<li>方法:将一个元素压入栈push(element)</li>
-<li>方法:将一个元素弹出栈pop()->element 被弹出的元素从栈中永久性删除</li>
-<li>方法:预览栈顶元素peek()->element 只返回栈顶元素,不删除该元素</li>
-<li>方法:清除栈内所有元素clear() 可以将top=0快速清空栈</li>
-<li>方法:栈内元素的个数:length()->number //可以使用top获取</li>
-<li>属性:栈顶元素位置number:top</li>
-<li>属性:栈内是否有元素boolean:empty //可以使用top=0进行判断,</li>
-</ul>
-
-<pre><code>function Stack(){
- this.dataStore = [];
- this.top = 0;
- this.push = function(element){
- this.dataStore[this.top++] = element;
- };
- this.pop = function(){
- return this.dataStore[--this.top];
- };
- this.peek = function(){
- return this.dataStore[this.top - 1];
- };
- this.length = function(){
- return this.top;
- };
- this.clear = function(){
- this.top = 0;
- };
-}
-</code></pre>
-
-<h3>使用栈</h3>
-
-<pre><code>var s = new Stack();
-s.push('iDarker');
-s.push('xiachuan');
-s.push('qianxia');
-console.log('length:' + s.length()); //length:3
-console.log('peek:' + s.peek()); //peek: qianxia
-var poped = s.pop();
-console.log('poped :' + poped); //poped : qianxia
-console.log('peek:' + s.peek()); //peek: xiachuan
-s.push('love');
-console.log('peek:' + s.peek()); //peek: love
-s.clear();
-console.log('length:' + s.length()); //length:0
-console.log('peek:' + s.peek()); //peek:undefined
-</code></pre>
-
-<h3>栈能解决什么问题</h3>
-
-<p><strong>使用栈进行进制转换</strong></p>
-
-<ul>
-<li>十六进制转为十进制 (这个问题不应该用栈解决,数组本身比这更好,想岔了 (ˇˍˇ))</li>
-</ul>
-
-<pre><code>function Hex2Dec(hex){
- var chars = hex.toUpperCase().split('').reverse(); //统一转换为大写-->分割成字符数组-->倒序排列
- var stack = new Stack();
- chars.forEach(function(char){
- var code = char.charCodeAt(); //获取字符串第一个元素的ascii码(实际上是Unicode码)
- var num = 0;
- if(code > 64){ //判断是否大于'A'=65
- num = code - 55; //'A'->10 'B'->11
- stack.push(num);
- }else{
- num = code - 48; //char('0')=ascii(48)
- stack.push(num);
- }
- });
- var converted = 0;
- while(stack.length()>0){
- converted = converted*16 + stack.pop();
- }
- return converted;
-}
-console.log(Hex2Dec('123')); // 291
-console.log(Hex2Dec('ABC')); //2748
-console.log(Hex2Dec('121ABCcd')); // 303742157
-</code></pre>
-
-<ul>
-<li>十进制转为十六进制/二进制/8进制</li>
-</ul>
-
-<pre><code>function convert(num,base){
- var s = new Stack();
- do{
- s.push(num % base);
- num = Math.floor(num / base);
- }while(num > 0);
-
- var converted ="";
- while(s.length() > 0){
- var poped = s.pop();
- if(poped > 9){
- converted += String.fromCharCode(poped+55);
- }else{
- converted += poped;
- }
- }
- return converted;
-}
-console.log(convert(303742157,16)); //121ABCCD
-console.log(convert(100,16)); //64
-console.log(convert(100,10)); //100
-console.log(convert(100,8)); //144
-console.log(convert(100,2)); //1100100
-console.log(convert(303742157,20)); //4EI7F7H (ˇˍˇ) ~
-</code></pre>
-
-<ul>
-<li>数组的reverse函数</li>
-</ul>
-
-<pre><code>Array.prototype.myReverse = function(){
- var s = new Stack();
- this.forEach(function(element){
- s.push(element);
- });
-
- for(var i = 0;i< this.length;i++){
- this[i] = s.pop();
- }
- return this;
-}
-
-var nums = [1,2,3,4,5];
-console.log(nums.myReverse()); // [ 5, 4, 3, 2, 1 ]
-console.log(nums); // [ 5, 4, 3, 2, 1 ]
-</code></pre>
-
-<ul>
-<li>判断字符串是否为回文
-回文是指这样一种现象: 一个单词、 短语或数字, 从前往后写和从后往前写都是一样的。</li>
-</ul>
-
-<pre><code>function isPalindrome(word) {
- var s = new Stack();
- for (var i = 0; i < word. length; ++i) {
- s. push(word[i] );
- }
- var rword = "";
- while (s. length() > 0) {
- rword += s. pop();
- }
- if (word == rword) {
- return true;
- }else {
- return false;
- }
-}
-
-var word = "hello" ;
-if (isPalindrome(word)) {
- console.log(word + " is a palindrome. " );
-}else {
- console.log(word + " is not a palindrome. " );
-}
-word = "racecar"
-if (isPalindrome(word)) {
- console.log(word + " is a palindrome. " );
-}else {
- console.log(word + " is not a palindrome. " );
-}
-</code></pre>
-
-<ul>
-<li>用栈实现函数的递归调用
-求阶乘5! = 5*4*3*2*1 = 120</li>
-</ul>
-
-<pre><code>function factorial(n){
- if(n == 0){
- return 1;
- }else{
- return n * factorial(n-1);
- }
-}
-
-function fact(n){
- var s = new Stack();
- while(n>1){
- s.push(n--);
- }
- var product = 1;
- while(s.length() > 0){
- product *= s.pop();
- }
- return product;
-}
-
-console.log(factorial(5));
-console.log(fact(5));
-</code></pre>
-
- <hr>
- <div class="pagination">
- <ul>
- <ul>
-
- <li class="prev"><a href="/Golang/%E5%88%86%E5%B8%83%E5%BC%8F%E7%AB%AF%E5%8F%A3%E6%98%A0%E5%B0%84NetMapping%E7%9A%84%E8%AE%BE%E8%AE%A1%E4%B8%8E%E5%AE%9E%E7%8E%B0/" title="分布式端口映射NetMapping的设计与实现">← Previous</a></li>
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
- <li class="next"><a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E5%88%97%E8%A1%A8/" title="JavaScript学习笔记-列表">Next →</a></li>
-
-
- </ul>
- </ul>
- </div>
- <hr>
-
-<div id="disqus_thread"></div>
-<script>
- var disqus_developer = 1;
- var disqus_shortname = 'jekyllbootstrap'; // required: replace example with your forum shortname
- /* * * DON'T EDIT BELOW THIS LINE * * */
- (function() {
- var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
- dsq.src = 'http://' + disqus_shortname + '.disqus.com/embed.js';
- (document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
- })();
-</script>
-<noscript>Please enable JavaScript to view the <a href="http://disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript>
-<a href="http://disqus.com" class="dsq-brlink">blog comments powered by <span class="logo-disqus">Disqus</span></a>
-
- </div>
-
- <div class="span4">
- <h4>Published</h4>
- <div class="date"><span>2015-05-29</span></div>
- <br>
- <h4>Categories</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/categories/#JavaScript-ref">JavaScript <span>5</span></a>
-</li>
-
- </ul>
- <br>
- <h4>Tags</h4>
- <ul class="tag_box">
-
- <li>
- <a href="/tags/#JavaScript-ref">JavaScript <span>5</span></a>
-</li>
-
- </ul>
- </div>
-</div>
-
- </div>
-
- <footer>
- <p>© Archer Ding 2013
- with help from <a href="http://github.com/wendal/gor" target="_blank" title="Gor -- Fast Blog">Gor</a>
- and <a href="http://twitter.github.com/bootstrap/" target="_blank">Twitter Bootstrap</a>
- and Idea from <a href="http://ruhoh.com" target="_blank" title="The Definitive Technical Blogging Framework">ruhoh</a>
- </p>
- </footer>
-
- </div> <!-- /container -->
-
-
-<script src="//cdnjscn.b0.upaiyun.com/libs/prettify/r298/prettify.min.js"></script>
-<script>
- var pres = document.getElementsByTagName("pre");
- for (var i=0; i < pres.length; ++i) {
- pres[i].className = "prettyprint linenums";
- }
- prettyPrint();
-</script>
-
-
-<script type="text/javascript">
-
- var _gaq = _gaq || [];
- var pluginUrl = '//www.google-analytics.com/plugins/ga/inpage_linkid.js';
- _gaq.push(['_require', 'inpage_linkid', pluginUrl]);
- _gaq.push(['_setAccount', 'UA-123-12']);
- _gaq.push(['_trackPageview']);
-
- (function() {
- var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
- ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
- var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
- })();
-
-</script>
- </body>
-</html>
diff --git a/about/index.html b/about/index.html
index 5e0f468..49b5283 100644
--- a/about/index.html
+++ b/about/index.html
@@ -1,131 +1,334 @@
-<!DOCTYPE html>
-<html lang="en">
- <head>
- <meta charset="utf-8">
- <title>About Me</title>
-
- <meta name="author" content="Archer Ding">
-
- <!-- Le HTML5 shim, for IE6-8 support of HTML elements -->
- <!--[if lt IE 9]>
- <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
-
- <!-- Le styles -->
- <link href="/assets/twitter/stylesheets/bootstrap.min.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/stylesheets/style.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/widgets/google_prettify/stylesheets/twitter-bootstrap.css" type="text/css" rel="stylesheet" media="all">
-
-
- <!-- Le fav and touch icons -->
- <!-- Update these with your own images
- <link rel="shortcut icon" href="images/favicon.ico">
- <link rel="apple-touch-icon" href="images/apple-touch-icon.png">
- <link rel="apple-touch-icon" sizes="72x72" href="images/apple-touch-icon-72x72.png">
- <link rel="apple-touch-icon" sizes="114x114" href="images/apple-touch-icon-114x114.png">
- -->
- </head>
-
- <body>
-
- <div class="navbar">
- <div class="navbar-inner">
- <div class="container">
- <a class="brand" href="/">ArcherDing's Blog</a>
- <ul class="nav">
-
-
-
-
- <li><a href="/archive">Archive</a></li>
-
-
-
-
-
-
- <li><a href="/tags">Tags</a></li>
-
-
-
-
-
-
- <li><a href="/categories">Categories</a></li>
-
-
-
-
-
-
- <li><a href="/pages">Pages</a></li>
-
-
-
-
- <li class="active"><a href="/about" class="active">About Me</a></li>
-
-
-
-
-
- </ul>
- </div>
- </div>
- </div>
-
- <div class="container">
-
- <div class="content">
-
-<div class="page-header">
- <h1>About Me </h1>
-</div>
-
-<div class="row">
- <div class="span12">
- <p>Hello, how are you?</p>
-
- </div>
-</div>
-
- </div>
-
- <footer>
- <p>© Archer Ding 2013
- with help from <a href="http://github.com/wendal/gor" target="_blank" title="Gor -- Fast Blog">Gor</a>
- and <a href="http://twitter.github.com/bootstrap/" target="_blank">Twitter Bootstrap</a>
- and Idea from <a href="http://ruhoh.com" target="_blank" title="The Definitive Technical Blogging Framework">ruhoh</a>
- </p>
- </footer>
-
- </div> <!-- /container -->
-
-
-<script src="//cdnjscn.b0.upaiyun.com/libs/prettify/r298/prettify.min.js"></script>
-<script>
- var pres = document.getElementsByTagName("pre");
- for (var i=0; i < pres.length; ++i) {
- pres[i].className = "prettyprint linenums";
- }
- prettyPrint();
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="Hexo,next" />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
</script>
-
-
+
+
+
+
+ <title>
+
+
+
+ about // ArcherDing's Notes
+
+</title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column ">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
- var _gaq = _gaq || [];
- var pluginUrl = '//www.google-analytics.com/plugins/ga/inpage_linkid.js';
- _gaq.push(['_require', 'inpage_linkid', pluginUrl]);
- _gaq.push(['_setAccount', 'UA-123-12']);
- _gaq.push(['_trackPageview']);
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
- (function() {
- var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
- ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
- var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
- })();
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
-</script>
- </body>
-</html>
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-expand">
+
+
+
+
+ </div>
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+</body>
+</html>
diff --git a/archive/index.html b/archive/index.html
deleted file mode 100644
index a036370..0000000
--- a/archive/index.html
+++ /dev/null
@@ -1,171 +0,0 @@
-<!DOCTYPE html>
-<html lang="en">
- <head>
- <meta charset="utf-8">
- <title>Archive</title>
-
- <meta name="author" content="Archer Ding">
-
- <!-- Le HTML5 shim, for IE6-8 support of HTML elements -->
- <!--[if lt IE 9]>
- <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
-
- <!-- Le styles -->
- <link href="/assets/twitter/stylesheets/bootstrap.min.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/stylesheets/style.css" type="text/css" rel="stylesheet" media="all">
-<link href="/assets/twitter/widgets/google_prettify/stylesheets/twitter-bootstrap.css" type="text/css" rel="stylesheet" media="all">
-
-
- <!-- Le fav and touch icons -->
- <!-- Update these with your own images
- <link rel="shortcut icon" href="images/favicon.ico">
- <link rel="apple-touch-icon" href="images/apple-touch-icon.png">
- <link rel="apple-touch-icon" sizes="72x72" href="images/apple-touch-icon-72x72.png">
- <link rel="apple-touch-icon" sizes="114x114" href="images/apple-touch-icon-114x114.png">
- -->
- </head>
-
- <body>
-
- <div class="navbar">
- <div class="navbar-inner">
- <div class="container">
- <a class="brand" href="/">ArcherDing's Blog</a>
- <ul class="nav">
-
-
- <li class="active"><a href="/archive" class="active">Archive</a></li>
-
-
-
-
-
-
-
-
- <li><a href="/tags">Tags</a></li>
-
-
-
-
-
-
- <li><a href="/categories">Categories</a></li>
-
-
-
-
-
-
- <li><a href="/pages">Pages</a></li>
-
-
-
-
-
-
- <li><a href="/about">About Me</a></li>
-
-
-
- </ul>
- </div>
- </div>
- </div>
-
- <div class="container">
-
- <div class="content">
-
-<div class="page-header">
- <h1>Archive </h1>
-</div>
-
-<div class="row">
- <div class="span12">
-
-
- <h2>2015</h2>
-
- <h3>June</h3>
- <ul>
-
- <li><span>2015-06-11</span> » <a href="/coredump/%E4%BD%BF%E7%94%A8gdb%E8%A7%A3%E6%9E%90core-dump-%E8%A7%A3%E6%9E%90%E7%AF%87/">使用gdb解析core dump-解析篇</a></li>
-
- <li><span>2015-06-06</span> » <a href="/coredump/%E4%BD%BF%E7%94%A8gdb%E8%A7%A3%E6%9E%90core-dump-%E6%A6%82%E5%BF%B5%E7%AF%87/">使用gdb解析core dump-概念篇</a></li>
-
- </ul>
-
- <h3>May</h3>
- <ul>
-
- <li><span>2015-05-29</span> » <a href="/Golang/%E5%88%86%E5%B8%83%E5%BC%8F%E7%AB%AF%E5%8F%A3%E6%98%A0%E5%B0%84NetMapping%E7%9A%84%E8%AE%BE%E8%AE%A1%E4%B8%8E%E5%AE%9E%E7%8E%B0/">分布式端口映射NetMapping的设计与实现</a></li>
-
- <li><span>2015-05-29</span> » <a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E6%A0%88/">JavaScript学习笔记-栈</a></li>
-
- <li><span>2015-05-29</span> » <a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E5%88%97%E8%A1%A8/">JavaScript学习笔记-列表</a></li>
-
- <li><span>2015-05-29</span> » <a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E6%95%B0%E7%BB%84%E7%BB%83%E4%B9%A0%E9%A2%98/">JavaScript学习笔记-数组练习题</a></li>
-
- <li><span>2015-05-29</span> » <a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E6%95%B0%E7%BB%842/">JavaScript学习笔记-数组2</a></li>
-
- <li><span>2015-05-29</span> » <a href="/JavaScript/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0-%E6%95%B0%E7%BB%84/">JavaScript学习笔记-数组</a></li>
-
- </ul>
-
-
- <h2>2013</h2>
-
- <h3>February</h3>
- <ul>
-
- <li><span>2013-02-08</span> » <a href="/2013/new-born.html">你的第一篇博客</a></li>
-
- </ul>
-
-
-
- </div>
-</div>
-
- </div>
-
- <footer>
- <p>© Archer Ding 2013
- with help from <a href="http://github.com/wendal/gor" target="_blank" title="Gor -- Fast Blog">Gor</a>
- and <a href="http://twitter.github.com/bootstrap/" target="_blank">Twitter Bootstrap</a>
- and Idea from <a href="http://ruhoh.com" target="_blank" title="The Definitive Technical Blogging Framework">ruhoh</a>
- </p>
- </footer>
-
- </div> <!-- /container -->
-
-
-<script src="//cdnjscn.b0.upaiyun.com/libs/prettify/r298/prettify.min.js"></script>
-<script>
- var pres = document.getElementsByTagName("pre");
- for (var i=0; i < pres.length; ++i) {
- pres[i].className = "prettyprint linenums";
- }
- prettyPrint();
-</script>
-
-
-<script type="text/javascript">
-
- var _gaq = _gaq || [];
- var pluginUrl = '//www.google-analytics.com/plugins/ga/inpage_linkid.js';
- _gaq.push(['_require', 'inpage_linkid', pluginUrl]);
- _gaq.push(['_setAccount', 'UA-123-12']);
- _gaq.push(['_trackPageview']);
-
- (function() {
- var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
- ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
- var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
- })();
-
-</script>
- </body>
-</html>
diff --git a/archives/2015/05/index.html b/archives/2015/05/index.html
new file mode 100644
index 0000000..6df8798
--- /dev/null
+++ b/archives/2015/05/index.html
@@ -0,0 +1,542 @@
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="Hexo,next" />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
+</script>
+
+
+
+
+ <title> 归档 // ArcherDing's Notes </title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column page-archive ">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
+<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
+
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
+
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
+
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-collapse">
+ <span class="archive-move-on"></span>
+
+ <span class="archive-page-counter">
+
+
+
+
+
+ 嗯..! 目前共计 8 篇日志。 继续努力。
+ </span>
+
+
+
+
+
+
+
+
+
+ <div class="collection-title">
+ <h2 class="archive-year motion-element" id="archive-year-2015">2015</h2>
+ </div>
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-01/">
+ JavaScript学习笔记-数组
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-03/">
+ JavaScript学习笔记-数组练习题
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-02/">
+ JavaScript学习笔记-数组2
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-04/">
+ JavaScript学习笔记-列表
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-05/">
+ JavaScript学习笔记-栈
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/netmapping-01/">
+ 分布式端口映射NetMapping的设计与实现
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+ <script type="text/javascript">
+ postMotionOptions = {stagger: 100, drag: true};
+ </script>
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+ <script type="text/javascript" id="motion.page.archive">
+ $('.archive-year').velocity('transition.slideLeftIn');
+ </script>
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+</body>
+</html>
diff --git a/archives/2015/06/index.html b/archives/2015/06/index.html
new file mode 100644
index 0000000..085361a
--- /dev/null
+++ b/archives/2015/06/index.html
@@ -0,0 +1,418 @@
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="Hexo,next" />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
+</script>
+
+
+
+
+ <title> 归档 // ArcherDing's Notes </title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column page-archive ">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
+<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
+
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
+
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
+
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-collapse">
+ <span class="archive-move-on"></span>
+
+ <span class="archive-page-counter">
+
+
+
+
+
+ 嗯..! 目前共计 8 篇日志。 继续努力。
+ </span>
+
+
+
+
+
+
+
+
+
+ <div class="collection-title">
+ <h2 class="archive-year motion-element" id="archive-year-2015">2015</h2>
+ </div>
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/06/11/coredump-02/">
+ 使用gdb解析core dump-解析篇
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 06-11 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/06/06/coredump-01/">
+ 使用gdb解析core dump-概念篇
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 06-06 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+ <script type="text/javascript">
+ postMotionOptions = {stagger: 100, drag: true};
+ </script>
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+ <script type="text/javascript" id="motion.page.archive">
+ $('.archive-year').velocity('transition.slideLeftIn');
+ </script>
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+</body>
+</html>
diff --git a/archives/2015/index.html b/archives/2015/index.html
new file mode 100644
index 0000000..0d33c4c
--- /dev/null
+++ b/archives/2015/index.html
@@ -0,0 +1,604 @@
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="Hexo,next" />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
+</script>
+
+
+
+
+ <title> 归档 // ArcherDing's Notes </title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column page-archive ">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
+<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
+
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
+
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
+
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-collapse">
+ <span class="archive-move-on"></span>
+
+ <span class="archive-page-counter">
+
+
+
+
+
+ 嗯..! 目前共计 8 篇日志。 继续努力。
+ </span>
+
+
+
+
+
+
+
+
+
+ <div class="collection-title">
+ <h2 class="archive-year motion-element" id="archive-year-2015">2015</h2>
+ </div>
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/06/11/coredump-02/">
+ 使用gdb解析core dump-解析篇
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 06-11 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/06/06/coredump-01/">
+ 使用gdb解析core dump-概念篇
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 06-06 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-01/">
+ JavaScript学习笔记-数组
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-03/">
+ JavaScript学习笔记-数组练习题
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-02/">
+ JavaScript学习笔记-数组2
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-04/">
+ JavaScript学习笔记-列表
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-05/">
+ JavaScript学习笔记-栈
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/netmapping-01/">
+ 分布式端口映射NetMapping的设计与实现
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+ <script type="text/javascript">
+ postMotionOptions = {stagger: 100, drag: true};
+ </script>
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+ <script type="text/javascript" id="motion.page.archive">
+ $('.archive-year').velocity('transition.slideLeftIn');
+ </script>
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+</body>
+</html>
diff --git a/archives/index.html b/archives/index.html
new file mode 100644
index 0000000..0d33c4c
--- /dev/null
+++ b/archives/index.html
@@ -0,0 +1,604 @@
+<!doctype html>
+<html class="theme-next use-motion theme-next-mist">
+<head>
+
+
+<meta charset="UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
+<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>
+
+
+
+
+
+
+ <link rel="stylesheet" type="text/css" href="/vendors/fancybox/source/jquery.fancybox.css?v=2.1.5"/>
+
+
+<link rel="stylesheet" type="text/css" href="/css/main.css?v=0.4.3"/>
+
+
+ <meta name="description" content="技术成就梦想,执着创造未来!" />
+
+
+
+ <meta name="keywords" content="Hexo,next" />
+
+
+
+
+
+ <link rel="shorticon icon" type="image/x-icon" href="/favicon.ico?v=0.4.3" />
+
+
+
+<script type="text/javascript" id="hexo.configuration">
+ var CONFIG = {
+ scheme: 'Mist',
+ analytics: {
+ google: ''
+ },
+ sidebar: 'post'
+ };
+</script>
+
+
+
+
+ <title> 归档 // ArcherDing's Notes </title>
+</head>
+
+<body>
+ <!--[if lte IE 8]>
+ <div style=' clear: both; height: 59px; padding:0 0 0 15px; position: relative;margin:0 auto;'>
+ <a href="http://windows.microsoft.com/en-US/internet-explorer/products/ie/home?ocid=ie6_countdown_bannercode">
+ <img src="http://7u2nvr.com1.z0.glb.clouddn.com/picouterie.jpg" border="0" height="42" width="820"
+ alt="You are using an outdated browser. For a faster, safer browsing experience, upgrade for free today or use other browser ,like chrome firefox safari."
+ style='margin-left:auto;margin-right:auto;display: block;'/>
+ </a>
+ </div>
+<![endif]-->
+
+ <div class="container one-column page-archive ">
+ <div class="headband"></div>
+
+ <div id="header" class="header">
+ <div class="header-inner">
+ <h1 class="site-meta">
+ <span class="logo-line-before"><i></i></span>
+ <a href="/" class="brand">
+ <span class="logo">
+ <i class="icon-logo"></i>
+ </span>
+ <span class="site-title">ArcherDing's Notes</span>
+ </a>
+ <span class="logo-line-after"><i></i></span>
+</h1>
+
+<div class="site-nav-toggle">
+ <button>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ <span class="btn-bar"></span>
+ </button>
+</div>
+
+<div class="site-nav">
+
+
+
+ <ul id="menu" class="menu menu-left">
+
+
+ <li class="menu-item menu-item-home">
+ <a href="/">
+ <i class="menu-item-icon icon-home"></i> <br />
+ 首页
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-categories">
+ <a href="/categories">
+ <i class="menu-item-icon icon-categories"></i> <br />
+ 分类
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-archives">
+ <a href="/archives">
+ <i class="menu-item-icon icon-archives"></i> <br />
+ 归档
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-tags">
+ <a href="/tags">
+ <i class="menu-item-icon icon-tags"></i> <br />
+ 标签
+ </a>
+ </li>
+
+
+ <li class="menu-item menu-item-about">
+ <a href="/about">
+ <i class="menu-item-icon icon-about"></i> <br />
+ 关于
+ </a>
+ </li>
+
+ </ul>
+
+
+
+ <div class="site-search">
+
+
+<form class="site-search-form">
+ <input type="text" id="st-search-input" class="st-search-input st-default-search-input" />
+</form>
+<script type="text/javascript">
+ (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){
+ (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);
+ e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);
+ })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');
+
+ _st('install', 'DPoFkRrVKwYPPTVoCWjM','2.0.0');
+</script>
+
+<div class="site-search-toggle"></div>
+ </div>
+
+</div>
+
+
+ </div>
+ </div>
+
+ <div id="main" class="main">
+ <div class="main-inner">
+ <div id="content" class="content">
+
+
+ <div id="posts" class="posts-collapse">
+ <span class="archive-move-on"></span>
+
+ <span class="archive-page-counter">
+
+
+
+
+
+ 嗯..! 目前共计 8 篇日志。 继续努力。
+ </span>
+
+
+
+
+
+
+
+
+
+ <div class="collection-title">
+ <h2 class="archive-year motion-element" id="archive-year-2015">2015</h2>
+ </div>
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/06/11/coredump-02/">
+ 使用gdb解析core dump-解析篇
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 06-11 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/06/06/coredump-01/">
+ 使用gdb解析core dump-概念篇
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 06-06 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-01/">
+ JavaScript学习笔记-数组
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-03/">
+ JavaScript学习笔记-数组练习题
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-02/">
+ JavaScript学习笔记-数组2
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-04/">
+ JavaScript学习笔记-列表
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/javascript-note-05/">
+ JavaScript学习笔记-栈
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <div class="post post-type-normal">
+ <div class="post-header">
+
+ <div class="post-title">
+
+ <a class="post-title-link" href="/2015/05/29/netmapping-01/">
+ 分布式端口映射NetMapping的设计与实现
+ </a>
+
+ </div>
+
+ <div class="post-meta">
+ <span class="post-time"> 05-29 </span>
+ </div>
+
+ </div>
+ </div>
+
+
+
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+ </div>
+
+
+
+
+ <div class="sidebar-toggle">
+ <div class="sidebar-toggle-line-wrap">
+ <span class="sidebar-toggle-line sidebar-toggle-line-first"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-middle"></span>
+ <span class="sidebar-toggle-line sidebar-toggle-line-last"></span>
+ </div>
+ </div>
+
+ <div id="sidebar" class="sidebar">
+ <div class="sidebar-inner">
+
+
+
+ <div class="site-overview">
+ <div class="site-author motion-element">
+ <img class="site-author-image" src="/images/avatar.jpg" alt="ArcherDing" />
+ <p class="site-author-name">ArcherDing</p>
+ </div>
+ <p class="site-description motion-element">技术成就梦想,执着创造未来!</p>
+ <div class="site-state motion-element">
+ <div class="site-state-item site-state-posts">
+ <a href="/archives">
+ <span class="site-state-item-count">8</span>
+ <span class="site-state-item-name">日志</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-categories">
+ <a href="/categories">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">分类</span>
+ </a>
+ </div>
+
+ <div class="site-state-item site-state-tags">
+ <a href="/tags">
+ <span class="site-state-item-count">3</span>
+ <span class="site-state-item-name">标签</span>
+ </a>
+ </div>
+
+ </div>
+
+
+
+ <div class="links-of-author motion-element">
+
+
+ <span class="links-of-author-item">
+ <a href="https://github.com/archerding" target="_blank">github</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://weibo.com/2732911514" target="_blank">weibo</a>
+ </span>
+
+ <span class="links-of-author-item">
+ <a href="http://www.zhihu.com/people/archerding" target="_blank">zhihu</a>
+ </span>
+
+
+ </div>
+
+
+
+
+ </div>
+
+
+
+ </div>
+ </div>
+
+
+ </div>
+
+ <div id="footer" class="footer">
+ <div class="footer-inner">
+ <div class="copyright">
+
+ ©
+ 2015
+ <span class="with-love">
+ <i class="icon-heart"></i>
+ </span>
+ <span class="author">ArcherDing</span>
+</div>
+
+<div class="powered-by">
+ 由 <a class="theme-link" href="http://hexo.io">Hexo</a> 强力驱动
+</div>
+
+<div class="theme-info">
+ 主题 -
+ <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
+ NexT.Mist
+ </a>
+</div>
+
+
+
+ </div>
+ </div>
+
+ <div class="back-to-top"></div>
+ </div>
+
+ <script type="text/javascript" src="/vendors/jquery/index.js?v=2.1.3"></script>
+
+
+
+
+ <script type="text/javascript">
+ postMotionOptions = {stagger: 100, drag: true};
+ </script>
+
+
+
+
+ <script type="text/javascript" src="/vendors/fancybox/source/jquery.fancybox.pack.js"></script>
+ <script type="text/javascript" src="/js/fancy-box.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/js/helpers.js?v=0.4.3"></script>
+
+
+ <script type="text/javascript" src="/vendors/velocity/velocity.min.js"></script>
+ <script type="text/javascript" src="/vendors/velocity/velocity.ui.min.js"></script>
+
+ <script type="text/javascript" src="/js/motion_global.js?v=0.4.3" id="motion.global"></script>
+
+
+
+ <script type="text/javascript" src="/js/search-toggle.js"></script>
+
+
+
+ <script type="text/javascript" id="motion.page.archive">
+ $('.archive-year').velocity('transition.slideLeftIn');
+ </script>
+
+
+
+ <script type="text/javascript">
+ $(document).ready(function () {
+ if (CONFIG.sidebar === 'always') {
+ displaySidebar();
+ }
+ });
+ </script>
+
+
+
+
+
+
+
+
+</body>
+</html>
diff --git a/assets/twitter/layouts/default.html b/assets/twitter/layouts/default.html
deleted file mode 100644
index 0435d10..0000000
--- a/assets/twitter/layouts/default.html
+++ /dev/null
@@ -1,62 +0,0 @@
-<!DOCTYPE html>
-<html lang="en">
- <head>
- <meta charset="utf-8">
- <title>{{ page.title }}</title>
- {{# page.description }}
- <meta name="description" content="{{ . }}">
- {{/ page.description }}
- <meta name="author" content="{{ site.author.name }}">
-
- <!-- Le HTML5 shim, for IE6-8 support of HTML elements -->
- <!--[if lt IE 9]>
- <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
-
- <!-- Le styles -->
- {{{ assets }}}
-
- <!-- Le fav and touch icons -->
- <!-- Update these with your own images
- <link rel="shortcut icon" href="images/favicon.ico">
- <link rel="apple-touch-icon" href="images/apple-touch-icon.png">
- <link rel="apple-touch-icon" sizes="72x72" href="images/apple-touch-icon-72x72.png">
- <link rel="apple-touch-icon" sizes="114x114" href="images/apple-touch-icon-114x114.png">
- -->
- </head>
-
- <body>
-
- <div class="navbar">
- <div class="navbar-inner">
- <div class="container">
- <a class="brand" href="/">{{ site.title }}</a>
- <ul class="nav">
- {{# site.navigation?to_pages }}
- {{> pages_list }}
- {{/ site.navigation?to_pages }}
- </ul>
- </div>
- </div>
- </div>
-
- <div class="container">
-
- <div class="content">
- {{{ content }}}
- </div>
-
- <footer>
- <p>© {{ site.author.name }} 2013
- with help from <a href="http://github.com/wendal/gor" target="_blank" title="Gor -- Fast Blog">Gor</a>
- and <a href="http://twitter.github.com/bootstrap/" target="_blank">Twitter Bootstrap</a>
- and Idea from <a href="http://ruhoh.com" target="_blank" title="The Definitive Technical Blogging Framework">ruhoh</a>
- </p>
- </footer>
-
- </div> <!-- /container -->
-
- {{{ google_prettify }}}
- {{{ analytics }}}
- </body>
-</html>
diff --git a/assets/twitter/layouts/page.html b/assets/twitter/layouts/page.html
deleted file mode 100644
index 666058f..0000000
--- a/assets/twitter/layouts/page.html
+++ /dev/null
@@ -1,13 +0,0 @@
----
-layout : default
----
-
-<div class="page-header">
- <h1>{{ page.title }} {{# page.tagline }} <small>{{ . }}</small>{{/ page.tagline }}</h1>
-</div>
-
-<div class="row">
- <div class="span12">
- {{{ content }}}
- </div>
-</div>
diff --git a/assets/twitter/layouts/post.html b/assets/twitter/layouts/post.html
deleted file mode 100644
index 6668b80..0000000
--- a/assets/twitter/layouts/post.html
+++ /dev/null
@@ -1,55 +0,0 @@
----
-layout : default
----
-<div class="page-header">
- <h1>{{ page.title }} {{# page.tagline }} <small>{{ . }}</small>{{/ page.tagline }}</h1>
-</div>
-
-<div class="row">
- <div class="span8">
- {{{ content }}}
- <hr>
- <div class="pagination">
- <ul>
- <ul>
- {{# page?previous }}
- <li class="prev"><a href="{{ url }}" title="{{ title }}">← Previous</a></li>
- {{/ page?previous }}
- {{^ page?previous }}
- <li class="prev disabled"><a>← Previous</a></li>
- {{/ page?previous }}
-
- <li><a href="/archive">Archive</a></li>
-
- {{# page?next }}
- <li class="next"><a href="{{ url }}" title="{{ title }}">Next →</a></li>
- {{/ page?next }}
- {{^ page?next }}
- <li class="next disabled"><a>Next →</a>
- {{/ page?next }}
- </ul>
- </ul>
- </div>
- <hr>
- {{{ comments }}}
- </div>
-
- <div class="span4">
- <h4>Published</h4>
- <div class="date"><span>{{ page.date }}</span></div>
- <br>
- <h4>Categories</h4>
- <ul class="tag_box">
- {{# page.categories?to_categories }}
- {{> categories_list }}
- {{/ page.categories?to_categories }}
- </ul>
- <br>
- <h4>Tags</h4>
- <ul class="tag_box">
- {{# page.tags?to_tags }}
- {{> tags_list }}
- {{/ page.tags?to_tags }}
- </ul>
- </div>
-</div>
diff --git a/assets/twitter/media/glyphicons-halflings-white.png b/assets/twitter/media/glyphicons-halflings-white.png
deleted file mode 100644
index a20760b..0000000
--- a/assets/twitter/media/glyphicons-halflings-white.png
+++ /dev/null
Binary files differ
diff --git a/assets/twitter/media/glyphicons-halflings.png b/assets/twitter/media/glyphicons-halflings.png
deleted file mode 100644
index 92d4445..0000000
--- a/assets/twitter/media/glyphicons-halflings.png
+++ /dev/null
Binary files differ
diff --git a/assets/twitter/stylesheets/bootstrap.min.css b/assets/twitter/stylesheets/bootstrap.min.css
deleted file mode 100644
index 34fd70c..0000000
--- a/assets/twitter/stylesheets/bootstrap.min.css
+++ /dev/null
@@ -1,689 +0,0 @@
-article,aside,details,figcaption,figure,footer,header,hgroup,nav,section{display:block;}
-audio,canvas,video{display:inline-block;*display:inline;*zoom:1;}
-audio:not([controls]){display:none;}
-html{font-size:100%;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;}
-a:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px;}
-a:hover,a:active{outline:0;}
-sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline;}
-sup{top:-0.5em;}
-sub{bottom:-0.25em;}
-img{height:auto;border:0;-ms-interpolation-mode:bicubic;vertical-align:middle;}
-button,input,select,textarea{margin:0;font-size:100%;vertical-align:middle;}
-button,input{*overflow:visible;line-height:normal;}
-button::-moz-focus-inner,input::-moz-focus-inner{padding:0;border:0;}
-button,input[type="button"],input[type="reset"],input[type="submit"]{cursor:pointer;-webkit-appearance:button;}
-input[type="search"]{-webkit-appearance:textfield;-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;}
-input[type="search"]::-webkit-search-decoration,input[type="search"]::-webkit-search-cancel-button{-webkit-appearance:none;}
-textarea{overflow:auto;vertical-align:top;}
-.clearfix{*zoom:1;}.clearfix:before,.clearfix:after{display:table;content:"";}
-.clearfix:after{clear:both;}
-.hide-text{overflow:hidden;text-indent:100%;white-space:nowrap;}
-.input-block-level{display:block;width:100%;min-height:28px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box;}
-body{margin:0;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:13px;line-height:18px;color:#333333;background-color:#ffffff;}
-a{color:#0088cc;text-decoration:none;}
-a:hover{color:#005580;text-decoration:underline;}
-.row{margin-left:-20px;*zoom:1;}.row:before,.row:after{display:table;content:"";}
-.row:after{clear:both;}
-[class*="span"]{float:left;margin-left:20px;}
-.container,.navbar-fixed-top .container,.navbar-fixed-bottom .container{width:940px;}
-.span12{width:940px;}
-.span11{width:860px;}
-.span10{width:780px;}
-.span9{width:700px;}
-.span8{width:620px;}
-.span7{width:540px;}
-.span6{width:460px;}
-.span5{width:380px;}
-.span4{width:300px;}
-.span3{width:220px;}
-.span2{width:140px;}
-.span1{width:60px;}
-.offset12{margin-left:980px;}
-.offset11{margin-left:900px;}
-.offset10{margin-left:820px;}
-.offset9{margin-left:740px;}
-.offset8{margin-left:660px;}
-.offset7{margin-left:580px;}
-.offset6{margin-left:500px;}
-.offset5{margin-left:420px;}
-.offset4{margin-left:340px;}
-.offset3{margin-left:260px;}
-.offset2{margin-left:180px;}
-.offset1{margin-left:100px;}
-.row-fluid{width:100%;*zoom:1;}.row-fluid:before,.row-fluid:after{display:table;content:"";}
-.row-fluid:after{clear:both;}
-.row-fluid>[class*="span"]{float:left;margin-left:2.127659574%;}
-.row-fluid>[class*="span"]:first-child{margin-left:0;}
-.row-fluid > .span12{width:99.99999998999999%;}
-.row-fluid > .span11{width:91.489361693%;}
-.row-fluid > .span10{width:82.97872339599999%;}
-.row-fluid > .span9{width:74.468085099%;}
-.row-fluid > .span8{width:65.95744680199999%;}
-.row-fluid > .span7{width:57.446808505%;}
-.row-fluid > .span6{width:48.93617020799999%;}
-.row-fluid > .span5{width:40.425531911%;}
-.row-fluid > .span4{width:31.914893614%;}
-.row-fluid > .span3{width:23.404255317%;}
-.row-fluid > .span2{width:14.89361702%;}
-.row-fluid > .span1{width:6.382978723%;}
-.container{margin-left:auto;margin-right:auto;*zoom:1;}.container:before,.container:after{display:table;content:"";}
-.container:after{clear:both;}
-.container-fluid{padding-left:20px;padding-right:20px;*zoom:1;}.container-fluid:before,.container-fluid:after{display:table;content:"";}
-.container-fluid:after{clear:both;}
-p{margin:0 0 9px;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:13px;line-height:18px;}p small{font-size:11px;color:#999999;}
-.lead{margin-bottom:18px;font-size:20px;font-weight:200;line-height:27px;}
-h1,h2,h3,h4,h5,h6{margin:0;font-family:inherit;font-weight:bold;color:inherit;text-rendering:optimizelegibility;}h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{font-weight:normal;color:#999999;}
-h1{font-size:30px;line-height:36px;}h1 small{font-size:18px;}
-h2{font-size:24px;line-height:36px;}h2 small{font-size:18px;}
-h3{line-height:27px;font-size:18px;}h3 small{font-size:14px;}
-h4,h5,h6{line-height:18px;}
-h4{font-size:14px;}h4 small{font-size:12px;}
-h5{font-size:12px;}
-h6{font-size:11px;color:#999999;text-transform:uppercase;}
-.page-header{padding-bottom:17px;margin:18px 0;border-bottom:1px solid #eeeeee;}
-.page-header h1{line-height:1;}
-ul,ol{padding:0;margin:0 0 9px 25px;}
-ul ul,ul ol,ol ol,ol ul{margin-bottom:0;}
-ul{list-style:disc;}
-ol{list-style:decimal;}
-li{line-height:18px;}
-ul.unstyled,ol.unstyled{margin-left:0;list-style:none;}
-dl{margin-bottom:18px;}
-dt,dd{line-height:18px;}
-dt{font-weight:bold;line-height:17px;}
-dd{margin-left:9px;}
-.dl-horizontal dt{float:left;clear:left;width:120px;text-align:right;}
-.dl-horizontal dd{margin-left:130px;}
-hr{margin:18px 0;border:0;border-top:1px solid #eeeeee;border-bottom:1px solid #ffffff;}
-strong{font-weight:bold;}
-em{font-style:italic;}
-.muted{color:#999999;}
-abbr[title]{border-bottom:1px dotted #ddd;cursor:help;}
-abbr.initialism{font-size:90%;text-transform:uppercase;}
-blockquote{padding:0 0 0 15px;margin:0 0 18px;border-left:5px solid #eeeeee;}blockquote p{margin-bottom:0;font-size:16px;font-weight:300;line-height:22.5px;}
-blockquote small{display:block;line-height:18px;color:#999999;}blockquote small:before{content:'\2014 \00A0';}
-blockquote.pull-right{float:right;padding-left:0;padding-right:15px;border-left:0;border-right:5px solid #eeeeee;}blockquote.pull-right p,blockquote.pull-right small{text-align:right;}
-q:before,q:after,blockquote:before,blockquote:after{content:"";}
-address{display:block;margin-bottom:18px;line-height:18px;font-style:normal;}
-small{font-size:100%;}
-cite{font-style:normal;}
-code,pre{padding:0 3px 2px;font-family:Menlo,Monaco,"Courier New",monospace;font-size:12px;color:#333333;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;}
-code{padding:2px 4px;color:#d14;background-color:#f7f7f9;border:1px solid #e1e1e8;}
-pre{display:block;padding:8.5px;margin:0 0 9px;font-size:12.025px;line-height:18px;background-color:#f5f5f5;border:1px solid #ccc;border:1px solid rgba(0, 0, 0, 0.15);-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;white-space:pre;white-space:pre-wrap;word-break:break-all;word-wrap:break-word;}pre.prettyprint{margin-bottom:18px;}
-pre code{padding:0;color:inherit;background-color:transparent;border:0;}
-.pre-scrollable{max-height:340px;overflow-y:scroll;}
-form{margin:0 0 18px;}
-fieldset{padding:0;margin:0;border:0;}
-legend{display:block;width:100%;padding:0;margin-bottom:27px;font-size:19.5px;line-height:36px;color:#333333;border:0;border-bottom:1px solid #eee;}legend small{font-size:13.5px;color:#999999;}
-label,input,button,select,textarea{font-size:13px;font-weight:normal;line-height:18px;}
-input,button,select,textarea{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;}
-label{display:block;margin-bottom:5px;color:#333333;}
-input,textarea,select,.uneditable-input{display:inline-block;width:210px;height:18px;padding:4px;margin-bottom:9px;font-size:13px;line-height:18px;color:#555555;border:1px solid #cccccc;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;}
-.uneditable-textarea{width:auto;height:auto;}
-label input,label textarea,label select{display:block;}
-input[type="image"],input[type="checkbox"],input[type="radio"]{width:auto;height:auto;padding:0;margin:3px 0;*margin-top:0;line-height:normal;cursor:pointer;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0;border:0 \9;}
-input[type="image"]{border:0;}
-input[type="file"]{width:auto;padding:initial;line-height:initial;border:initial;background-color:#ffffff;background-color:initial;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;}
-input[type="button"],input[type="reset"],input[type="submit"]{width:auto;height:auto;}
-select,input[type="file"]{height:28px;*margin-top:4px;line-height:28px;}
-input[type="file"]{line-height:18px \9;}
-select{width:220px;background-color:#ffffff;}
-select[multiple],select[size]{height:auto;}
-input[type="image"]{-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;}
-textarea{height:auto;}
-input[type="hidden"]{display:none;}
-.radio,.checkbox{padding-left:18px;}
-.radio input[type="radio"],.checkbox input[type="checkbox"]{float:left;margin-left:-18px;}
-.controls>.radio:first-child,.controls>.checkbox:first-child{padding-top:5px;}
-.radio.inline,.checkbox.inline{display:inline-block;padding-top:5px;margin-bottom:0;vertical-align:middle;}
-.radio.inline+.radio.inline,.checkbox.inline+.checkbox.inline{margin-left:10px;}
-input,textarea{-webkit-box-shadow:inset 0 1px 1px rgba(0, 0, 0, 0.075);-moz-box-shadow:inset 0 1px 1px rgba(0, 0, 0, 0.075);box-shadow:inset 0 1px 1px rgba(0, 0, 0, 0.075);-webkit-transition:border linear 0.2s,box-shadow linear 0.2s;-moz-transition:border linear 0.2s,box-shadow linear 0.2s;-ms-transition:border linear 0.2s,box-shadow linear 0.2s;-o-transition:border linear 0.2s,box-shadow linear 0.2s;transition:border linear 0.2s,box-shadow linear 0.2s;}
-input:focus,textarea:focus{border-color:rgba(82, 168, 236, 0.8);-webkit-box-shadow:inset 0 1px 1px rgba(0, 0, 0, 0.075),0 0 8px rgba(82, 168, 236, 0.6);-moz-box-shadow:inset 0 1px 1px rgba(0, 0, 0, 0.075),0 0 8px rgba(82, 168, 236, 0.6);box-shadow:inset 0 1px 1px rgba(0, 0, 0, 0.075),0 0 8px rgba(82, 168, 236, 0.6);outline:0;outline:thin dotted \9;}
-input[type="file"]:focus,input[type="radio"]:focus,input[type="checkbox"]:focus,select:focus{-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px;}
-.input-mini{width:60px;}
-.input-small{width:90px;}
-.input-medium{width:150px;}
-.input-large{width:210px;}
-.input-xlarge{width:270px;}
-.input-xxlarge{width:530px;}
-input[class*="span"],select[class*="span"],textarea[class*="span"],.uneditable-input{float:none;margin-left:0;}
-input,textarea,.uneditable-input{margin-left:0;}
-input.span12, textarea.span12, .uneditable-input.span12{width:930px;}
-input.span11, textarea.span11, .uneditable-input.span11{width:850px;}
-input.span10, textarea.span10, .uneditable-input.span10{width:770px;}
-input.span9, textarea.span9, .uneditable-input.span9{width:690px;}
-input.span8, textarea.span8, .uneditable-input.span8{width:610px;}
-input.span7, textarea.span7, .uneditable-input.span7{width:530px;}
-input.span6, textarea.span6, .uneditable-input.span6{width:450px;}
-input.span5, textarea.span5, .uneditable-input.span5{width:370px;}
-input.span4, textarea.span4, .uneditable-input.span4{width:290px;}
-input.span3, textarea.span3, .uneditable-input.span3{width:210px;}
-input.span2, textarea.span2, .uneditable-input.span2{width:130px;}
-input.span1, textarea.span1, .uneditable-input.span1{width:50px;}
-input[disabled],select[disabled],textarea[disabled],input[readonly],select[readonly],textarea[readonly]{background-color:#eeeeee;border-color:#ddd;cursor:not-allowed;}
-.control-group.warning>label,.control-group.warning .help-block,.control-group.warning .help-inline{color:#c09853;}
-.control-group.warning input,.control-group.warning select,.control-group.warning textarea{color:#c09853;border-color:#c09853;}.control-group.warning input:focus,.control-group.warning select:focus,.control-group.warning textarea:focus{border-color:#a47e3c;-webkit-box-shadow:0 0 6px #dbc59e;-moz-box-shadow:0 0 6px #dbc59e;box-shadow:0 0 6px #dbc59e;}
-.control-group.warning .input-prepend .add-on,.control-group.warning .input-append .add-on{color:#c09853;background-color:#fcf8e3;border-color:#c09853;}
-.control-group.error>label,.control-group.error .help-block,.control-group.error .help-inline{color:#b94a48;}
-.control-group.error input,.control-group.error select,.control-group.error textarea{color:#b94a48;border-color:#b94a48;}.control-group.error input:focus,.control-group.error select:focus,.control-group.error textarea:focus{border-color:#953b39;-webkit-box-shadow:0 0 6px #d59392;-moz-box-shadow:0 0 6px #d59392;box-shadow:0 0 6px #d59392;}
-.control-group.error .input-prepend .add-on,.control-group.error .input-append .add-on{color:#b94a48;background-color:#f2dede;border-color:#b94a48;}
-.control-group.success>label,.control-group.success .help-block,.control-group.success .help-inline{color:#468847;}
-.control-group.success input,.control-group.success select,.control-group.success textarea{color:#468847;border-color:#468847;}.control-group.success input:focus,.control-group.success select:focus,.control-group.success textarea:focus{border-color:#356635;-webkit-box-shadow:0 0 6px #7aba7b;-moz-box-shadow:0 0 6px #7aba7b;box-shadow:0 0 6px #7aba7b;}
-.control-group.success .input-prepend .add-on,.control-group.success .input-append .add-on{color:#468847;background-color:#dff0d8;border-color:#468847;}
-input:focus:required:invalid,textarea:focus:required:invalid,select:focus:required:invalid{color:#b94a48;border-color:#ee5f5b;}input:focus:required:invalid:focus,textarea:focus:required:invalid:focus,select:focus:required:invalid:focus{border-color:#e9322d;-webkit-box-shadow:0 0 6px #f8b9b7;-moz-box-shadow:0 0 6px #f8b9b7;box-shadow:0 0 6px #f8b9b7;}
-.form-actions{padding:17px 20px 18px;margin-top:18px;margin-bottom:18px;background-color:#eeeeee;border-top:1px solid #ddd;*zoom:1;}.form-actions:before,.form-actions:after{display:table;content:"";}
-.form-actions:after{clear:both;}
-.uneditable-input{display:block;background-color:#ffffff;border-color:#eee;-webkit-box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.025);-moz-box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.025);box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.025);cursor:not-allowed;}
-:-moz-placeholder{color:#999999;}
-::-webkit-input-placeholder{color:#999999;}
-.help-block,.help-inline{color:#555555;}
-.help-block{display:block;margin-bottom:9px;}
-.help-inline{display:inline-block;*display:inline;*zoom:1;vertical-align:middle;padding-left:5px;}
-.input-prepend,.input-append{margin-bottom:5px;}.input-prepend input,.input-append input,.input-prepend select,.input-append select,.input-prepend .uneditable-input,.input-append .uneditable-input{*margin-left:0;-webkit-border-radius:0 3px 3px 0;-moz-border-radius:0 3px 3px 0;border-radius:0 3px 3px 0;}.input-prepend input:focus,.input-append input:focus,.input-prepend select:focus,.input-append select:focus,.input-prepend .uneditable-input:focus,.input-append .uneditable-input:focus{position:relative;z-index:2;}
-.input-prepend .uneditable-input,.input-append .uneditable-input{border-left-color:#ccc;}
-.input-prepend .add-on,.input-append .add-on{display:inline-block;width:auto;min-width:16px;height:18px;padding:4px 5px;font-weight:normal;line-height:18px;text-align:center;text-shadow:0 1px 0 #ffffff;vertical-align:middle;background-color:#eeeeee;border:1px solid #ccc;}
-.input-prepend .add-on,.input-append .add-on,.input-prepend .btn,.input-append .btn{-webkit-border-radius:3px 0 0 3px;-moz-border-radius:3px 0 0 3px;border-radius:3px 0 0 3px;}
-.input-prepend .active,.input-append .active{background-color:#a9dba9;border-color:#46a546;}
-.input-prepend .add-on,.input-prepend .btn{margin-right:-1px;}
-.input-append input,.input-append select .uneditable-input{-webkit-border-radius:3px 0 0 3px;-moz-border-radius:3px 0 0 3px;border-radius:3px 0 0 3px;}
-.input-append .uneditable-input{border-left-color:#eee;border-right-color:#ccc;}
-.input-append .add-on,.input-append .btn{margin-left:-1px;-webkit-border-radius:0 3px 3px 0;-moz-border-radius:0 3px 3px 0;border-radius:0 3px 3px 0;}
-.input-prepend.input-append input,.input-prepend.input-append select,.input-prepend.input-append .uneditable-input{-webkit-border-radius:0;-moz-border-radius:0;border-radius:0;}
-.input-prepend.input-append .add-on:first-child,.input-prepend.input-append .btn:first-child{margin-right:-1px;-webkit-border-radius:3px 0 0 3px;-moz-border-radius:3px 0 0 3px;border-radius:3px 0 0 3px;}
-.input-prepend.input-append .add-on:last-child,.input-prepend.input-append .btn:last-child{margin-left:-1px;-webkit-border-radius:0 3px 3px 0;-moz-border-radius:0 3px 3px 0;border-radius:0 3px 3px 0;}
-.search-query{padding-left:14px;padding-right:14px;margin-bottom:0;-webkit-border-radius:14px;-moz-border-radius:14px;border-radius:14px;}
-.form-search input,.form-inline input,.form-horizontal input,.form-search textarea,.form-inline textarea,.form-horizontal textarea,.form-search select,.form-inline select,.form-horizontal select,.form-search .help-inline,.form-inline .help-inline,.form-horizontal .help-inline,.form-search .uneditable-input,.form-inline .uneditable-input,.form-horizontal .uneditable-input,.form-search .input-prepend,.form-inline .input-prepend,.form-horizontal .input-prepend,.form-search .input-append,.form-inline .input-append,.form-horizontal .input-append{display:inline-block;margin-bottom:0;}
-.form-search .hide,.form-inline .hide,.form-horizontal .hide{display:none;}
-.form-search label,.form-inline label{display:inline-block;}
-.form-search .input-append,.form-inline .input-append,.form-search .input-prepend,.form-inline .input-prepend{margin-bottom:0;}
-.form-search .radio,.form-search .checkbox,.form-inline .radio,.form-inline .checkbox{padding-left:0;margin-bottom:0;vertical-align:middle;}
-.form-search .radio input[type="radio"],.form-search .checkbox input[type="checkbox"],.form-inline .radio input[type="radio"],.form-inline .checkbox input[type="checkbox"]{float:left;margin-left:0;margin-right:3px;}
-.control-group{margin-bottom:9px;}
-legend+.control-group{margin-top:18px;-webkit-margin-top-collapse:separate;}
-.form-horizontal .control-group{margin-bottom:18px;*zoom:1;}.form-horizontal .control-group:before,.form-horizontal .control-group:after{display:table;content:"";}
-.form-horizontal .control-group:after{clear:both;}
-.form-horizontal .control-label{float:left;width:140px;padding-top:5px;text-align:right;}
-.form-horizontal .controls{margin-left:160px;*display:inline-block;*margin-left:0;*padding-left:20px;}
-.form-horizontal .help-block{margin-top:9px;margin-bottom:0;}
-.form-horizontal .form-actions{padding-left:160px;}
-table{max-width:100%;border-collapse:collapse;border-spacing:0;background-color:transparent;}
-.table{width:100%;margin-bottom:18px;}.table th,.table td{padding:8px;line-height:18px;text-align:left;vertical-align:top;border-top:1px solid #dddddd;}
-.table th{font-weight:bold;}
-.table thead th{vertical-align:bottom;}
-.table colgroup+thead tr:first-child th,.table colgroup+thead tr:first-child td,.table thead:first-child tr:first-child th,.table thead:first-child tr:first-child td{border-top:0;}
-.table tbody+tbody{border-top:2px solid #dddddd;}
-.table-condensed th,.table-condensed td{padding:4px 5px;}
-.table-bordered{border:1px solid #dddddd;border-left:0;border-collapse:separate;*border-collapse:collapsed;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;}.table-bordered th,.table-bordered td{border-left:1px solid #dddddd;}
-.table-bordered thead:first-child tr:first-child th,.table-bordered tbody:first-child tr:first-child th,.table-bordered tbody:first-child tr:first-child td{border-top:0;}
-.table-bordered thead:first-child tr:first-child th:first-child,.table-bordered tbody:first-child tr:first-child td:first-child{-webkit-border-radius:4px 0 0 0;-moz-border-radius:4px 0 0 0;border-radius:4px 0 0 0;}
-.table-bordered thead:first-child tr:first-child th:last-child,.table-bordered tbody:first-child tr:first-child td:last-child{-webkit-border-radius:0 4px 0 0;-moz-border-radius:0 4px 0 0;border-radius:0 4px 0 0;}
-.table-bordered thead:last-child tr:last-child th:first-child,.table-bordered tbody:last-child tr:last-child td:first-child{-webkit-border-radius:0 0 0 4px;-moz-border-radius:0 0 0 4px;border-radius:0 0 0 4px;}
-.table-bordered thead:last-child tr:last-child th:last-child,.table-bordered tbody:last-child tr:last-child td:last-child{-webkit-border-radius:0 0 4px 0;-moz-border-radius:0 0 4px 0;border-radius:0 0 4px 0;}
-.table-striped tbody tr:nth-child(odd) td,.table-striped tbody tr:nth-child(odd) th{background-color:#f9f9f9;}
-.table tbody tr:hover td,.table tbody tr:hover th{background-color:#f5f5f5;}
-table .span1{float:none;width:44px;margin-left:0;}
-table .span2{float:none;width:124px;margin-left:0;}
-table .span3{float:none;width:204px;margin-left:0;}
-table .span4{float:none;width:284px;margin-left:0;}
-table .span5{float:none;width:364px;margin-left:0;}
-table .span6{float:none;width:444px;margin-left:0;}
-table .span7{float:none;width:524px;margin-left:0;}
-table .span8{float:none;width:604px;margin-left:0;}
-table .span9{float:none;width:684px;margin-left:0;}
-table .span10{float:none;width:764px;margin-left:0;}
-table .span11{float:none;width:844px;margin-left:0;}
-table .span12{float:none;width:924px;margin-left:0;}
-table .span13{float:none;width:1004px;margin-left:0;}
-table .span14{float:none;width:1084px;margin-left:0;}
-table .span15{float:none;width:1164px;margin-left:0;}
-table .span16{float:none;width:1244px;margin-left:0;}
-table .span17{float:none;width:1324px;margin-left:0;}
-table .span18{float:none;width:1404px;margin-left:0;}
-table .span19{float:none;width:1484px;margin-left:0;}
-table .span20{float:none;width:1564px;margin-left:0;}
-table .span21{float:none;width:1644px;margin-left:0;}
-table .span22{float:none;width:1724px;margin-left:0;}
-table .span23{float:none;width:1804px;margin-left:0;}
-table .span24{float:none;width:1884px;margin-left:0;}
-[class^="icon-"],[class*=" icon-"]{display:inline-block;width:14px;height:14px;line-height:14px;vertical-align:text-top;background-image:url("../media/glyphicons-halflings.png");background-position:14px 14px;background-repeat:no-repeat;*margin-right:.3em;}[class^="icon-"]:last-child,[class*=" icon-"]:last-child{*margin-left:0;}
-.icon-white{background-image:url("../media/glyphicons-halflings-white.png");}
-.icon-glass{background-position:0 0;}
-.icon-music{background-position:-24px 0;}
-.icon-search{background-position:-48px 0;}
-.icon-envelope{background-position:-72px 0;}
-.icon-heart{background-position:-96px 0;}
-.icon-star{background-position:-120px 0;}
-.icon-star-empty{background-position:-144px 0;}
-.icon-user{background-position:-168px 0;}
-.icon-film{background-position:-192px 0;}
-.icon-th-large{background-position:-216px 0;}
-.icon-th{background-position:-240px 0;}
-.icon-th-list{background-position:-264px 0;}
-.icon-ok{background-position:-288px 0;}
-.icon-remove{background-position:-312px 0;}
-.icon-zoom-in{background-position:-336px 0;}
-.icon-zoom-out{background-position:-360px 0;}
-.icon-off{background-position:-384px 0;}
-.icon-signal{background-position:-408px 0;}
-.icon-cog{background-position:-432px 0;}
-.icon-trash{background-position:-456px 0;}
-.icon-home{background-position:0 -24px;}
-.icon-file{background-position:-24px -24px;}
-.icon-time{background-position:-48px -24px;}
-.icon-road{background-position:-72px -24px;}
-.icon-download-alt{background-position:-96px -24px;}
-.icon-download{background-position:-120px -24px;}
-.icon-upload{background-position:-144px -24px;}
-.icon-inbox{background-position:-168px -24px;}
-.icon-play-circle{background-position:-192px -24px;}
-.icon-repeat{background-position:-216px -24px;}
-.icon-refresh{background-position:-240px -24px;}
-.icon-list-alt{background-position:-264px -24px;}
-.icon-lock{background-position:-287px -24px;}
-.icon-flag{background-position:-312px -24px;}
-.icon-headphones{background-position:-336px -24px;}
-.icon-volume-off{background-position:-360px -24px;}
-.icon-volume-down{background-position:-384px -24px;}
-.icon-volume-up{background-position:-408px -24px;}
-.icon-qrcode{background-position:-432px -24px;}
-.icon-barcode{background-position:-456px -24px;}
-.icon-tag{background-position:0 -48px;}
-.icon-tags{background-position:-25px -48px;}
-.icon-book{background-position:-48px -48px;}
-.icon-bookmark{background-position:-72px -48px;}
-.icon-print{background-position:-96px -48px;}
-.icon-camera{background-position:-120px -48px;}
-.icon-font{background-position:-144px -48px;}
-.icon-bold{background-position:-167px -48px;}
-.icon-italic{background-position:-192px -48px;}
-.icon-text-height{background-position:-216px -48px;}
-.icon-text-width{background-position:-240px -48px;}
-.icon-align-left{background-position:-264px -48px;}
-.icon-align-center{background-position:-288px -48px;}
-.icon-align-right{background-position:-312px -48px;}
-.icon-align-justify{background-position:-336px -48px;}
-.icon-list{background-position:-360px -48px;}
-.icon-indent-left{background-position:-384px -48px;}
-.icon-indent-right{background-position:-408px -48px;}
-.icon-facetime-video{background-position:-432px -48px;}
-.icon-picture{background-position:-456px -48px;}
-.icon-pencil{background-position:0 -72px;}
-.icon-map-marker{background-position:-24px -72px;}
-.icon-adjust{background-position:-48px -72px;}
-.icon-tint{background-position:-72px -72px;}
-.icon-edit{background-position:-96px -72px;}
-.icon-share{background-position:-120px -72px;}
-.icon-check{background-position:-144px -72px;}
-.icon-move{background-position:-168px -72px;}
-.icon-step-backward{background-position:-192px -72px;}
-.icon-fast-backward{background-position:-216px -72px;}
-.icon-backward{background-position:-240px -72px;}
-.icon-play{background-position:-264px -72px;}
-.icon-pause{background-position:-288px -72px;}
-.icon-stop{background-position:-312px -72px;}
-.icon-forward{background-position:-336px -72px;}
-.icon-fast-forward{background-position:-360px -72px;}
-.icon-step-forward{background-position:-384px -72px;}
-.icon-eject{background-position:-408px -72px;}
-.icon-chevron-left{background-position:-432px -72px;}
-.icon-chevron-right{background-position:-456px -72px;}
-.icon-plus-sign{background-position:0 -96px;}
-.icon-minus-sign{background-position:-24px -96px;}
-.icon-remove-sign{background-position:-48px -96px;}
-.icon-ok-sign{background-position:-72px -96px;}
-.icon-question-sign{background-position:-96px -96px;}
-.icon-info-sign{background-position:-120px -96px;}
-.icon-screenshot{background-position:-144px -96px;}
-.icon-remove-circle{background-position:-168px -96px;}
-.icon-ok-circle{background-position:-192px -96px;}
-.icon-ban-circle{background-position:-216px -96px;}
-.icon-arrow-left{background-position:-240px -96px;}
-.icon-arrow-right{background-position:-264px -96px;}
-.icon-arrow-up{background-position:-289px -96px;}
-.icon-arrow-down{background-position:-312px -96px;}
-.icon-share-alt{background-position:-336px -96px;}
-.icon-resize-full{background-position:-360px -96px;}
-.icon-resize-small{background-position:-384px -96px;}
-.icon-plus{background-position:-408px -96px;}
-.icon-minus{background-position:-433px -96px;}
-.icon-asterisk{background-position:-456px -96px;}
-.icon-exclamation-sign{background-position:0 -120px;}
-.icon-gift{background-position:-24px -120px;}
-.icon-leaf{background-position:-48px -120px;}
-.icon-fire{background-position:-72px -120px;}
-.icon-eye-open{background-position:-96px -120px;}
-.icon-eye-close{background-position:-120px -120px;}
-.icon-warning-sign{background-position:-144px -120px;}
-.icon-plane{background-position:-168px -120px;}
-.icon-calendar{background-position:-192px -120px;}
-.icon-random{background-position:-216px -120px;}
-.icon-comment{background-position:-240px -120px;}
-.icon-magnet{background-position:-264px -120px;}
-.icon-chevron-up{background-position:-288px -120px;}
-.icon-chevron-down{background-position:-313px -119px;}
-.icon-retweet{background-position:-336px -120px;}
-.icon-shopping-cart{background-position:-360px -120px;}
-.icon-folder-close{background-position:-384px -120px;}
-.icon-folder-open{background-position:-408px -120px;}
-.icon-resize-vertical{background-position:-432px -119px;}
-.icon-resize-horizontal{background-position:-456px -118px;}
-.dropdown{position:relative;}
-.dropdown-toggle{*margin-bottom:-3px;}
-.dropdown-toggle:active,.open .dropdown-toggle{outline:0;}
-.caret{display:inline-block;width:0;height:0;vertical-align:top;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid #000000;opacity:0.3;filter:alpha(opacity=30);content:"";}
-.dropdown .caret{margin-top:8px;margin-left:2px;}
-.dropdown:hover .caret,.open.dropdown .caret{opacity:1;filter:alpha(opacity=100);}
-.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;float:left;display:none;min-width:160px;padding:4px 0;margin:0;list-style:none;background-color:#ffffff;border-color:#ccc;border-color:rgba(0, 0, 0, 0.2);border-style:solid;border-width:1px;-webkit-border-radius:0 0 5px 5px;-moz-border-radius:0 0 5px 5px;border-radius:0 0 5px 5px;-webkit-box-shadow:0 5px 10px rgba(0, 0, 0, 0.2);-moz-box-shadow:0 5px 10px rgba(0, 0, 0, 0.2);box-shadow:0 5px 10px rgba(0, 0, 0, 0.2);-webkit-background-clip:padding-box;-moz-background-clip:padding;background-clip:padding-box;*border-right-width:2px;*border-bottom-width:2px;}.dropdown-menu.pull-right{right:0;left:auto;}
-.dropdown-menu .divider{height:1px;margin:8px 1px;overflow:hidden;background-color:#e5e5e5;border-bottom:1px solid #ffffff;*width:100%;*margin:-5px 0 5px;}
-.dropdown-menu a{display:block;padding:3px 15px;clear:both;font-weight:normal;line-height:18px;color:#333333;white-space:nowrap;}
-.dropdown-menu li>a:hover,.dropdown-menu .active>a,.dropdown-menu .active>a:hover{color:#ffffff;text-decoration:none;background-color:#0088cc;}
-.dropdown.open{*z-index:1000;}.dropdown.open .dropdown-toggle{color:#ffffff;background:#ccc;background:rgba(0, 0, 0, 0.3);}
-.dropdown.open .dropdown-menu{display:block;}
-.pull-right .dropdown-menu{left:auto;right:0;}
-.dropup .caret,.navbar-fixed-bottom .dropdown .caret{border-top:0;border-bottom:4px solid #000000;content:"\2191";}
-.dropup .dropdown-menu,.navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:1px;}
-.typeahead{margin-top:2px;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;}
-.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #eee;border:1px solid rgba(0, 0, 0, 0.05);-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0, 0, 0, 0.05);-moz-box-shadow:inset 0 1px 1px rgba(0, 0, 0, 0.05);box-shadow:inset 0 1px 1px rgba(0, 0, 0, 0.05);}.well blockquote{border-color:#ddd;border-color:rgba(0, 0, 0, 0.15);}
-.well-large{padding:24px;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;}
-.well-small{padding:9px;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;}
-.fade{-webkit-transition:opacity 0.15s linear;-moz-transition:opacity 0.15s linear;-ms-transition:opacity 0.15s linear;-o-transition:opacity 0.15s linear;transition:opacity 0.15s linear;opacity:0;}.fade.in{opacity:1;}
-.collapse{-webkit-transition:height 0.35s ease;-moz-transition:height 0.35s ease;-ms-transition:height 0.35s ease;-o-transition:height 0.35s ease;transition:height 0.35s ease;position:relative;overflow:hidden;height:0;}.collapse.in{height:auto;}
-.close{float:right;font-size:20px;font-weight:bold;line-height:18px;color:#000000;text-shadow:0 1px 0 #ffffff;opacity:0.2;filter:alpha(opacity=20);}.close:hover{color:#000000;text-decoration:none;opacity:0.4;filter:alpha(opacity=40);cursor:pointer;}
-.btn{display:inline-block;*display:inline;*zoom:1;padding:4px 10px 4px;margin-bottom:0;font-size:13px;line-height:18px;color:#333333;text-align:center;text-shadow:0 1px 1px rgba(255, 255, 255, 0.75);vertical-align:middle;background-color:#f5f5f5;background-image:-moz-linear-gradient(top, #ffffff, #e6e6e6);background-image:-ms-linear-gradient(top, #ffffff, #e6e6e6);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#ffffff), to(#e6e6e6));background-image:-webkit-linear-gradient(top, #ffffff, #e6e6e6);background-image:-o-linear-gradient(top, #ffffff, #e6e6e6);background-image:linear-gradient(top, #ffffff, #e6e6e6);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#e6e6e6', GradientType=0);border-color:#e6e6e6 #e6e6e6 #bfbfbf;border-color:rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);filter:progid:dximagetransform.microsoft.gradient(enabled=false);border:1px solid #cccccc;border-bottom-color:#b3b3b3;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;-webkit-box-shadow:inset 0 1px 0 rgba(255, 255, 255, 0.2),0 1px 2px rgba(0, 0, 0, 0.05);-moz-box-shadow:inset 0 1px 0 rgba(255, 255, 255, 0.2),0 1px 2px rgba(0, 0, 0, 0.05);box-shadow:inset 0 1px 0 rgba(255, 255, 255, 0.2),0 1px 2px rgba(0, 0, 0, 0.05);cursor:pointer;*margin-left:.3em;}.btn:hover,.btn:active,.btn.active,.btn.disabled,.btn[disabled]{background-color:#e6e6e6;}
-.btn:active,.btn.active{background-color:#cccccc \9;}
-.btn:first-child{*margin-left:0;}
-.btn:hover{color:#333333;text-decoration:none;background-color:#e6e6e6;background-position:0 -15px;-webkit-transition:background-position 0.1s linear;-moz-transition:background-position 0.1s linear;-ms-transition:background-position 0.1s linear;-o-transition:background-position 0.1s linear;transition:background-position 0.1s linear;}
-.btn:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px;}
-.btn.active,.btn:active{background-image:none;-webkit-box-shadow:inset 0 2px 4px rgba(0, 0, 0, 0.15),0 1px 2px rgba(0, 0, 0, 0.05);-moz-box-shadow:inset 0 2px 4px rgba(0, 0, 0, 0.15),0 1px 2px rgba(0, 0, 0, 0.05);box-shadow:inset 0 2px 4px rgba(0, 0, 0, 0.15),0 1px 2px rgba(0, 0, 0, 0.05);background-color:#e6e6e6;background-color:#d9d9d9 \9;outline:0;}
-.btn.disabled,.btn[disabled]{cursor:default;background-image:none;background-color:#e6e6e6;opacity:0.65;filter:alpha(opacity=65);-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;}
-.btn-large{padding:9px 14px;font-size:15px;line-height:normal;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px;}
-.btn-large [class^="icon-"]{margin-top:1px;}
-.btn-small{padding:5px 9px;font-size:11px;line-height:16px;}
-.btn-small [class^="icon-"]{margin-top:-1px;}
-.btn-mini{padding:2px 6px;font-size:11px;line-height:14px;}
-.btn-primary,.btn-primary:hover,.btn-warning,.btn-warning:hover,.btn-danger,.btn-danger:hover,.btn-success,.btn-success:hover,.btn-info,.btn-info:hover,.btn-inverse,.btn-inverse:hover{text-shadow:0 -1px 0 rgba(0, 0, 0, 0.25);color:#ffffff;}
-.btn-primary.active,.btn-warning.active,.btn-danger.active,.btn-success.active,.btn-info.active,.btn-inverse.active{color:rgba(255, 255, 255, 0.75);}
-.btn-primary{background-color:#0074cc;background-image:-moz-linear-gradient(top, #0088cc, #0055cc);background-image:-ms-linear-gradient(top, #0088cc, #0055cc);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#0088cc), to(#0055cc));background-image:-webkit-linear-gradient(top, #0088cc, #0055cc);background-image:-o-linear-gradient(top, #0088cc, #0055cc);background-image:linear-gradient(top, #0088cc, #0055cc);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#0088cc', endColorstr='#0055cc', GradientType=0);border-color:#0055cc #0055cc #003580;border-color:rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);filter:progid:dximagetransform.microsoft.gradient(enabled=false);}.btn-primary:hover,.btn-primary:active,.btn-primary.active,.btn-primary.disabled,.btn-primary[disabled]{background-color:#0055cc;}
-.btn-primary:active,.btn-primary.active{background-color:#004099 \9;}
-.btn-warning{background-color:#faa732;background-image:-moz-linear-gradient(top, #fbb450, #f89406);background-image:-ms-linear-gradient(top, #fbb450, #f89406);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#fbb450), to(#f89406));background-image:-webkit-linear-gradient(top, #fbb450, #f89406);background-image:-o-linear-gradient(top, #fbb450, #f89406);background-image:linear-gradient(top, #fbb450, #f89406);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#fbb450', endColorstr='#f89406', GradientType=0);border-color:#f89406 #f89406 #ad6704;border-color:rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);filter:progid:dximagetransform.microsoft.gradient(enabled=false);}.btn-warning:hover,.btn-warning:active,.btn-warning.active,.btn-warning.disabled,.btn-warning[disabled]{background-color:#f89406;}
-.btn-warning:active,.btn-warning.active{background-color:#c67605 \9;}
-.btn-danger{background-color:#da4f49;background-image:-moz-linear-gradient(top, #ee5f5b, #bd362f);background-image:-ms-linear-gradient(top, #ee5f5b, #bd362f);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#ee5f5b), to(#bd362f));background-image:-webkit-linear-gradient(top, #ee5f5b, #bd362f);background-image:-o-linear-gradient(top, #ee5f5b, #bd362f);background-image:linear-gradient(top, #ee5f5b, #bd362f);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ee5f5b', endColorstr='#bd362f', GradientType=0);border-color:#bd362f #bd362f #802420;border-color:rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);filter:progid:dximagetransform.microsoft.gradient(enabled=false);}.btn-danger:hover,.btn-danger:active,.btn-danger.active,.btn-danger.disabled,.btn-danger[disabled]{background-color:#bd362f;}
-.btn-danger:active,.btn-danger.active{background-color:#942a25 \9;}
-.btn-success{background-color:#5bb75b;background-image:-moz-linear-gradient(top, #62c462, #51a351);background-image:-ms-linear-gradient(top, #62c462, #51a351);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#62c462), to(#51a351));background-image:-webkit-linear-gradient(top, #62c462, #51a351);background-image:-o-linear-gradient(top, #62c462, #51a351);background-image:linear-gradient(top, #62c462, #51a351);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#62c462', endColorstr='#51a351', GradientType=0);border-color:#51a351 #51a351 #387038;border-color:rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);filter:progid:dximagetransform.microsoft.gradient(enabled=false);}.btn-success:hover,.btn-success:active,.btn-success.active,.btn-success.disabled,.btn-success[disabled]{background-color:#51a351;}
-.btn-success:active,.btn-success.active{background-color:#408140 \9;}
-.btn-info{background-color:#49afcd;background-image:-moz-linear-gradient(top, #5bc0de, #2f96b4);background-image:-ms-linear-gradient(top, #5bc0de, #2f96b4);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#5bc0de), to(#2f96b4));background-image:-webkit-linear-gradient(top, #5bc0de, #2f96b4);background-image:-o-linear-gradient(top, #5bc0de, #2f96b4);background-image:linear-gradient(top, #5bc0de, #2f96b4);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#5bc0de', endColorstr='#2f96b4', GradientType=0);border-color:#2f96b4 #2f96b4 #1f6377;border-color:rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);filter:progid:dximagetransform.microsoft.gradient(enabled=false);}.btn-info:hover,.btn-info:active,.btn-info.active,.btn-info.disabled,.btn-info[disabled]{background-color:#2f96b4;}
-.btn-info:active,.btn-info.active{background-color:#24748c \9;}
-.btn-inverse{background-color:#414141;background-image:-moz-linear-gradient(top, #555555, #222222);background-image:-ms-linear-gradient(top, #555555, #222222);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#555555), to(#222222));background-image:-webkit-linear-gradient(top, #555555, #222222);background-image:-o-linear-gradient(top, #555555, #222222);background-image:linear-gradient(top, #555555, #222222);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#555555', endColorstr='#222222', GradientType=0);border-color:#222222 #222222 #000000;border-color:rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);filter:progid:dximagetransform.microsoft.gradient(enabled=false);}.btn-inverse:hover,.btn-inverse:active,.btn-inverse.active,.btn-inverse.disabled,.btn-inverse[disabled]{background-color:#222222;}
-.btn-inverse:active,.btn-inverse.active{background-color:#080808 \9;}
-button.btn,input[type="submit"].btn{*padding-top:2px;*padding-bottom:2px;}button.btn::-moz-focus-inner,input[type="submit"].btn::-moz-focus-inner{padding:0;border:0;}
-button.btn.btn-large,input[type="submit"].btn.btn-large{*padding-top:7px;*padding-bottom:7px;}
-button.btn.btn-small,input[type="submit"].btn.btn-small{*padding-top:3px;*padding-bottom:3px;}
-button.btn.btn-mini,input[type="submit"].btn.btn-mini{*padding-top:1px;*padding-bottom:1px;}
-.btn-group{position:relative;*zoom:1;*margin-left:.3em;}.btn-group:before,.btn-group:after{display:table;content:"";}
-.btn-group:after{clear:both;}
-.btn-group:first-child{*margin-left:0;}
-.btn-group+.btn-group{margin-left:5px;}
-.btn-toolbar{margin-top:9px;margin-bottom:9px;}.btn-toolbar .btn-group{display:inline-block;*display:inline;*zoom:1;}
-.btn-group .btn{position:relative;float:left;margin-left:-1px;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0;}
-.btn-group .btn:first-child{margin-left:0;-webkit-border-top-left-radius:4px;-moz-border-radius-topleft:4px;border-top-left-radius:4px;-webkit-border-bottom-left-radius:4px;-moz-border-radius-bottomleft:4px;border-bottom-left-radius:4px;}
-.btn-group .btn:last-child,.btn-group .dropdown-toggle{-webkit-border-top-right-radius:4px;-moz-border-radius-topright:4px;border-top-right-radius:4px;-webkit-border-bottom-right-radius:4px;-moz-border-radius-bottomright:4px;border-bottom-right-radius:4px;}
-.btn-group .btn.large:first-child{margin-left:0;-webkit-border-top-left-radius:6px;-moz-border-radius-topleft:6px;border-top-left-radius:6px;-webkit-border-bottom-left-radius:6px;-moz-border-radius-bottomleft:6px;border-bottom-left-radius:6px;}
-.btn-group .btn.large:last-child,.btn-group .large.dropdown-toggle{-webkit-border-top-right-radius:6px;-moz-border-radius-topright:6px;border-top-right-radius:6px;-webkit-border-bottom-right-radius:6px;-moz-border-radius-bottomright:6px;border-bottom-right-radius:6px;}
-.btn-group .btn:hover,.btn-group .btn:focus,.btn-group .btn:active,.btn-group .btn.active{z-index:2;}
-.btn-group .dropdown-toggle:active,.btn-group.open .dropdown-toggle{outline:0;}
-.btn-group .dropdown-toggle{padding-left:8px;padding-right:8px;-webkit-box-shadow:inset 1px 0 0 rgba(255, 255, 255, 0.125),inset 0 1px 0 rgba(255, 255, 255, 0.2),0 1px 2px rgba(0, 0, 0, 0.05);-moz-box-shadow:inset 1px 0 0 rgba(255, 255, 255, 0.125),inset 0 1px 0 rgba(255, 255, 255, 0.2),0 1px 2px rgba(0, 0, 0, 0.05);box-shadow:inset 1px 0 0 rgba(255, 255, 255, 0.125),inset 0 1px 0 rgba(255, 255, 255, 0.2),0 1px 2px rgba(0, 0, 0, 0.05);*padding-top:3px;*padding-bottom:3px;}
-.btn-group .btn-mini.dropdown-toggle{padding-left:5px;padding-right:5px;*padding-top:1px;*padding-bottom:1px;}
-.btn-group .btn-small.dropdown-toggle{*padding-top:4px;*padding-bottom:4px;}
-.btn-group .btn-large.dropdown-toggle{padding-left:12px;padding-right:12px;}
-.btn-group.open{*z-index:1000;}.btn-group.open .dropdown-menu{display:block;margin-top:1px;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px;}
-.btn-group.open .dropdown-toggle{background-image:none;-webkit-box-shadow:inset 0 1px 6px rgba(0, 0, 0, 0.15),0 1px 2px rgba(0, 0, 0, 0.05);-moz-box-shadow:inset 0 1px 6px rgba(0, 0, 0, 0.15),0 1px 2px rgba(0, 0, 0, 0.05);box-shadow:inset 0 1px 6px rgba(0, 0, 0, 0.15),0 1px 2px rgba(0, 0, 0, 0.05);}
-.btn .caret{margin-top:7px;margin-left:0;}
-.btn:hover .caret,.open.btn-group .caret{opacity:1;filter:alpha(opacity=100);}
-.btn-mini .caret{margin-top:5px;}
-.btn-small .caret{margin-top:6px;}
-.btn-large .caret{margin-top:6px;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid #000000;}
-.btn-primary .caret,.btn-warning .caret,.btn-danger .caret,.btn-info .caret,.btn-success .caret,.btn-inverse .caret{border-top-color:#ffffff;border-bottom-color:#ffffff;opacity:0.75;filter:alpha(opacity=75);}
-.alert{padding:8px 35px 8px 14px;margin-bottom:18px;text-shadow:0 1px 0 rgba(255, 255, 255, 0.5);background-color:#fcf8e3;border:1px solid #fbeed5;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;color:#c09853;}
-.alert-heading{color:inherit;}
-.alert .close{position:relative;top:-2px;right:-21px;line-height:18px;}
-.alert-success{background-color:#dff0d8;border-color:#d6e9c6;color:#468847;}
-.alert-danger,.alert-error{background-color:#f2dede;border-color:#eed3d7;color:#b94a48;}
-.alert-info{background-color:#d9edf7;border-color:#bce8f1;color:#3a87ad;}
-.alert-block{padding-top:14px;padding-bottom:14px;}
-.alert-block>p,.alert-block>ul{margin-bottom:0;}
-.alert-block p+p{margin-top:5px;}
-.nav{margin-left:0;margin-bottom:18px;list-style:none;}
-.nav>li>a{display:block;}
-.nav>li>a:hover{text-decoration:none;background-color:#eeeeee;}
-.nav .nav-header{display:block;padding:3px 15px;font-size:11px;font-weight:bold;line-height:18px;color:#999999;text-shadow:0 1px 0 rgba(255, 255, 255, 0.5);text-transform:uppercase;}
-.nav li+.nav-header{margin-top:9px;}
-.nav-list{padding-left:15px;padding-right:15px;margin-bottom:0;}
-.nav-list>li>a,.nav-list .nav-header{margin-left:-15px;margin-right:-15px;text-shadow:0 1px 0 rgba(255, 255, 255, 0.5);}
-.nav-list>li>a{padding:3px 15px;}
-.nav-list>.active>a,.nav-list>.active>a:hover{color:#ffffff;text-shadow:0 -1px 0 rgba(0, 0, 0, 0.2);background-color:#0088cc;}
-.nav-list [class^="icon-"]{margin-right:2px;}
-.nav-list .divider{height:1px;margin:8px 1px;overflow:hidden;background-color:#e5e5e5;border-bottom:1px solid #ffffff;*width:100%;*margin:-5px 0 5px;}
-.nav-tabs,.nav-pills{*zoom:1;}.nav-tabs:before,.nav-pills:before,.nav-tabs:after,.nav-pills:after{display:table;content:"";}
-.nav-tabs:after,.nav-pills:after{clear:both;}
-.nav-tabs>li,.nav-pills>li{float:left;}
-.nav-tabs>li>a,.nav-pills>li>a{padding-right:12px;padding-left:12px;margin-right:2px;line-height:14px;}
-.nav-tabs{border-bottom:1px solid #ddd;}
-.nav-tabs>li{margin-bottom:-1px;}
-.nav-tabs>li>a{padding-top:8px;padding-bottom:8px;line-height:18px;border:1px solid transparent;-webkit-border-radius:4px 4px 0 0;-moz-border-radius:4px 4px 0 0;border-radius:4px 4px 0 0;}.nav-tabs>li>a:hover{border-color:#eeeeee #eeeeee #dddddd;}
-.nav-tabs>.active>a,.nav-tabs>.active>a:hover{color:#555555;background-color:#ffffff;border:1px solid #ddd;border-bottom-color:transparent;cursor:default;}
-.nav-pills>li>a{padding-top:8px;padding-bottom:8px;margin-top:2px;margin-bottom:2px;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px;}
-.nav-pills>.active>a,.nav-pills>.active>a:hover{color:#ffffff;background-color:#0088cc;}
-.nav-stacked>li{float:none;}
-.nav-stacked>li>a{margin-right:0;}
-.nav-tabs.nav-stacked{border-bottom:0;}
-.nav-tabs.nav-stacked>li>a{border:1px solid #ddd;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0;}
-.nav-tabs.nav-stacked>li:first-child>a{-webkit-border-radius:4px 4px 0 0;-moz-border-radius:4px 4px 0 0;border-radius:4px 4px 0 0;}
-.nav-tabs.nav-stacked>li:last-child>a{-webkit-border-radius:0 0 4px 4px;-moz-border-radius:0 0 4px 4px;border-radius:0 0 4px 4px;}
-.nav-tabs.nav-stacked>li>a:hover{border-color:#ddd;z-index:2;}
-.nav-pills.nav-stacked>li>a{margin-bottom:3px;}
-.nav-pills.nav-stacked>li:last-child>a{margin-bottom:1px;}
-.nav-tabs .dropdown-menu,.nav-pills .dropdown-menu{margin-top:1px;border-width:1px;}
-.nav-pills .dropdown-menu{-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;}
-.nav-tabs .dropdown-toggle .caret,.nav-pills .dropdown-toggle .caret{border-top-color:#0088cc;border-bottom-color:#0088cc;margin-top:6px;}
-.nav-tabs .dropdown-toggle:hover .caret,.nav-pills .dropdown-toggle:hover .caret{border-top-color:#005580;border-bottom-color:#005580;}
-.nav-tabs .active .dropdown-toggle .caret,.nav-pills .active .dropdown-toggle .caret{border-top-color:#333333;border-bottom-color:#333333;}
-.nav>.dropdown.active>a:hover{color:#000000;cursor:pointer;}
-.nav-tabs .open .dropdown-toggle,.nav-pills .open .dropdown-toggle,.nav>.open.active>a:hover{color:#ffffff;background-color:#999999;border-color:#999999;}
-.nav .open .caret,.nav .open.active .caret,.nav .open a:hover .caret{border-top-color:#ffffff;border-bottom-color:#ffffff;opacity:1;filter:alpha(opacity=100);}
-.tabs-stacked .open>a:hover{border-color:#999999;}
-.tabbable{*zoom:1;}.tabbable:before,.tabbable:after{display:table;content:"";}
-.tabbable:after{clear:both;}
-.tab-content{display:table;width:100%;}
-.tabs-below .nav-tabs,.tabs-right .nav-tabs,.tabs-left .nav-tabs{border-bottom:0;}
-.tab-content>.tab-pane,.pill-content>.pill-pane{display:none;}
-.tab-content>.active,.pill-content>.active{display:block;}
-.tabs-below .nav-tabs{border-top:1px solid #ddd;}
-.tabs-below .nav-tabs>li{margin-top:-1px;margin-bottom:0;}
-.tabs-below .nav-tabs>li>a{-webkit-border-radius:0 0 4px 4px;-moz-border-radius:0 0 4px 4px;border-radius:0 0 4px 4px;}.tabs-below .nav-tabs>li>a:hover{border-bottom-color:transparent;border-top-color:#ddd;}
-.tabs-below .nav-tabs .active>a,.tabs-below .nav-tabs .active>a:hover{border-color:transparent #ddd #ddd #ddd;}
-.tabs-left .nav-tabs>li,.tabs-right .nav-tabs>li{float:none;}
-.tabs-left .nav-tabs>li>a,.tabs-right .nav-tabs>li>a{min-width:74px;margin-right:0;margin-bottom:3px;}
-.tabs-left .nav-tabs{float:left;margin-right:19px;border-right:1px solid #ddd;}
-.tabs-left .nav-tabs>li>a{margin-right:-1px;-webkit-border-radius:4px 0 0 4px;-moz-border-radius:4px 0 0 4px;border-radius:4px 0 0 4px;}
-.tabs-left .nav-tabs>li>a:hover{border-color:#eeeeee #dddddd #eeeeee #eeeeee;}
-.tabs-left .nav-tabs .active>a,.tabs-left .nav-tabs .active>a:hover{border-color:#ddd transparent #ddd #ddd;*border-right-color:#ffffff;}
-.tabs-right .nav-tabs{float:right;margin-left:19px;border-left:1px solid #ddd;}
-.tabs-right .nav-tabs>li>a{margin-left:-1px;-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0;}
-.tabs-right .nav-tabs>li>a:hover{border-color:#eeeeee #eeeeee #eeeeee #dddddd;}
-.tabs-right .nav-tabs .active>a,.tabs-right .nav-tabs .active>a:hover{border-color:#ddd #ddd #ddd transparent;*border-left-color:#ffffff;}
-.navbar{*position:relative;*z-index:2;overflow:visible;margin-bottom:18px;}
-.navbar-inner{padding-left:20px;padding-right:20px;background-color:#2c2c2c;background-image:-moz-linear-gradient(top, #333333, #222222);background-image:-ms-linear-gradient(top, #333333, #222222);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#333333), to(#222222));background-image:-webkit-linear-gradient(top, #333333, #222222);background-image:-o-linear-gradient(top, #333333, #222222);background-image:linear-gradient(top, #333333, #222222);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#333333', endColorstr='#222222', GradientType=0);-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;-webkit-box-shadow:0 1px 3px rgba(0, 0, 0, 0.25),inset 0 -1px 0 rgba(0, 0, 0, 0.1);-moz-box-shadow:0 1px 3px rgba(0, 0, 0, 0.25),inset 0 -1px 0 rgba(0, 0, 0, 0.1);box-shadow:0 1px 3px rgba(0, 0, 0, 0.25),inset 0 -1px 0 rgba(0, 0, 0, 0.1);}
-.navbar .container{width:auto;}
-.btn-navbar{display:none;float:right;padding:7px 10px;margin-left:5px;margin-right:5px;background-color:#2c2c2c;background-image:-moz-linear-gradient(top, #333333, #222222);background-image:-ms-linear-gradient(top, #333333, #222222);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#333333), to(#222222));background-image:-webkit-linear-gradient(top, #333333, #222222);background-image:-o-linear-gradient(top, #333333, #222222);background-image:linear-gradient(top, #333333, #222222);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#333333', endColorstr='#222222', GradientType=0);border-color:#222222 #222222 #000000;border-color:rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);filter:progid:dximagetransform.microsoft.gradient(enabled=false);-webkit-box-shadow:inset 0 1px 0 rgba(255, 255, 255, 0.1),0 1px 0 rgba(255, 255, 255, 0.075);-moz-box-shadow:inset 0 1px 0 rgba(255, 255, 255, 0.1),0 1px 0 rgba(255, 255, 255, 0.075);box-shadow:inset 0 1px 0 rgba(255, 255, 255, 0.1),0 1px 0 rgba(255, 255, 255, 0.075);}.btn-navbar:hover,.btn-navbar:active,.btn-navbar.active,.btn-navbar.disabled,.btn-navbar[disabled]{background-color:#222222;}
-.btn-navbar:active,.btn-navbar.active{background-color:#080808 \9;}
-.btn-navbar .icon-bar{display:block;width:18px;height:2px;background-color:#f5f5f5;-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px;-webkit-box-shadow:0 1px 0 rgba(0, 0, 0, 0.25);-moz-box-shadow:0 1px 0 rgba(0, 0, 0, 0.25);box-shadow:0 1px 0 rgba(0, 0, 0, 0.25);}
-.btn-navbar .icon-bar+.icon-bar{margin-top:3px;}
-.nav-collapse.collapse{height:auto;}
-.navbar{color:#999999;}.navbar .brand:hover{text-decoration:none;}
-.navbar .brand{float:left;display:block;padding:8px 20px 12px;margin-left:-20px;font-size:20px;font-weight:200;line-height:1;color:#ffffff;}
-.navbar .navbar-text{margin-bottom:0;line-height:40px;}
-.navbar .btn,.navbar .btn-group{margin-top:5px;}
-.navbar .btn-group .btn{margin-top:0;}
-.navbar-form{margin-bottom:0;*zoom:1;}.navbar-form:before,.navbar-form:after{display:table;content:"";}
-.navbar-form:after{clear:both;}
-.navbar-form input,.navbar-form select,.navbar-form .radio,.navbar-form .checkbox{margin-top:5px;}
-.navbar-form input,.navbar-form select{display:inline-block;margin-bottom:0;}
-.navbar-form input[type="image"],.navbar-form input[type="checkbox"],.navbar-form input[type="radio"]{margin-top:3px;}
-.navbar-form .input-append,.navbar-form .input-prepend{margin-top:6px;white-space:nowrap;}.navbar-form .input-append input,.navbar-form .input-prepend input{margin-top:0;}
-.navbar-search{position:relative;float:left;margin-top:6px;margin-bottom:0;}.navbar-search .search-query{padding:4px 9px;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:13px;font-weight:normal;line-height:1;color:#ffffff;background-color:#626262;border:1px solid #151515;-webkit-box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1),0 1px 0px rgba(255, 255, 255, 0.15);-moz-box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1),0 1px 0px rgba(255, 255, 255, 0.15);box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1),0 1px 0px rgba(255, 255, 255, 0.15);-webkit-transition:none;-moz-transition:none;-ms-transition:none;-o-transition:none;transition:none;}.navbar-search .search-query:-moz-placeholder{color:#cccccc;}
-.navbar-search .search-query::-webkit-input-placeholder{color:#cccccc;}
-.navbar-search .search-query:focus,.navbar-search .search-query.focused{padding:5px 10px;color:#333333;text-shadow:0 1px 0 #ffffff;background-color:#ffffff;border:0;-webkit-box-shadow:0 0 3px rgba(0, 0, 0, 0.15);-moz-box-shadow:0 0 3px rgba(0, 0, 0, 0.15);box-shadow:0 0 3px rgba(0, 0, 0, 0.15);outline:0;}
-.navbar-fixed-top,.navbar-fixed-bottom{position:fixed;right:0;left:0;z-index:1030;margin-bottom:0;}
-.navbar-fixed-top .navbar-inner,.navbar-fixed-bottom .navbar-inner{padding-left:0;padding-right:0;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0;}
-.navbar-fixed-top .container,.navbar-fixed-bottom .container{width:940px;}
-.navbar-fixed-top{top:0;}
-.navbar-fixed-bottom{bottom:0;}
-.navbar .nav{position:relative;left:0;display:block;float:left;margin:0 10px 0 0;}
-.navbar .nav.pull-right{float:right;}
-.navbar .nav>li{display:block;float:left;}
-.navbar .nav>li>a{float:none;padding:10px 10px 11px;line-height:19px;color:#999999;text-decoration:none;text-shadow:0 -1px 0 rgba(0, 0, 0, 0.25);}
-.navbar .nav>li>a:hover{background-color:transparent;color:#ffffff;text-decoration:none;}
-.navbar .nav .active>a,.navbar .nav .active>a:hover{color:#ffffff;text-decoration:none;background-color:#222222;}
-.navbar .divider-vertical{height:40px;width:1px;margin:0 9px;overflow:hidden;background-color:#222222;border-right:1px solid #333333;}
-.navbar .nav.pull-right{margin-left:10px;margin-right:0;}
-.navbar .dropdown-menu{margin-top:1px;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;}.navbar .dropdown-menu:before{content:'';display:inline-block;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:7px solid #ccc;border-bottom-color:rgba(0, 0, 0, 0.2);position:absolute;top:-7px;left:9px;}
-.navbar .dropdown-menu:after{content:'';display:inline-block;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid #ffffff;position:absolute;top:-6px;left:10px;}
-.navbar-fixed-bottom .dropdown-menu:before{border-top:7px solid #ccc;border-top-color:rgba(0, 0, 0, 0.2);border-bottom:0;bottom:-7px;top:auto;}
-.navbar-fixed-bottom .dropdown-menu:after{border-top:6px solid #ffffff;border-bottom:0;bottom:-6px;top:auto;}
-.navbar .nav .dropdown-toggle .caret,.navbar .nav .open.dropdown .caret{border-top-color:#ffffff;border-bottom-color:#ffffff;}
-.navbar .nav .active .caret{opacity:1;filter:alpha(opacity=100);}
-.navbar .nav .open>.dropdown-toggle,.navbar .nav .active>.dropdown-toggle,.navbar .nav .open.active>.dropdown-toggle{background-color:transparent;}
-.navbar .nav .active>.dropdown-toggle:hover{color:#ffffff;}
-.navbar .nav.pull-right .dropdown-menu,.navbar .nav .dropdown-menu.pull-right{left:auto;right:0;}.navbar .nav.pull-right .dropdown-menu:before,.navbar .nav .dropdown-menu.pull-right:before{left:auto;right:12px;}
-.navbar .nav.pull-right .dropdown-menu:after,.navbar .nav .dropdown-menu.pull-right:after{left:auto;right:13px;}
-.breadcrumb{padding:7px 14px;margin:0 0 18px;list-style:none;background-color:#fbfbfb;background-image:-moz-linear-gradient(top, #ffffff, #f5f5f5);background-image:-ms-linear-gradient(top, #ffffff, #f5f5f5);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#ffffff), to(#f5f5f5));background-image:-webkit-linear-gradient(top, #ffffff, #f5f5f5);background-image:-o-linear-gradient(top, #ffffff, #f5f5f5);background-image:linear-gradient(top, #ffffff, #f5f5f5);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#f5f5f5', GradientType=0);border:1px solid #ddd;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;-webkit-box-shadow:inset 0 1px 0 #ffffff;-moz-box-shadow:inset 0 1px 0 #ffffff;box-shadow:inset 0 1px 0 #ffffff;}.breadcrumb li{display:inline-block;*display:inline;*zoom:1;text-shadow:0 1px 0 #ffffff;}
-.breadcrumb .divider{padding:0 5px;color:#999999;}
-.breadcrumb .active a{color:#333333;}
-.pagination{height:36px;margin:18px 0;}
-.pagination ul{display:inline-block;*display:inline;*zoom:1;margin-left:0;margin-bottom:0;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;-webkit-box-shadow:0 1px 2px rgba(0, 0, 0, 0.05);-moz-box-shadow:0 1px 2px rgba(0, 0, 0, 0.05);box-shadow:0 1px 2px rgba(0, 0, 0, 0.05);}
-.pagination li{display:inline;}
-.pagination a{float:left;padding:0 14px;line-height:34px;text-decoration:none;border:1px solid #ddd;border-left-width:0;}
-.pagination a:hover,.pagination .active a{background-color:#f5f5f5;}
-.pagination .active a{color:#999999;cursor:default;}
-.pagination .disabled span,.pagination .disabled a,.pagination .disabled a:hover{color:#999999;background-color:transparent;cursor:default;}
-.pagination li:first-child a{border-left-width:1px;-webkit-border-radius:3px 0 0 3px;-moz-border-radius:3px 0 0 3px;border-radius:3px 0 0 3px;}
-.pagination li:last-child a{-webkit-border-radius:0 3px 3px 0;-moz-border-radius:0 3px 3px 0;border-radius:0 3px 3px 0;}
-.pagination-centered{text-align:center;}
-.pagination-right{text-align:right;}
-.pager{margin-left:0;margin-bottom:18px;list-style:none;text-align:center;*zoom:1;}.pager:before,.pager:after{display:table;content:"";}
-.pager:after{clear:both;}
-.pager li{display:inline;}
-.pager a{display:inline-block;padding:5px 14px;background-color:#fff;border:1px solid #ddd;-webkit-border-radius:15px;-moz-border-radius:15px;border-radius:15px;}
-.pager a:hover{text-decoration:none;background-color:#f5f5f5;}
-.pager .next a{float:right;}
-.pager .previous a{float:left;}
-.pager .disabled a,.pager .disabled a:hover{color:#999999;background-color:#fff;cursor:default;}
-.modal-open .dropdown-menu{z-index:2050;}
-.modal-open .dropdown.open{*z-index:2050;}
-.modal-open .popover{z-index:2060;}
-.modal-open .tooltip{z-index:2070;}
-.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;background-color:#000000;}.modal-backdrop.fade{opacity:0;}
-.modal-backdrop,.modal-backdrop.fade.in{opacity:0.8;filter:alpha(opacity=80);}
-.modal{position:fixed;top:50%;left:50%;z-index:1050;overflow:auto;width:560px;margin:-250px 0 0 -280px;background-color:#ffffff;border:1px solid #999;border:1px solid rgba(0, 0, 0, 0.3);*border:1px solid #999;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;-webkit-box-shadow:0 3px 7px rgba(0, 0, 0, 0.3);-moz-box-shadow:0 3px 7px rgba(0, 0, 0, 0.3);box-shadow:0 3px 7px rgba(0, 0, 0, 0.3);-webkit-background-clip:padding-box;-moz-background-clip:padding-box;background-clip:padding-box;}.modal.fade{-webkit-transition:opacity .3s linear, top .3s ease-out;-moz-transition:opacity .3s linear, top .3s ease-out;-ms-transition:opacity .3s linear, top .3s ease-out;-o-transition:opacity .3s linear, top .3s ease-out;transition:opacity .3s linear, top .3s ease-out;top:-25%;}
-.modal.fade.in{top:50%;}
-.modal-header{padding:9px 15px;border-bottom:1px solid #eee;}.modal-header .close{margin-top:2px;}
-.modal-body{overflow-y:auto;max-height:400px;padding:15px;}
-.modal-form{margin-bottom:0;}
-.modal-footer{padding:14px 15px 15px;margin-bottom:0;text-align:right;background-color:#f5f5f5;border-top:1px solid #ddd;-webkit-border-radius:0 0 6px 6px;-moz-border-radius:0 0 6px 6px;border-radius:0 0 6px 6px;-webkit-box-shadow:inset 0 1px 0 #ffffff;-moz-box-shadow:inset 0 1px 0 #ffffff;box-shadow:inset 0 1px 0 #ffffff;*zoom:1;}.modal-footer:before,.modal-footer:after{display:table;content:"";}
-.modal-footer:after{clear:both;}
-.modal-footer .btn+.btn{margin-left:5px;margin-bottom:0;}
-.modal-footer .btn-group .btn+.btn{margin-left:-1px;}
-.tooltip{position:absolute;z-index:1020;display:block;visibility:visible;padding:5px;font-size:11px;opacity:0;filter:alpha(opacity=0);}.tooltip.in{opacity:0.8;filter:alpha(opacity=80);}
-.tooltip.top{margin-top:-2px;}
-.tooltip.right{margin-left:2px;}
-.tooltip.bottom{margin-top:2px;}
-.tooltip.left{margin-left:-2px;}
-.tooltip.top .tooltip-arrow{bottom:0;left:50%;margin-left:-5px;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid #000000;}
-.tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:5px solid #000000;}
-.tooltip.bottom .tooltip-arrow{top:0;left:50%;margin-left:-5px;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:5px solid #000000;}
-.tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-top:5px solid transparent;border-bottom:5px solid transparent;border-right:5px solid #000000;}
-.tooltip-inner{max-width:200px;padding:3px 8px;color:#ffffff;text-align:center;text-decoration:none;background-color:#000000;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;}
-.tooltip-arrow{position:absolute;width:0;height:0;}
-.popover{position:absolute;top:0;left:0;z-index:1010;display:none;padding:5px;}.popover.top{margin-top:-5px;}
-.popover.right{margin-left:5px;}
-.popover.bottom{margin-top:5px;}
-.popover.left{margin-left:-5px;}
-.popover.top .arrow{bottom:0;left:50%;margin-left:-5px;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid #000000;}
-.popover.right .arrow{top:50%;left:0;margin-top:-5px;border-top:5px solid transparent;border-bottom:5px solid transparent;border-right:5px solid #000000;}
-.popover.bottom .arrow{top:0;left:50%;margin-left:-5px;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:5px solid #000000;}
-.popover.left .arrow{top:50%;right:0;margin-top:-5px;border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:5px solid #000000;}
-.popover .arrow{position:absolute;width:0;height:0;}
-.popover-inner{padding:3px;width:280px;overflow:hidden;background:#000000;background:rgba(0, 0, 0, 0.8);-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;-webkit-box-shadow:0 3px 7px rgba(0, 0, 0, 0.3);-moz-box-shadow:0 3px 7px rgba(0, 0, 0, 0.3);box-shadow:0 3px 7px rgba(0, 0, 0, 0.3);}
-.popover-title{padding:9px 15px;line-height:1;background-color:#f5f5f5;border-bottom:1px solid #eee;-webkit-border-radius:3px 3px 0 0;-moz-border-radius:3px 3px 0 0;border-radius:3px 3px 0 0;}
-.popover-content{padding:14px;background-color:#ffffff;-webkit-border-radius:0 0 3px 3px;-moz-border-radius:0 0 3px 3px;border-radius:0 0 3px 3px;-webkit-background-clip:padding-box;-moz-background-clip:padding-box;background-clip:padding-box;}.popover-content p,.popover-content ul,.popover-content ol{margin-bottom:0;}
-.thumbnails{margin-left:-20px;list-style:none;*zoom:1;}.thumbnails:before,.thumbnails:after{display:table;content:"";}
-.thumbnails:after{clear:both;}
-.thumbnails>li{float:left;margin:0 0 18px 20px;}
-.thumbnail{display:block;padding:4px;line-height:1;border:1px solid #ddd;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;-webkit-box-shadow:0 1px 1px rgba(0, 0, 0, 0.075);-moz-box-shadow:0 1px 1px rgba(0, 0, 0, 0.075);box-shadow:0 1px 1px rgba(0, 0, 0, 0.075);}
-a.thumbnail:hover{border-color:#0088cc;-webkit-box-shadow:0 1px 4px rgba(0, 105, 214, 0.25);-moz-box-shadow:0 1px 4px rgba(0, 105, 214, 0.25);box-shadow:0 1px 4px rgba(0, 105, 214, 0.25);}
-.thumbnail>img{display:block;max-width:100%;margin-left:auto;margin-right:auto;}
-.thumbnail .caption{padding:9px;}
-.label{padding:1px 4px 2px;font-size:10.998px;font-weight:bold;line-height:13px;color:#ffffff;vertical-align:middle;white-space:nowrap;text-shadow:0 -1px 0 rgba(0, 0, 0, 0.25);background-color:#999999;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;}
-.label:hover{color:#ffffff;text-decoration:none;}
-.label-important{background-color:#b94a48;}
-.label-important:hover{background-color:#953b39;}
-.label-warning{background-color:#f89406;}
-.label-warning:hover{background-color:#c67605;}
-.label-success{background-color:#468847;}
-.label-success:hover{background-color:#356635;}
-.label-info{background-color:#3a87ad;}
-.label-info:hover{background-color:#2d6987;}
-.label-inverse{background-color:#333333;}
-.label-inverse:hover{background-color:#1a1a1a;}
-.badge{padding:1px 9px 2px;font-size:12.025px;font-weight:bold;white-space:nowrap;color:#ffffff;background-color:#999999;-webkit-border-radius:9px;-moz-border-radius:9px;border-radius:9px;}
-.badge:hover{color:#ffffff;text-decoration:none;cursor:pointer;}
-.badge-error{background-color:#b94a48;}
-.badge-error:hover{background-color:#953b39;}
-.badge-warning{background-color:#f89406;}
-.badge-warning:hover{background-color:#c67605;}
-.badge-success{background-color:#468847;}
-.badge-success:hover{background-color:#356635;}
-.badge-info{background-color:#3a87ad;}
-.badge-info:hover{background-color:#2d6987;}
-.badge-inverse{background-color:#333333;}
-.badge-inverse:hover{background-color:#1a1a1a;}
-@-webkit-keyframes progress-bar-stripes{from{background-position:0 0;} to{background-position:40px 0;}}@-moz-keyframes progress-bar-stripes{from{background-position:0 0;} to{background-position:40px 0;}}@-ms-keyframes progress-bar-stripes{from{background-position:0 0;} to{background-position:40px 0;}}@keyframes progress-bar-stripes{from{background-position:0 0;} to{background-position:40px 0;}}.progress{overflow:hidden;height:18px;margin-bottom:18px;background-color:#f7f7f7;background-image:-moz-linear-gradient(top, #f5f5f5, #f9f9f9);background-image:-ms-linear-gradient(top, #f5f5f5, #f9f9f9);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#f5f5f5), to(#f9f9f9));background-image:-webkit-linear-gradient(top, #f5f5f5, #f9f9f9);background-image:-o-linear-gradient(top, #f5f5f5, #f9f9f9);background-image:linear-gradient(top, #f5f5f5, #f9f9f9);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#f5f5f5', endColorstr='#f9f9f9', GradientType=0);-webkit-box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1);-moz-box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1);box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1);-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;}
-.progress .bar{width:0%;height:18px;color:#ffffff;font-size:12px;text-align:center;text-shadow:0 -1px 0 rgba(0, 0, 0, 0.25);background-color:#0e90d2;background-image:-moz-linear-gradient(top, #149bdf, #0480be);background-image:-ms-linear-gradient(top, #149bdf, #0480be);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#149bdf), to(#0480be));background-image:-webkit-linear-gradient(top, #149bdf, #0480be);background-image:-o-linear-gradient(top, #149bdf, #0480be);background-image:linear-gradient(top, #149bdf, #0480be);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#149bdf', endColorstr='#0480be', GradientType=0);-webkit-box-shadow:inset 0 -1px 0 rgba(0, 0, 0, 0.15);-moz-box-shadow:inset 0 -1px 0 rgba(0, 0, 0, 0.15);box-shadow:inset 0 -1px 0 rgba(0, 0, 0, 0.15);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box;-webkit-transition:width 0.6s ease;-moz-transition:width 0.6s ease;-ms-transition:width 0.6s ease;-o-transition:width 0.6s ease;transition:width 0.6s ease;}
-.progress-striped .bar{background-color:#149bdf;background-image:-webkit-gradient(linear, 0 100%, 100% 0, color-stop(0.25, rgba(255, 255, 255, 0.15)), color-stop(0.25, transparent), color-stop(0.5, transparent), color-stop(0.5, rgba(255, 255, 255, 0.15)), color-stop(0.75, rgba(255, 255, 255, 0.15)), color-stop(0.75, transparent), to(transparent));background-image:-webkit-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-moz-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-ms-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-o-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);-webkit-background-size:40px 40px;-moz-background-size:40px 40px;-o-background-size:40px 40px;background-size:40px 40px;}
-.progress.active .bar{-webkit-animation:progress-bar-stripes 2s linear infinite;-moz-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite;}
-.progress-danger .bar{background-color:#dd514c;background-image:-moz-linear-gradient(top, #ee5f5b, #c43c35);background-image:-ms-linear-gradient(top, #ee5f5b, #c43c35);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#ee5f5b), to(#c43c35));background-image:-webkit-linear-gradient(top, #ee5f5b, #c43c35);background-image:-o-linear-gradient(top, #ee5f5b, #c43c35);background-image:linear-gradient(top, #ee5f5b, #c43c35);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ee5f5b', endColorstr='#c43c35', GradientType=0);}
-.progress-danger.progress-striped .bar{background-color:#ee5f5b;background-image:-webkit-gradient(linear, 0 100%, 100% 0, color-stop(0.25, rgba(255, 255, 255, 0.15)), color-stop(0.25, transparent), color-stop(0.5, transparent), color-stop(0.5, rgba(255, 255, 255, 0.15)), color-stop(0.75, rgba(255, 255, 255, 0.15)), color-stop(0.75, transparent), to(transparent));background-image:-webkit-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-moz-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-ms-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-o-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);}
-.progress-success .bar{background-color:#5eb95e;background-image:-moz-linear-gradient(top, #62c462, #57a957);background-image:-ms-linear-gradient(top, #62c462, #57a957);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#62c462), to(#57a957));background-image:-webkit-linear-gradient(top, #62c462, #57a957);background-image:-o-linear-gradient(top, #62c462, #57a957);background-image:linear-gradient(top, #62c462, #57a957);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#62c462', endColorstr='#57a957', GradientType=0);}
-.progress-success.progress-striped .bar{background-color:#62c462;background-image:-webkit-gradient(linear, 0 100%, 100% 0, color-stop(0.25, rgba(255, 255, 255, 0.15)), color-stop(0.25, transparent), color-stop(0.5, transparent), color-stop(0.5, rgba(255, 255, 255, 0.15)), color-stop(0.75, rgba(255, 255, 255, 0.15)), color-stop(0.75, transparent), to(transparent));background-image:-webkit-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-moz-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-ms-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-o-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);}
-.progress-info .bar{background-color:#4bb1cf;background-image:-moz-linear-gradient(top, #5bc0de, #339bb9);background-image:-ms-linear-gradient(top, #5bc0de, #339bb9);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#5bc0de), to(#339bb9));background-image:-webkit-linear-gradient(top, #5bc0de, #339bb9);background-image:-o-linear-gradient(top, #5bc0de, #339bb9);background-image:linear-gradient(top, #5bc0de, #339bb9);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#5bc0de', endColorstr='#339bb9', GradientType=0);}
-.progress-info.progress-striped .bar{background-color:#5bc0de;background-image:-webkit-gradient(linear, 0 100%, 100% 0, color-stop(0.25, rgba(255, 255, 255, 0.15)), color-stop(0.25, transparent), color-stop(0.5, transparent), color-stop(0.5, rgba(255, 255, 255, 0.15)), color-stop(0.75, rgba(255, 255, 255, 0.15)), color-stop(0.75, transparent), to(transparent));background-image:-webkit-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-moz-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-ms-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-o-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);}
-.progress-warning .bar{background-color:#faa732;background-image:-moz-linear-gradient(top, #fbb450, #f89406);background-image:-ms-linear-gradient(top, #fbb450, #f89406);background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#fbb450), to(#f89406));background-image:-webkit-linear-gradient(top, #fbb450, #f89406);background-image:-o-linear-gradient(top, #fbb450, #f89406);background-image:linear-gradient(top, #fbb450, #f89406);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#fbb450', endColorstr='#f89406', GradientType=0);}
-.progress-warning.progress-striped .bar{background-color:#fbb450;background-image:-webkit-gradient(linear, 0 100%, 100% 0, color-stop(0.25, rgba(255, 255, 255, 0.15)), color-stop(0.25, transparent), color-stop(0.5, transparent), color-stop(0.5, rgba(255, 255, 255, 0.15)), color-stop(0.75, rgba(255, 255, 255, 0.15)), color-stop(0.75, transparent), to(transparent));background-image:-webkit-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-moz-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-ms-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:-o-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);background-image:linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);}
-.accordion{margin-bottom:18px;}
-.accordion-group{margin-bottom:2px;border:1px solid #e5e5e5;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;}
-.accordion-heading{border-bottom:0;}
-.accordion-heading .accordion-toggle{display:block;padding:8px 15px;}
-.accordion-inner{padding:9px 15px;border-top:1px solid #e5e5e5;}
-.carousel{position:relative;margin-bottom:18px;line-height:1;}
-.carousel-inner{overflow:hidden;width:100%;position:relative;}
-.carousel .item{display:none;position:relative;-webkit-transition:0.6s ease-in-out left;-moz-transition:0.6s ease-in-out left;-ms-transition:0.6s ease-in-out left;-o-transition:0.6s ease-in-out left;transition:0.6s ease-in-out left;}
-.carousel .item>img{display:block;line-height:1;}
-.carousel .active,.carousel .next,.carousel .prev{display:block;}
-.carousel .active{left:0;}
-.carousel .next,.carousel .prev{position:absolute;top:0;width:100%;}
-.carousel .next{left:100%;}
-.carousel .prev{left:-100%;}
-.carousel .next.left,.carousel .prev.right{left:0;}
-.carousel .active.left{left:-100%;}
-.carousel .active.right{left:100%;}
-.carousel-control{position:absolute;top:40%;left:15px;width:40px;height:40px;margin-top:-20px;font-size:60px;font-weight:100;line-height:30px;color:#ffffff;text-align:center;background:#222222;border:3px solid #ffffff;-webkit-border-radius:23px;-moz-border-radius:23px;border-radius:23px;opacity:0.5;filter:alpha(opacity=50);}.carousel-control.right{left:auto;right:15px;}
-.carousel-control:hover{color:#ffffff;text-decoration:none;opacity:0.9;filter:alpha(opacity=90);}
-.carousel-caption{position:absolute;left:0;right:0;bottom:0;padding:10px 15px 5px;background:#333333;background:rgba(0, 0, 0, 0.75);}
-.carousel-caption h4,.carousel-caption p{color:#ffffff;}
-.hero-unit{padding:60px;margin-bottom:30px;background-color:#eeeeee;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;}.hero-unit h1{margin-bottom:0;font-size:60px;line-height:1;color:inherit;letter-spacing:-1px;}
-.hero-unit p{font-size:18px;font-weight:200;line-height:27px;color:inherit;}
-.pull-right{float:right;}
-.pull-left{float:left;}
-.hide{display:none;}
-.show{display:block;}
-.invisible{visibility:hidden;}
diff --git a/assets/twitter/stylesheets/style.css b/assets/twitter/stylesheets/style.css
deleted file mode 100644
index d51c4bb..0000000
--- a/assets/twitter/stylesheets/style.css
+++ /dev/null
@@ -1,84 +0,0 @@
-/* Override some defaults */
-html, body {
- background-color: #eee;
-}
-.navbar {
- margin-bottom: 0;
-}
-.navbar .container{
- width:940px;
-}
-.container > footer {
- margin-top: 20px;
-}
-.container > footer p {
- text-align: center; /* center align it with the container */
-}
-
-/* The white background content wrapper */
-.content {
- background-color: #fff;
- padding: 20px;
- margin: 0 -20px; /* negative indent the amount of the padding to maintain the grid system */
- -webkit-border-radius: 0 0 6px 6px;
- -moz-border-radius: 0 0 6px 6px;
- border-radius: 0 0 6px 6px;
- -webkit-box-shadow: 0 1px 2px rgba(0,0,0,.15);
- -moz-box-shadow: 0 1px 2px rgba(0,0,0,.15);
- box-shadow: 0 1px 2px rgba(0,0,0,.15);
-}
-
-/* Page header tweaks */
-.page-header {
- background-color: #f5f5f5;
- padding: 20px 20px 10px;
- margin: -20px -20px 20px;
-}
-
-/* posts index */
-.post > h3.title {
- position:relative;
- padding-top:10px;
- border-top:3px solid #eee;
-}
-.post > h3.title span.date {
- position:absolute;
- right:0;
- font-size:0.9em;
-}
-.post > .more {
- margin:10px 0;
- text-align:left;
-}
-
-/* tag_box ======================================================== */
-
-.tag_box {
- list-style:none;
- margin:0;
- padding:5px 0 ;
- overflow:hidden;
-}
-.tag_box li {
- line-height:28px;
-}
-.tag_box.inline li {
- float:left;
-}
-.tag_box a {
- padding: 3px 6px;
- margin: 2px;
- background: #eee;
- color:#005F6B;
- border-radius: 3px;
- text-decoration:none;
-}
-.tag_box a span{
- vertical-align:super;
- font-size:0.8em;
-}
-.tag_box a.active {
- background:#57A957;
- border:1px solid #4C964D;
- color:#FFF;
-}
diff --git a/assets/twitter/theme.yml b/assets/twitter/theme.yml
deleted file mode 100644
index cdc5f85..0000000
--- a/assets/twitter/theme.yml
+++ /dev/null
@@ -1,23 +0,0 @@
-{
- "stylesheets" : {
- "default" : [
- "bootstrap.min.css",
- "style.css"
- ],
-
- "widgets" : {
- "google_prettify" : "twitter-bootstrap.css"
- }
-
- },
-
- "javascripts" : {
- "default" : [
- ]
- },
-
- "manifest" : {
- "author" : "Jacob Thornton and Mark Otto",
- "website" : "http://twitter.github.com/bootstrap"
- }
-}
\ No newline at end of file
diff --git a/assets/twitter/widgets/google_prettify/stylesheets/default.css b/assets/twitter/widgets/google_prettify/stylesheets/default.css
deleted file mode 100644
index acfee4d..0000000
--- a/assets/twitter/widgets/google_prettify/stylesheets/default.css
+++ /dev/null
@@ -1,52 +0,0 @@
-/* Pretty printing styles. Used with prettify.js. */
-
-/* SPAN elements with the classes below are added by prettyprint. */
-.pln { color: #000 } /* plain text */
-
-@media screen {
- .str { color: #080 } /* string content */
- .kwd { color: #008 } /* a keyword */
- .com { color: #800 } /* a comment */
- .typ { color: #606 } /* a type name */
- .lit { color: #066 } /* a literal value */
- /* punctuation, lisp open bracket, lisp close bracket */
- .pun, .opn, .clo { color: #660 }
- .tag { color: #008 } /* a markup tag name */
- .atn { color: #606 } /* a markup attribute name */
- .atv { color: #080 } /* a markup attribute value */
- .dec, .var { color: #606 } /* a declaration; a variable name */
- .fun { color: red } /* a function name */
-}
-
-/* Use higher contrast and text-weight for printable form. */
-@media print, projection {
- .str { color: #060 }
- .kwd { color: #006; font-weight: bold }
- .com { color: #600; font-style: italic }
- .typ { color: #404; font-weight: bold }
- .lit { color: #044 }
- .pun, .opn, .clo { color: #440 }
- .tag { color: #006; font-weight: bold }
- .atn { color: #404 }
- .atv { color: #060 }
-}
-
-/* Put a border around prettyprinted code snippets. */
-pre.prettyprint { padding: 2px; border: 1px solid #888 }
-
-/* Specify class=linenums on a pre to get line numbering */
-ol.linenums { margin-top: 0; margin-bottom: 0 } /* IE indents via margin-left */
-li.L0,
-li.L1,
-li.L2,
-li.L3,
-li.L5,
-li.L6,
-li.L7,
-li.L8 { list-style-type: none }
-/* Alternate shading for lines */
-li.L1,
-li.L3,
-li.L5,
-li.L7,
-li.L9 { background: #eee }
diff --git a/assets/twitter/widgets/google_prettify/stylesheets/desert.css b/assets/twitter/widgets/google_prettify/stylesheets/desert.css
deleted file mode 100644
index f6ba40d..0000000
--- a/assets/twitter/widgets/google_prettify/stylesheets/desert.css
+++ /dev/null
@@ -1,34 +0,0 @@
-/* desert scheme ported from vim to google prettify */
-pre { display: block; background-color: #333 }
-pre .nocode { background-color: none; color: #000 }
-pre .str { color: #ffa0a0 } /* string - pink */
-pre .kwd { color: #f0e68c; font-weight: bold }
-pre .com { color: #87ceeb } /* comment - skyblue */
-pre .typ { color: #98fb98 } /* type - lightgreen */
-pre .lit { color: #cd5c5c } /* literal - darkred */
-pre .pun { color: #fff } /* punctuation */
-pre .pln { color: #fff } /* plaintext */
-pre .tag { color: #f0e68c; font-weight: bold } /* html/xml tag - lightyellow */
-pre .atn { color: #bdb76b; font-weight: bold } /* attribute name - khaki */
-pre .atv { color: #ffa0a0 } /* attribute value - pink */
-pre .dec { color: #98fb98 } /* decimal - lightgreen */
-
-/* Specify class=linenums on a pre to get line numbering */
-ol.linenums { margin-top: 0; margin-bottom: 0; color: #AEAEAE } /* IE indents via margin-left */
-li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8 { list-style-type: none }
-/* Alternate shading for lines */
-li.L1,li.L3,li.L5,li.L7,li.L9 { }
-
-@media print {
- pre { background-color: none }
- pre .str, code .str { color: #060 }
- pre .kwd, code .kwd { color: #006; font-weight: bold }
- pre .com, code .com { color: #600; font-style: italic }
- pre .typ, code .typ { color: #404; font-weight: bold }
- pre .lit, code .lit { color: #044 }
- pre .pun, code .pun { color: #440 }
- pre .pln, code .pln { color: #000 }
- pre .tag, code .tag { color: #006; font-weight: bold }
- pre .atn, code .atn { color: #404 }
- pre .atv, code .atv { color: #060 }
-}
diff --git a/assets/twitter/widgets/google_prettify/stylesheets/sons-of-obsidian.css b/assets/twitter/widgets/google_prettify/stylesheets/sons-of-obsidian.css
deleted file mode 100644
index 6eb4135..0000000
--- a/assets/twitter/widgets/google_prettify/stylesheets/sons-of-obsidian.css
+++ /dev/null
@@ -1,117 +0,0 @@
-/*
- * Derived from einaros's Sons of Obsidian theme at
- * http://studiostyl.es/schemes/son-of-obsidian by
- * Alex Ford of CodeTunnel:
- * http://CodeTunnel.com/blog/post/71/google-code-prettify-obsidian-theme
- */
-
-.str
-{
- color: #EC7600;
-}
-.kwd
-{
- color: #93C763;
-}
-.com
-{
- color: #66747B;
-}
-.typ
-{
- color: #678CB1;
-}
-.lit
-{
- color: #FACD22;
-}
-.pun
-{
- color: #F1F2F3;
-}
-.pln
-{
- color: #F1F2F3;
-}
-.tag
-{
- color: #8AC763;
-}
-.atn
-{
- color: #E0E2E4;
-}
-.atv
-{
- color: #EC7600;
-}
-.dec
-{
- color: purple;
-}
-pre.prettyprint
-{
- border: 0px solid #888;
-}
-ol.linenums
-{
- margin-top: 0;
- margin-bottom: 0;
-}
-.prettyprint {
- background: #000;
-}
-li.L0, li.L1, li.L2, li.L3, li.L4, li.L5, li.L6, li.L7, li.L8, li.L9
-{
- color: #555;
-}
-li.L1, li.L3, li.L5, li.L7, li.L9 {
- background: #111;
-}
-@media print
-{
- .str
- {
- color: #060;
- }
- .kwd
- {
- color: #006;
- font-weight: bold;
- }
- .com
- {
- color: #600;
- font-style: italic;
- }
- .typ
- {
- color: #404;
- font-weight: bold;
- }
- .lit
- {
- color: #044;
- }
- .pun
- {
- color: #440;
- }
- .pln
- {
- color: #000;
- }
- .tag
- {
- color: #006;
- font-weight: bold;
- }
- .atn
- {
- color: #404;
- }
- .atv
- {
- color: #060;
- }
-}
diff --git a/assets/twitter/widgets/google_prettify/stylesheets/sunburst.css b/assets/twitter/widgets/google_prettify/stylesheets/sunburst.css
deleted file mode 100644
index 8772515..0000000
--- a/assets/twitter/widgets/google_prettify/stylesheets/sunburst.css
+++ /dev/null
@@ -1,51 +0,0 @@
-/* Pretty printing styles. Used with prettify.js. */
-/* Vim sunburst theme by David Leibovic */
-
-pre .str, code .str { color: #65B042; } /* string - green */
-pre .kwd, code .kwd { color: #E28964; } /* keyword - dark pink */
-pre .com, code .com { color: #AEAEAE; font-style: italic; } /* comment - gray */
-pre .typ, code .typ { color: #89bdff; } /* type - light blue */
-pre .lit, code .lit { color: #3387CC; } /* literal - blue */
-pre .pun, code .pun { color: #fff; } /* punctuation - white */
-pre .pln, code .pln { color: #fff; } /* plaintext - white */
-pre .tag, code .tag { color: #89bdff; } /* html/xml tag - light blue */
-pre .atn, code .atn { color: #bdb76b; } /* html/xml attribute name - khaki */
-pre .atv, code .atv { color: #65B042; } /* html/xml attribute value - green */
-pre .dec, code .dec { color: #3387CC; } /* decimal - blue */
-
-pre.prettyprint, code.prettyprint {
- background-color: #000;
- -moz-border-radius: 8px;
- -webkit-border-radius: 8px;
- -o-border-radius: 8px;
- -ms-border-radius: 8px;
- -khtml-border-radius: 8px;
- bo