Pandoc中使用Reveal.js制作幻灯片

工具:Typora (markdown编辑器) + Pandoc + reveal.js

如果需要使用 pandoc 命令,则需将 pandoc 添加到 path 环境变量中

Pandoc

pandoc如果没有指定输入文件则从stdin读取,并且使用stdout作为默认输出。可以使用 -o选项指定输出文件:

pandoc -o output.html input.txt

pandoc 自行安装

文件转换

官方提供了各种转换示例:Pandoc - Demos

还可在线尝试 Pandoc:Try pandoc!

直接使用 pandoc 命令(使用其默认模板)

转换为word:

pandoc -f markdown -t docx file.md -o file.docx

转换为 html:

pandoc file.md -o file.html -s

转换为pdf:

pandoc test.txt -o test.pdf

直接使用pandoc,遇到如下提示:

pdflatex not found. Please select a different --pdf-engine or install pdflatex

直接使用pandoc命令,使用的是其默认的模板,往往得不到自己想要的效果,所以建议利用 Typora 完成markdown 到其它文件格式的转换。使用 Typora 调用 Pandoc,好处就是转换后的文档格式就是Typora中所显示的格式。

比如中Typora中markdown与word的互转:

在Typora中:Typora > 文件 > 导入/导出 选择 word格式即可。(markdown中的数学公式可以转换到word中。)

Pandoc具有模块化设计:它由一系列读出器和一系列编写器组成的,读出器用于以给定格式分析文本并生成一份此文档的本地表示,编写器则用于将这份本地表示转换为目标格式。因此,增加某种输入或输出格式只需要增加一个读出器或编写器就可以了。

查看转换为pdf使用的默认模板:

pandoc -D latex

转换为幻灯片(slides)

目前Pandoc包含了对五种HTML幻灯片框架的支持:

  • DZSlides
  • Slidy
  • S5
  • Slideous
  • reveal.js

当然,你实际上可以使用任何喜欢的幻灯片框架,只要让Pandoc在渲染HTML时使用你指定的模板(使用-t选项)即可。

使用dzslides,转换为ppt 的示例:

pandoc slides.md -o slides.html -t dzslides -s

选项 -s 的作用:(表示不理解)

By default, pandoc produces a document fragment. To produce a standalone document (e.g. a valid HTML file including and ), use the -s or --standalone flag:

另:使用-s / - standalone选项时,pandoc使用模板添加自立文档所需的页眉和页脚材料

pandoc -s -o output.html input.txt

在直接转换成html文件的时候感觉加不加-s没啥大的区别,但在制作幻灯片时必须加 -s选项

HTML fragment:
pandoc README -o example1.html

Standalone HTML file:
pandoc -s README -o example2.html

在这些框架中 Reveal.js 的设计风格(字体、HTML5/CSS3效果)比起前面几个框架更加现代,所以推荐使用 Reveal.js。

虽说reveal.js本身就提供对Markdown语法的支持.。不过使用Pandoc的好处很明显,那就是一条命令解决问题,不需要用户接触任何HTML,使用简单。缺点就是需要安装 pandoc ,而reveal.js只有几M大小的Js文件而已,且使用 reveal.js 可以更容易进行深度定制。

下文将介绍 reveal.js 的使用。

直接使用Reveal.js

下载 reveal.js文件里面提供了一个模板文件 index.html 和 一个示例文件 demo.html 。

我们在创建幻灯片时,可以复制index.html文件内容,并在其基础上更改,找到文件中类似下面的标签,并在里面添加幻灯片。

        
Slide 1 幻灯片1的内容
Slide 2 幻灯片2的内容
使该幻灯片支持 markdown 语法
为该幻灯片 使用特定转场动画,值可以是:fede,slide,convex,concave,zoom,none
为该幻灯片指定背景色
为该幻灯片指定背景图片
为该幻灯片指定背景视频

如果还嫌不够,顺便说一句,Reveal.js 支持 javascript,所以其应用场景可不限于传统的演示文稿——如果你想做一个现场投票、幸运转盘抽奖,都没问题。这些有趣的拓展功能都内嵌在你的 Reveal.js 版「PPT」里 。

参考: Reveal.js:把你的 Markdown 文稿变成 PPT - 少数派

更详细的使用见文档:GitHub - hakimel/reveal.js: The HTML Presentation Framework

使用Pandoc和Reveal.js制作幻灯片

转换所用文本(示例文本,标准文本):

% Habits
% John Doe
% March 22, 2005

# In the morning

## Getting up

- Turn off alarm
- Get out of bed

## Breakfast

- Eat eggs
- Drink coffee

# In the evening

## Dinner

- Eat spaghetti
- Drink wine

------------------

![picture of spaghetti](images/spaghetti.jpg)

## Going to sleep

- Get in bed
- Count sheep

该文本来自: Pandoc - Pandoc User’s Guide

为了让Pandoc对不包含任何元信息的Markdown文本进行处理生成幻灯片,在文本开头需要包含三行以%打头的元信息:标题、作者和日期。

首先需要从GitHub上获取https://github.com/hakimel/reveal.js,并将reveal.js同名的文件夹放在幻灯片所在目录下即可:

使用git克隆,或者直接下载reveal.js的压缩包.

$ git clone https://github.com/hakimel/reveal.js

渲染幻灯片:

$ pandoc slides.md -o slides.html -t revealjs -s

除了默认的外观主题以外,reveal.js 还提供了多个主题可供选择

$ pandoc slides.md -o slides.html -t revealjs -s -V theme=beige

reveal.js主题:

  • default:(默认)深灰色背景,白色文字
  • beige:米色背景,深色文字
  • sky:天蓝色背景,白色细文字
  • night:黑色背景,白色粗文字
  • serif:浅色背景,灰色衬线文字
  • simple:白色背景,黑色文字
  • solarized:奶油色背景,深青色文字

如果你用于转换的markdown文件格式不符合要求,可能会出现如下警告:

pandoc Pandoc.md -o slides.html -t revealjs -s -V theme=night
[WARNING] This document format requires a nonempty  element.
 Please specify either 'title' or 'pagetitle' in the metadata.
 Falling back to 'Pandoc'
</code></pre> 
 </blockquote> 
 <blockquote> 
  <p><code>-V</code>选项:</p> 
  <p>模板包含变量(variables),它的作用是允许在文件中的任何位置包含任意信息。 可以使用<code>-V / - variable</code>选项在命令行中设置它们 。</p> 
  <p>如果未设置变量,pandoc将在文档的元数据中查找对应的值。元数据 可以使用YAML metadata blocks 或<code>--metadata</code>选项进行设置。</p> 
  <p>YAML metadata blocks:就是出现在文档顶部,且使用两个 <code>---</code> 包围起来的部分。</p> 
 </blockquote> 
 <h3>幻灯片的分隔依据</h3> 
 <blockquote> 
  <p>内容整理自: Pandoc - Pandoc User’s Guide</p> 
 </blockquote> 
 <p>默认情况下,<em>幻灯片级别</em>是层次结构中的最高标级别,<strong>后面紧跟内容</strong>,而不是文档中某处的一个标题。在上面的示例中,级别1标题后面始终跟有2级标题,后跟内容,因此2是幻灯片级别。</p> 
 <blockquote> 
  <p>1级标题In the morning后面紧跟2级标题Getting up,而2级标题Getting up后面的内容是显示在幻灯片上的主体内容,因此这里的Slide level为2。这意味着每个2级标题生成一张幻灯片。高于2级的标题(1级标题)生成一张独立的仅包含标题的幻灯片,而低于2级的标题(3级标题)将存在于上一级标题的幻灯片中,不单独生成新的幻灯片.</p> 
  <p>可以使用--slide-level选项覆盖默认的Slide level。</p> 
  <p>在reveal.js模板下,由于幻灯片的滚动方向可以是二维的(键盘→←↑↓),所以1级标题渲染为水平方向的幻灯片,2级标题渲染为竖直方向的幻灯片。</p> 
  <p>为了生成合适的用于演示的HTML文档,需要记住的另一点是:在默认情况下每个二级标题是一张独立的幻灯片。这样在写作的时候,只需注意把每个二级标题下的内容控制在适当的长度。</p> 
 </blockquote> 
 <p>这里幻灯片的布局格式:</p> 
 <pre><code>+---------+     +---------+    +---------+
|         |     |         |    |         |
+---------+     +---------+    +---------+

+---------+     +---------+    +---------+
|         |     |         |    |         |
|  slide1 |     |  slide1 |    |  slide1 |
|         |     |         |    |         |
+---------+     +---------+    +---------+

+---------+     +---------+    +---------+
|         |     |         |    |         |
| slide2  |     | slide2  |    | slide2  |
|         |     |         |    |         |
+---------+     +---------+    +---------+

</code></pre> 
 <p>根据以下规则将文档划分为幻灯片:</p> 
 <ul> 
  <li>水平规则 始终会分割出一个新幻灯片(对应上文的 <code>----------</code>),即可以使用分割线来强行生成新的幻灯片。分隔线的使用场景我想因该是当你的内容在一张幻灯片上装不下时使用。</li> 
  <li>幻灯片级别的 <strong>标题</strong> 始终会分割出一个新幻灯片。</li> 
  <li>.....(看不懂)</li> 
 </ul> 
 <p>文件编码必须是 utf-8,否则当文件中出现中文时会产生如下错误:</p> 
 <pre><code>pandoc: Cannot decode byte '\xe3': Data.Text.Internal.Encoding.decodeUtf8: Invalid UTF-8 stream
</code></pre> 
 <h3>渐进显示的列表</h3> 
 <p>比如有如下列表:</p> 
 <ul> 
  <li>列表项1</li> 
  <li>列表项2</li> 
 </ul> 
 <p>你希望展示时先显示<code>列表项1</code>,之后点击向下箭头后再显示<code>列表项2</code>,则可使用下面的 <code>fenced div</code>语法:</p> 
 <pre><code>::: incremental

- 列表项1i
- 列表项2

:::
</code></pre> 
 <blockquote> 
  <p>这里 <code>:::</code>对表示这是一个 <code>div</code>, 而 <code>incremental</code>表示它所属的 <code>class</code></p> 
  <pre><code class="html"><div class=incremental>
    
</div>
</code></pre> 
 </blockquote> 
 <p>或者在生成幻灯片时加入<code>-i</code>选项,用于控制列表的显示效果(逐条渐入)</p> 
 <pre><code>$ pandoc slides.md -o slides.html -t revealjs -s -i
</code></pre> 
 <h3>插入暂停</h3> 
 <p>使用带空格的三个点 <code>. . .</code>即可插入在两段文字显示之间的人为停顿</p> 
 <pre><code class="markdown">## 暂停

暂停之前

. . .

暂停之后
</code></pre> 
 <blockquote> 
  <p>建议直接复制上面的三个点</p> 
 </blockquote> 
 <h3>幻灯片主题</h3> 
 <p>这里所有的配置 reveal.js configuration options 都可通过变量形式进行设置。比如主题可以使用 <code>theme</code>变量来进行设置:</p> 
 <pre><code>-V theme=moon
</code></pre> 
 <p>我们找到上面 url 中所列的 <code>keyboard</code>来进行测试:</p> 
 <pre><code>pandoc test01.txt -o slides.html -t revealjs -s  -V theme=simple -V keyboard=false
</code></pre> 
 <p>效果是我们在生成的幻灯片中不能使用键盘的方向键来切换幻灯片。</p> 
 <h3>提示板</h3> 
 <p>notes应该是为了给演讲者相应的提示的内容,Notes使用如下格式:</p> 
 <pre><code>::: notes

这是我的笔记.

- 它可以包含 Markdown
- 比如这个列表
- 只有按 s 键,notes才会显示

:::
</code></pre> 
 <p>默认看不到notes,只有按 s 键,notes才会显示。</p> 
 <h3>并排显示</h3> 
 <p>可以添加多个列,只需将对应的 <code>div</code>的<code>class</code>设置为<code>columns</code>并且为 <code>width</code>属性设置值。示例:</p> 
 <pre><code class="markdown">:::::::::::::: {.columns}
::: {.column width="40%"}
contents...
:::
::: {.column width="60%"}
contents...
:::
::::::::::::::
</code></pre> 
 <h3>设置背景</h3> 
 <blockquote> 
  <p><strong>Sorry: 在我的windows中就是提示找不到本地图片,可能路径有问题</strong></p> 
  <p>当使用在线图片是可以显示的,可能会有点慢(在尝试了几次后才加载出来)</p> 
 </blockquote> 
 <p><strong>为每个幻灯片设置同一个背景图片:</strong></p> 
 <p>使用配置选项 <code>parallaxBackgroundImage</code> ,可以 在YAML元数据块中或作为命令行变量 使用该选项。</p> 
 <p>You can also set <code>parallaxBackgroundHorizontal</code> and <code>parallaxBackgroundVertical</code> the same way and must also set <code>parallaxBackgroundSize</code> to have your values take effect.</p> 
 <p><strong>为单独的某个幻灯片设置背景图片:</strong></p> 
 <p>在第一个幻灯片级别的头部添加 <code>{data-background-image="/path/to/image"}</code>。</p> 
 <p>add <code>{data-background-image="/path/to/image"}</code> to the first slide-level header on the slide (which may even be empty).</p> 
 <p>其它的一些 background 设置也可以在单独的某个幻灯片上使用,包括:</p> 
 <p><code>data-background-size</code>, <code>data-background-repeat</code>, <code>data-background-color</code>, <code>data-transition</code>, and <code>data-transition-speed</code>.</p> 
 <p>查看 reveal.js documentation 文档以了解更多细节 ( 一定要看 )。</p> 
 <p>示例:</p> 
 <pre><code class="markdown">---
title: My Slideshow
parallaxBackgroundImage: /path/to/my/background_image.png
---

## Slide One

Slide 1 has background_image.png as its background.

## {data-background-image="/path/to/special_image.jpg"}

Slide 2 has a special image for its background, even though the header has no content.
</code></pre> 
 <blockquote> 
  <p>In reveal.js’s overview mode, the parallaxBackgroundImage will show up only on the first slide. 只会在第一个幻灯片上显示</p> 
 </blockquote> 
 <h3>代码高亮风格</h3> 
 <p>控制代码高亮风格的选项有:</p> 
 <ul> 
  <li>--highlight-style pygments</li> 
  <li>--highlight-style kate</li> 
  <li>--highlight-style monochrome</li> 
  <li>--highlight-style espresso</li> 
  <li>--highlight-style haddock</li> 
  <li>--highlight-style tango</li> 
  <li>--highlight-style zenburn</li> 
 </ul> 
 <blockquote> 
  <p>参考: 桌面应用|Markdown+Pandoc→HTML幻灯片速成</p> 
 </blockquote> 
</article>
                            </div>
                        </div>
                    </div>
                    <!--PC和WAP自适应版-->
                    <div id="SOHUCS" sid="1181229295129907200"></div>
                    <script type="text/javascript" src="/views/front/js/chanyan.js"></script>
                    <!-- 文章页-底部 动态广告位 -->
                    <div class="youdao-fixed-ad" id="detail_ad_bottom"></div>
                </div>
                <div class="col-md-3">
                    <div class="row" id="ad">
                        <!-- 文章页-右侧1 动态广告位 -->
                        <div id="right-1" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad">
                            <div class="youdao-fixed-ad" id="detail_ad_1"> </div>
                        </div>
                        <!-- 文章页-右侧2 动态广告位 -->
                        <div id="right-2" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad">
                            <div class="youdao-fixed-ad" id="detail_ad_2"></div>
                        </div>
                        <!-- 文章页-右侧3 动态广告位 -->
                        <div id="right-3" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad">
                            <div class="youdao-fixed-ad" id="detail_ad_3"></div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </div>
    <div class="container">
        <h4 class="pt20 mb15 mt0 border-top">你可能感兴趣的:(Pandoc中使用Reveal.js制作幻灯片)</h4>
        <div id="paradigm-article-related">
            <div class="recommend-post mb30">
                <ul class="widget-links">
                    <li><a href="/article/1902706582211325952.htm"
                           title="【新能源集成热管理系统的开发与优化】" target="_blank">【新能源集成热管理系统的开发与优化】</a>
                        <span class="text-muted">新能源汽车--三电老K</span>
<a class="tag" taget="_blank" href="/search/%E7%A0%94%E5%8F%91%E6%B5%8B%E8%AF%95/1.htm">研发测试</a><a class="tag" taget="_blank" href="/search/%E6%B1%BD%E8%BD%A6/1.htm">汽车</a><a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0%E6%96%B9%E6%B3%95/1.htm">学习方法</a>
                        <div>新能源集成热管理系统的开发与优化涉及多阶段的试验、标定和策略调整,需结合实验室仿真、环境仓测试及实车道路验证,以应对高低温、极端气候等复杂工况。以下是具体实施方法:一、环境仓试验室测试系统标定与基础验证模型搭建:通过AMESim等仿真工具建立机-电-热耦合模型,涵盖电池、电机、空调等子系统,分析高温工况下各部件能耗占比及整车续航表现。参数标定:在环境仓中模拟极端温度(如38℃高温或-30℃低温),</div>
                    </li>
                    <li><a href="/article/1902705826154475520.htm"
                           title="【C#】Task.Delay与Thread.Sleep" target="_blank">【C#】Task.Delay与Thread.Sleep</a>
                        <span class="text-muted">我不是程序猿儿</span>
<a class="tag" taget="_blank" href="/search/C%23/1.htm">C#</a><a class="tag" taget="_blank" href="/search/c%23/1.htm">c#</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a>
                        <div>Task.Delay和Thread.Sleep都是用来使程序暂停一段时间,但它们有一些关键的区别,特别是在多线程和异步编程的上下文中。1.Thread.Sleep:阻塞当前线程Thread.Sleep是同步操作,它会让当前线程暂停执行,直到指定的时间过去。它会阻塞当前线程,导致线程无法继续执行任何代码,直到休眠时间结束。这意味着如果你在UI线程中使用Thread.Sleep,会导致UI卡顿,用户无</div>
                    </li>
                    <li><a href="/article/1902705698823794688.htm"
                           title="c#:使用串口通讯实现数据的发送和接收" target="_blank">c#:使用串口通讯实现数据的发送和接收</a>
                        <span class="text-muted">妮妮学代码</span>
<a class="tag" taget="_blank" href="/search/c%23/1.htm">c#</a><a class="tag" taget="_blank" href="/search/%E4%B8%B2%E5%8F%A3%E9%80%9A%E8%AE%AF/1.htm">串口通讯</a><a class="tag" taget="_blank" href="/search/c%23/1.htm">c#</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a>
                        <div>串口通讯(SerialCommunication)是一种常见的硬件设备与计算机之间的数据传输方式,广泛应用于工业控制、嵌入式系统、传感器数据采集等领域。本文将详细介绍如何使用C#实现基于串口通讯的数据发送和接收,并结合代码示例解析其实现过程。1.概述串口通讯的核心是System.IO.Ports.SerialPort类,它封装了串口操作的底层细节,提供了简单易用的接口。以下是串口通讯的基本流程:1</div>
                    </li>
                    <li><a href="/article/1902705699775901696.htm"
                           title="c#:使用Modbus RTU协议" target="_blank">c#:使用Modbus RTU协议</a>
                        <span class="text-muted">妮妮学代码</span>
<a class="tag" taget="_blank" href="/search/c%23/1.htm">c#</a><a class="tag" taget="_blank" href="/search/Modbus/1.htm">Modbus</a><a class="tag" taget="_blank" href="/search/RTU/1.htm">RTU</a><a class="tag" taget="_blank" href="/search/c%23/1.htm">c#</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a>
                        <div>Modbus是一种广泛应用于工业自动化领域的通信协议,支持多种传输方式,如RTU、TCP等。其中,ModbusRTU是一种基于串行通信的协议,具有高效、可靠的特点。本文将详细介绍ModbusRTU协议的基本原理,并重点解析功能码0x03(读取保持寄存器)、0x06(写单个寄存器)和0x10(写多个寄存器)的使用和作用。同时,我们将通过C#代码实现这些功能码的读写操作。1.ModbusRTU协议简介</div>
                    </li>
                    <li><a href="/article/1902705697313845248.htm"
                           title="C#:使用UDP协议实现数据的发送和接收" target="_blank">C#:使用UDP协议实现数据的发送和接收</a>
                        <span class="text-muted">妮妮学代码</span>
<a class="tag" taget="_blank" href="/search/c%23/1.htm">c#</a><a class="tag" taget="_blank" href="/search/UDP/1.htm">UDP</a><a class="tag" taget="_blank" href="/search/c%23/1.htm">c#</a><a class="tag" taget="_blank" href="/search/udp/1.htm">udp</a>
                        <div>UDP(UserDatagramProtocol)是一种无连接的、轻量级的传输协议,适用于对实时性要求较高的应用场景,如视频流、在线游戏等。与TCP不同,UDP不保证数据的可靠传输,但其传输效率更高。本文将详细介绍如何使用C#实现基于UDP协议的数据发送和接收,并结合代码示例解析其实现过程。1.概述UDP通讯的核心是UdpClient类,它封装了UDP协议的底层操作,提供了简单易用的接口。以下是U</div>
                    </li>
                    <li><a href="/article/1902705570993991680.htm"
                           title="stm32 栈 HardFault_Handler 硬件中断 解决问题" target="_blank">stm32 栈 HardFault_Handler 硬件中断 解决问题</a>
                        <span class="text-muted">月骑荞面山</span>
<a class="tag" taget="_blank" href="/search/stm32/1.htm">stm32</a><a class="tag" taget="_blank" href="/search/%E5%B5%8C%E5%85%A5%E5%BC%8F%E7%A1%AC%E4%BB%B6/1.htm">嵌入式硬件</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E7%89%87%E6%9C%BA/1.htm">单片机</a>
                        <div>stm32进入硬件中断分析stm32的栈空间,是用于在发生中断时,保存CPU的一些寄存器(不是全部CPU寄存器)和保存函数的局部变量、等(注意这个等,说明是不仅仅包含这些)的空间,这就是入栈。中断函数运行完,CPU将使用栈空间的内容,恢复自己所有的寄存器,以及局部变量,这就是出栈。栈空间大小,由自己设置,如下图,不会的话,就去看其他文章栈空间大小设置好后,编译后,栈将会分配被分配真实的内存地址,怎</div>
                    </li>
                    <li><a href="/article/1902704186076753920.htm"
                           title="JAVA泛型" target="_blank">JAVA泛型</a>
                        <span class="text-muted">TraceChen</span>
<a class="tag" taget="_blank" href="/search/JAVA/1.htm">JAVA</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a>
                        <div>JAVA泛型Java泛型(generic)是在JDK1.5版本引用的一种新的特性,泛型提供编译时安全检查机制,该机制允许程序员在编译时检查非安全的类型。一、泛型本质泛型本质是数据化类型,即先给类型指定一个参数,然后使用时再指定参数具体的值,那么这个类型可以在使用时候决定,这种参数类型可以用在类、接口、方法中,分别被称为泛型类、泛型接口、泛型方法。    Listlist=newArrayListl</div>
                    </li>
                    <li><a href="/article/1902703052423491584.htm"
                           title="服务器使用宝塔上传文件时卡住了的解决办法" target="_blank">服务器使用宝塔上传文件时卡住了的解决办法</a>
                        <span class="text-muted">Frozen-tzy</span>
<a class="tag" taget="_blank" href="/search/%E6%9C%8D%E5%8A%A1%E5%99%A8/1.htm">服务器</a><a class="tag" taget="_blank" href="/search/%E8%BF%90%E7%BB%B4/1.htm">运维</a><a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a>
                        <div>当我用宝塔向服务器上传文件时,它一直显示上传速度是0,卡住不动了。还有一种情况是上传到一半失败了,这时报了一个磁盘空间不足的错。这时我们来看宝塔面板首页的磁盘空间,一般会看到它是红色的,接近100%,这时我们就需要清理掉服务器中不必要的文件(比如日志、缓存等)我们也可以通过命令来查看磁盘的使用情况:通过SSH登录服务器df-h输出示例FilesystemSizeUsedAvailUse%Mount</div>
                    </li>
                    <li><a href="/article/1902702170533326848.htm"
                           title="使用CSS3实现炫酷的3D翻转卡片效果" target="_blank">使用CSS3实现炫酷的3D翻转卡片效果</a>
                        <span class="text-muted">木木黄木木</span>
<a class="tag" taget="_blank" href="/search/css3/1.htm">css3</a><a class="tag" taget="_blank" href="/search/3d/1.htm">3d</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a>
                        <div>使用CSS3实现炫酷的3D翻转卡片效果这里写目录标题使用CSS3实现炫酷的3D翻转卡片效果项目介绍技术要点分析1.3D空间设置2.核心CSS属性3.布局和定位实现难点和解决方案1.3D效果的流畅性2.卡片内容布局3.响应式设计性能优化建议浏览器兼容性总结项目介绍在这个项目中,我们使用纯CSS3技术实现了一个具有3D翻转效果的交互卡片。当用户将鼠标悬停在卡片上时,卡片会沿Y轴优雅地旋转180度,展示</div>
                    </li>
                    <li><a href="/article/1902702169795129344.htm"
                           title="Maven中dependency标签参数" target="_blank">Maven中dependency标签参数</a>
                        <span class="text-muted">lgily-1225</span>
<a class="tag" taget="_blank" href="/search/%E6%97%A5%E5%B8%B8%E7%A7%AF%E7%B4%AF/1.htm">日常积累</a><a class="tag" taget="_blank" href="/search/maven/1.htm">maven</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E5%90%8E%E7%AB%AF/1.htm">后端</a>
                        <div>Maven中dependency标签参数如下:一、type有时候我们引入某一个依赖时,必须指定type,这是因为用于匹配dependency引用和dependencyManagement部分的最小信息集实际上是{groupId,artifactId,type,classifier}。在很多情况下,这些依赖关系将引用没有classifier的jar依赖。这允许我们将标识设置为{groupId,art</div>
                    </li>
                    <li><a href="/article/1902701916761157632.htm"
                           title="深入理解 C# 反射 的使用" target="_blank">深入理解 C# 反射 的使用</a>
                        <span class="text-muted">鲤籽鲲</span>
<a class="tag" taget="_blank" href="/search/C%23/1.htm">C#</a><a class="tag" taget="_blank" href="/search/c%23/1.htm">c#</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a><a class="tag" taget="_blank" href="/search/C%23/1.htm">C#</a><a class="tag" taget="_blank" href="/search/%E7%9F%A5%E8%AF%86%E6%8D%A1%E6%BC%8F/1.htm">知识捡漏</a><a class="tag" taget="_blank" href="/search/C%23/1.htm">C#</a><a class="tag" taget="_blank" href="/search/%E5%8F%8D%E5%B0%84/1.htm">反射</a>
                        <div>总目录前言反射是.NET框架中一个强大的特性,允许程序在运行时检查和操作类型信息。通过反射,开发者可以动态地创建对象、调用方法、访问属性等,为程序提供了极大的灵活性。本文将详细讲解C#反射的使用方法及其应用场景。一、什么是反射?1.定义反射(Reflection)是指程序在运行时能够检查和操作其自身的类型信息。通过反射,可以获取类型的成员(如方法、属性、事件等)并动态地调用它们。在.NET框架中,</div>
                    </li>
                    <li><a href="/article/1902700530103283712.htm"
                           title="鸿蒙NEXT开发之开屏广告实现" target="_blank">鸿蒙NEXT开发之开屏广告实现</a>
                        <span class="text-muted">怀男孩</span>
<a class="tag" taget="_blank" href="/search/harmonyos/1.htm">harmonyos</a><a class="tag" taget="_blank" href="/search/harmonyos/1.htm">harmonyos</a><a class="tag" taget="_blank" href="/search/%E5%8D%8E%E4%B8%BA/1.htm">华为</a>
                        <div>1.广告请求服务的实现首先,你需要创建一个广告请求服务来处理广告的加载和展示。你已经在代码中实现了requestAd函数,接下来需要处理广告加载、显示、点击等事件。可以考虑以下结构:1.1创建广告加载函数import{advertising,identifier}from'@kit.AdsKit';import{hilog}from'@kit.PerformanceAnalysisKit';imp</div>
                    </li>
                    <li><a href="/article/1902700278017224704.htm"
                           title="async和 await 的基本使用" target="_blank">async和 await 的基本使用</a>
                        <span class="text-muted">怀男孩</span>
<a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/javascript/1.htm">javascript</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a>
                        <div>目录1.async/await是什么?2.async/await基本语法3.async函数和await的特点3.1async函数的特点3.2async函数的特点代码演示3.3await的特点4.try/catch捕获错误1.async/await是什么?async/await是一种用于处理异步操作的Promise语法糖。(语法糖:更易读、更简洁或更符合人类思维习惯而设计的一种语法方式)通过使用as</div>
                    </li>
                    <li><a href="/article/1902699899061858304.htm"
                           title="JDK8 Stream 数据流效率分析,Java开发你需要了解的那些事" target="_blank">JDK8 Stream 数据流效率分析,Java开发你需要了解的那些事</a>
                        <span class="text-muted">气质大叔</span>
<a class="tag" taget="_blank" href="/search/%E7%A8%8B%E5%BA%8F%E5%91%98/1.htm">程序员</a><a class="tag" taget="_blank" href="/search/%E5%90%8E%E7%AB%AF/1.htm">后端</a><a class="tag" taget="_blank" href="/search/%E9%9D%A2%E8%AF%95/1.htm">面试</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a>
                        <div>此外还有一系列特化流,如IntStream,LongStream,DoubleStream等),Java8引入的的Stream主要用于取代部分Collection的操作,每个流代表一个值序列,流提供一系列常用的聚集操作,可以便捷的在它上面进行各种运算。集合类库也提供了便捷的方式使我们可以以操作流的方式使用集合、数组以及其它数据结构;作为阅读福利,小编也整理了一些Java学习笔记(包含面试真题+脑图</div>
                    </li>
                    <li><a href="/article/1902699899850387456.htm"
                           title="3.ArkTS语法介绍" target="_blank">3.ArkTS语法介绍</a>
                        <span class="text-muted">北辰星Charih</span>
<a class="tag" taget="_blank" href="/search/HarmonyNext/1.htm">HarmonyNext</a><a class="tag" taget="_blank" href="/search/harmonyos/1.htm">harmonyos</a>
                        <div>一、具体内容ArkTS语法介绍-华为开发者学堂(huawei.com)二、习题整理2.1判断题1.ArkTS中使用const声明常量。正确(True)错误(False)答案:正确(True)2.允许在容器组件内使用if/else条件渲染语句构建不同的子组件。正确(True)错误(False)答案:正确(True)3.@Entry装饰的自定义组件将作为UI页面的入口。在单个UI页面中可以使用多个@E</div>
                    </li>
                    <li><a href="/article/1902699646380208128.htm"
                           title="LeetCode每日一题——30. 串联所有单词的子串" target="_blank">LeetCode每日一题——30. 串联所有单词的子串</a>
                        <span class="text-muted">hyk今天写算法了吗</span>
<a class="tag" taget="_blank" href="/search/%23/1.htm">#</a><a class="tag" taget="_blank" href="/search/%E7%AE%97%E6%B3%95%E5%AE%9E%E4%BE%8B/1.htm">算法实例</a><a class="tag" taget="_blank" href="/search/leetcode/1.htm">leetcode</a><a class="tag" taget="_blank" href="/search/%E7%AE%97%E6%B3%95/1.htm">算法</a><a class="tag" taget="_blank" href="/search/%E8%81%8C%E5%9C%BA%E5%92%8C%E5%8F%91%E5%B1%95/1.htm">职场和发展</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84/1.htm">数据结构</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a>
                        <div>文章目录题目示例思路题解题目给定一个字符串s和一些长度相同的单词words。找出s中恰好可以由words中所有单词串联形成的子串的起始位置。注意子串要与words中的单词完全匹配,中间不能有其他字符,但不需要考虑words中单词串联的顺序。示例示例1:输入:s=“barfoothefoobarman”,words=[“foo”,“bar”]输出:[0,9]解释:从索引0和9开始的子串分别是“bar</div>
                    </li>
                    <li><a href="/article/1902699519171162112.htm"
                           title="React中useEffect和useLayoutEffect的区别" target="_blank">React中useEffect和useLayoutEffect的区别</a>
                        <span class="text-muted">CreatorRay</span>
<a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/%E9%9D%A2%E8%AF%95/1.htm">面试</a><a class="tag" taget="_blank" href="/search/react/1.htm">react</a><a class="tag" taget="_blank" href="/search/react.js/1.htm">react.js</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/%E9%9D%A2%E8%AF%95/1.htm">面试</a>
                        <div>在最近一次面试中被问到,我印象中好像从来没用过useLayoutEffect,就没答上来。但是看名字应该是跟布局相关的,而且跟useEffect会有类似的作用。在React中,useEffect和useLayoutEffect都是用于处理副作用的Hooks,但它们的执行时机和对渲染流程的影响有显著区别。以下是两者的核心差异及使用场景:公众号:Code程序人生,个人网站:https://creato</div>
                    </li>
                    <li><a href="/article/1902699265524822016.htm"
                           title="「Python数据分析」Pandas基础,筛选数据利器:布尔索引" target="_blank">「Python数据分析」Pandas基础,筛选数据利器:布尔索引</a>
                        <span class="text-muted">奕澄羽邦</span>
<a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%88%86%E6%9E%90/1.htm">数据分析</a><a class="tag" taget="_blank" href="/search/pandas/1.htm">pandas</a>
                        <div>我们在处理数据的时候,数据筛选是一个重要的过程。利用布尔索引,我们可以选择需要的数据区间。布尔索引,是利用各种不等式,以及与或非操作,来对数据区间进行选择。在pandas中,与操作,对应的是&这个符号,表示选取两个数据集重合的部分。或操作,对应的是|这个符号,表示选择两个数据集中,只要在一个数据集中出现的部分。非操作,对应的是~这个符号,表示选取一个数据集中,相反的部分。我们下面通过具体的例子,来</div>
                    </li>
                    <li><a href="/article/1902699266984439808.htm"
                           title="STM32 SPI总线驱动CH376T实现U盘/TF卡读写全解析—SPI通信、命令集与文件操作(下) | 零基础入门STM32第七十五步" target="_blank">STM32 SPI总线驱动CH376T实现U盘/TF卡读写全解析—SPI通信、命令集与文件操作(下) | 零基础入门STM32第七十五步</a>
                        <span class="text-muted">触角01010001</span>
<a class="tag" taget="_blank" href="/search/STM32%E5%85%A5%E9%97%A8%E6%95%99%E7%A8%8B%EF%BC%88100%E6%AD%A5%EF%BC%89/1.htm">STM32入门教程(100步)</a><a class="tag" taget="_blank" href="/search/stm32/1.htm">stm32</a><a class="tag" taget="_blank" href="/search/%E9%A9%B1%E5%8A%A8%E5%BC%80%E5%8F%91/1.htm">驱动开发</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E7%89%87%E6%9C%BA/1.htm">单片机</a><a class="tag" taget="_blank" href="/search/%E5%B5%8C%E5%85%A5%E5%BC%8F%E7%A1%AC%E4%BB%B6/1.htm">嵌入式硬件</a><a class="tag" taget="_blank" href="/search/%E7%89%A9%E8%81%94%E7%BD%91/1.htm">物联网</a>
                        <div>主题内容教学目的/扩展视频CH376芯片重点课程电路原理,跳线设置,切换U盘和TF卡。手册分析。驱动程序。调用常用函数。会调用现有函数操作U盘即可。师从洋桃电子,杜洋老师文章目录1.引言2.硬件连接3.驱动程序分析3.1SPI通信机制4.CH376命令集详解4.1常用命令表4.2命令使用示例5.初始化程序解析6.数据读写函数实现6.1写数据到文件6.2从文件读取数据7.应用示例:U盘状态检测8.扩</div>
                    </li>
                    <li><a href="/article/1902698761700831232.htm"
                           title="探索高效加载动画:Loading Animation Widget" target="_blank">探索高效加载动画:Loading Animation Widget</a>
                        <span class="text-muted">盛言蓓Juliana</span>

                        <div>探索高效加载动画:LoadingAnimationWidgetloading_animation_widgetFlutterloadinganimationwidget.项目地址:https://gitcode.com/gh_mirrors/lo/loading_animation_widget在现代应用开发中,加载动画不仅是提升用户体验的关键元素,也是品牌形象展示的重要途径。今天,我们将深入介绍</div>
                    </li>
                    <li><a href="/article/1902698006218600448.htm"
                           title="流式编程 JDK8 Stream的简单使用方法介绍" target="_blank">流式编程 JDK8 Stream的简单使用方法介绍</a>
                        <span class="text-muted">桔仔</span>
<a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/jdk/1.htm">jdk</a><a class="tag" taget="_blank" href="/search/stream/1.htm">stream</a>
                        <div>JDK8Stream文章目录JDK8Stream概念特点代码简洁多核友好示例foreach方式Stream方式流程操作特性常用操作符具体用法一、流的创建1.1使用Collection下的stream()和parallelStream()方法。1.2使用Arrays中的stream()方法,将数组转成流。1.3使用Stream中的静态方法:of()、iterate()、generate()。1.4使</div>
                    </li>
                    <li><a href="/article/1902696872217210880.htm"
                           title="编译时报错“LNK2019 无法解析的外部符号”的可能原因及其解决办法" target="_blank">编译时报错“LNK2019 无法解析的外部符号”的可能原因及其解决办法</a>
                        <span class="text-muted">烟锁池塘柳0</span>
<a class="tag" taget="_blank" href="/search/%E7%A8%8B%E5%BA%8F%E8%AE%BE%E8%AE%A1%E4%B8%8E%E7%BC%96%E7%A8%8B%E8%AF%AD%E8%A8%80/1.htm">程序设计与编程语言</a><a class="tag" taget="_blank" href="/search/c%2B%2B/1.htm">c++</a>
                        <div>在VS2022中运行C++程序的时候,有时候会遇到这样的问题:1>(源文件名称).obj:errorLNK2019:无法解析的外部符号"public:__cdecl(函数名(参数列表))"(??0(函数名与乱码)@@QEAA@XZ),函数main中引用了该符号1>项目路径\x64\Debug\可执行程序名.exe:fatalerrorLNK1120:1个无法解析的外部命令遇到这种问题,可以说是很难</div>
                    </li>
                    <li><a href="/article/1902696743942811648.htm"
                           title="【数学建模】层次分析法(AHP)详解及其应用" target="_blank">【数学建模】层次分析法(AHP)详解及其应用</a>
                        <span class="text-muted">烟锁池塘柳0</span>
<a class="tag" taget="_blank" href="/search/%E6%95%B0%E5%AD%A6%E5%BB%BA%E6%A8%A1/1.htm">数学建模</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E5%AD%A6%E5%BB%BA%E6%A8%A1/1.htm">数学建模</a>
                        <div>层次分析法(AHP)详解及其应用引言在现实生活和工作中,我们经常面临复杂的决策问题,这些问题通常涉及多个评价准则,且各准则之间可能存在相互影响。如何在这些复杂因素中做出合理的决策?层次分析法(AnalyticHierarchyProcess,AHP)作为一种系统、灵活的多准则决策方法,为我们提供了科学的决策工具。文章目录层次分析法(AHP)详解及其应用引言什么是层次分析法?层次分析法的基本原理层次</div>
                    </li>
                    <li><a href="/article/1902696742210564096.htm"
                           title="查看 Linux 系统中安装的 CUDA 版本" target="_blank">查看 Linux 系统中安装的 CUDA 版本</a>
                        <span class="text-muted">烟锁池塘柳0</span>
<a class="tag" taget="_blank" href="/search/Linux/1.htm">Linux</a><a class="tag" taget="_blank" href="/search/CUDA/1.htm">CUDA</a><a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/ubuntu/1.htm">ubuntu</a>
                        <div>查看Linux系统中安装的CUDA版本的常见方法:文章目录1查看/usr/local/cuda目录2使用nvcc命令3检查libcublas版本注意:nvidia-smi1查看/usr/local/cuda目录通常,CUDA被安装在/usr/local/cuda目录下,所以可以使用ls命令来查看这个目录是否存在,以及查看其中的内容。ls/usr/local/cuda如果这个目录存在,通常它会是一个</div>
                    </li>
                    <li><a href="/article/1902695103110115328.htm"
                           title="优化Redis AOF重写配置:解决AOF文件过大的终极指南" target="_blank">优化Redis AOF重写配置:解决AOF文件过大的终极指南</a>
                        <span class="text-muted">冯·诺依曼的</span>
<a class="tag" taget="_blank" href="/search/redis/1.htm">redis</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a><a class="tag" taget="_blank" href="/search/%E7%BC%93%E5%AD%98/1.htm">缓存</a><a class="tag" taget="_blank" href="/search/%E4%BA%91%E8%AE%A1%E7%AE%97/1.htm">云计算</a>
                        <div>核心配置参数解析与优化以下配置参数位于Redis配置文件/etc/redis.conf中,用于控制AOF持久化与重写行为。通过合理调整这些参数,可显著减少AOF文件体积并提升性能。1.appendfsync:AOF文件同步策略默认值:everysec修改建议:appendfsyncno作用:控制AOF日志同步到磁盘的频率。everysec(默认):每秒同步一次,平衡性能与数据安全。no:由操作系统</div>
                    </li>
                    <li><a href="/article/1902695102510329856.htm"
                           title="深入解析:C# 中 `Task.Delay` 与 `Thread.Sleep` 的对比与实战" target="_blank">深入解析:C# 中 `Task.Delay` 与 `Thread.Sleep` 的对比与实战</a>
                        <span class="text-muted">墨夶</span>
<a class="tag" taget="_blank" href="/search/C%23%E5%AD%A6%E4%B9%A0%E8%B5%84%E6%96%991/1.htm">C#学习资料1</a><a class="tag" taget="_blank" href="/search/c%23/1.htm">c#</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a>
                        <div>嘿,小伙伴们!今天我们要一起深入探讨C#中的Task.Delay和Thread.Sleep。想象一下,你正在开发一个需要处理异步操作的应用程序,如何有效地管理线程和延迟执行任务呢?别急,让我们通过这篇文章来详细解析Task.Delay和Thread.Sleep的区别,并涵盖以下内容:基本概念Thread.Sleep的用法Task.Delay的用法对比分析实战示例注意事项与最佳实践常见面试题及答案正</div>
                    </li>
                    <li><a href="/article/1902694975552942080.htm"
                           title="详解Springboot的启动流程" target="_blank">详解Springboot的启动流程</a>
                        <span class="text-muted">凭君语未可</span>
<a class="tag" taget="_blank" href="/search/%E9%9D%A2%E8%AF%95/1.htm">面试</a><a class="tag" taget="_blank" href="/search/spring/1.htm">spring</a><a class="tag" taget="_blank" href="/search/boot/1.htm">boot</a><a class="tag" taget="_blank" href="/search/%E5%90%8E%E7%AB%AF/1.htm">后端</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a>
                        <div>在Redis中实现分布式锁1.主入口与SpringApplication.run()2.准备阶段3.创建应用上下文(ApplicationContext)4.Bean定义加载与上下文刷新5.EmbeddedWebServer的启动(针对Web应用)6.ApplicationRunner和CommandLineRunner执行7.应用启动完成总结1.主入口与SpringApplication.run</div>
                    </li>
                    <li><a href="/article/1902694722653188096.htm"
                           title="【万字总结】前端全方位性能优化指南(四)——虚拟DOM批处理、文档碎片池、重排规避" target="_blank">【万字总结】前端全方位性能优化指南(四)——虚拟DOM批处理、文档碎片池、重排规避</a>
                        <span class="text-muted">庸俗今天不摸鱼</span>
<a class="tag" taget="_blank" href="/search/Web%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E5%90%88%E9%9B%86/1.htm">Web性能优化合集</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96/1.htm">性能优化</a>
                        <div>前言在浏览器宇宙中,DOM操作如同「时空裂缝」——一次不当的节点更新可能引发连锁重排,吞噬整条渲染流水线的性能。本章直面这一核心矛盾,以原子级操作合并、节点记忆重组、排版禁忌破解为三重武器,重构DOM更新的物理法则。通过虚拟DOM的批处理引擎将千次操作坍缩为单次提交,借助文档碎片池实现90%节点的跨时空复用,再以transform替代top等20项反重排铁律,我们将彻底终结「JavaScript线</div>
                    </li>
                    <li><a href="/article/1902694343601352704.htm"
                           title="Java泛型" target="_blank">Java泛型</a>
                        <span class="text-muted">lgily-1225</span>
<a class="tag" taget="_blank" href="/search/%E6%97%A5%E5%B8%B8%E7%A7%AF%E7%B4%AF/1.htm">日常积累</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a><a class="tag" taget="_blank" href="/search/%E5%90%8E%E7%AB%AF/1.htm">后端</a>
                        <div>Java泛型是Java5引入的一项重要特性,旨在增强类型安全、减少代码冗余,并支持更灵活的代码设计。以下是对泛型的详细介绍及使用指南:一、泛型核心概念泛型允许在类、接口、方法中使用类型参数(如),使得代码可以处理多种数据类型,而无需重复编写逻辑。解决的问题类型安全:避免运行时ClassCastException。消除强制类型转换:编译器自动处理类型转换。代码复用:同一逻辑可处理不同类型的数据。二、</div>
                    </li>
                    <li><a href="/article/1902693838934306816.htm"
                           title="【数学建模】TOPSIS法简介及应用" target="_blank">【数学建模】TOPSIS法简介及应用</a>
                        <span class="text-muted">烟锁池塘柳0</span>
<a class="tag" taget="_blank" href="/search/%E6%95%B0%E5%AD%A6%E5%BB%BA%E6%A8%A1/1.htm">数学建模</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E5%AD%A6%E5%BB%BA%E6%A8%A1/1.htm">数学建模</a><a class="tag" taget="_blank" href="/search/%E7%AE%97%E6%B3%95/1.htm">算法</a>
                        <div>文章目录TOPSIS法的基本原理TOPSIS法的基本步骤TOPSIS法的应用总结在多目标决策分析中,我们常常需要在多个选择中找到一个最优解。TOPSIS(TechniqueforOrderPreferencebySimilaritytoIdealSolution)法是一个广泛应用的决策方法,基于理想解与负理想解的距离来评估各个选项的优劣。本文将简要介绍TOPSIS法的基本原理、步骤以及其在实际决策</div>
                    </li>
                                <li><a href="/article/9.htm"
                                       title="apache ftpserver-CentOS config" target="_blank">apache ftpserver-CentOS config</a>
                                    <span class="text-muted">gengzg</span>
<a class="tag" taget="_blank" href="/search/apache/1.htm">apache</a>
                                    <div><server xmlns="http://mina.apache.org/ftpserver/spring/v1"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="
       http://mina.apache.o</div>
                                </li>
                                <li><a href="/article/136.htm"
                                       title="优化MySQL数据库性能的八种方法" target="_blank">优化MySQL数据库性能的八种方法</a>
                                    <span class="text-muted">AILIKES</span>
<a class="tag" taget="_blank" href="/search/sql/1.htm">sql</a><a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a>
                                    <div>1、选取最适用的字段属性   MySQL可以很好的支持大数据量的存取,但是一般说来,数据库中的表越小,在它上面执行的查询也就会越快。因此,在创建表的时候,为了获得更好的 性能,我们可以将表中字段的宽度设得尽可能小。例如,在定义邮政编码这个字段时,如果将其设置为CHAR(255),显然给数据库增加了不必要的空间,甚至使用VARCHAR这种类型也是多余的,因为CHAR(6)就可以很</div>
                                </li>
                                <li><a href="/article/263.htm"
                                       title="JeeSite 企业信息化快速开发平台" target="_blank">JeeSite 企业信息化快速开发平台</a>
                                    <span class="text-muted">Kai_Ge</span>
<a class="tag" taget="_blank" href="/search/JeeSite/1.htm">JeeSite</a>
                                    <div>JeeSite 企业信息化快速开发平台  
平台简介 
JeeSite是基于多个优秀的开源项目,高度整合封装而成的高效,高性能,强安全性的开源Java EE快速开发平台。 
JeeSite本身是以Spring Framework为核心容器,Spring MVC为模型视图控制器,MyBatis为数据访问层, Apache Shiro为权限授权层,Ehcahe对常用数据进行缓存,Activit为工作流</div>
                                </li>
                                <li><a href="/article/390.htm"
                                       title="通过Spring Mail Api发送邮件" target="_blank">通过Spring Mail Api发送邮件</a>
                                    <span class="text-muted">120153216</span>
<a class="tag" taget="_blank" href="/search/%E9%82%AE%E4%BB%B6/1.htm">邮件</a><a class="tag" taget="_blank" href="/search/main/1.htm">main</a>
                                    <div>原文地址:http://www.open-open.com/lib/view/open1346857871615.html 
使用Java Mail API来发送邮件也很容易实现,但是最近公司一个同事封装的邮件API实在让我无法接受,于是便打算改用Spring Mail API来发送邮件,顺便记录下这篇文章。 【Spring Mail API】 
Spring Mail API都在org.spri</div>
                                </li>
                                <li><a href="/article/517.htm"
                                       title="Pysvn 程序员使用指南" target="_blank">Pysvn 程序员使用指南</a>
                                    <span class="text-muted">2002wmj</span>
<a class="tag" taget="_blank" href="/search/SVN/1.htm">SVN</a>
                                    <div>源文件:http://ju.outofmemory.cn/entry/35762 
这是一篇关于pysvn模块的指南. 
完整和详细的API请参考 http://pysvn.tigris.org/docs/pysvn_prog_ref.html. 
pysvn是操作Subversion版本控制的Python接口模块. 这个API接口可以管理一个工作副本, 查询档案库, 和同步两个. 
该</div>
                                </li>
                                <li><a href="/article/644.htm"
                                       title="在SQLSERVER中查找被阻塞和正在被阻塞的SQL" target="_blank">在SQLSERVER中查找被阻塞和正在被阻塞的SQL</a>
                                    <span class="text-muted">357029540</span>
<a class="tag" taget="_blank" href="/search/SQL+Server/1.htm">SQL Server</a>
                                    <div>SELECT  R.session_id AS BlockedSessionID ,  
        S.session_id AS BlockingSessionID ,  
        Q1.text AS Block</div>
                                </li>
                                <li><a href="/article/771.htm"
                                       title="Intent 常用的用法备忘" target="_blank">Intent 常用的用法备忘</a>
                                    <span class="text-muted">7454103</span>
<a class="tag" taget="_blank" href="/search/.net/1.htm">.net</a><a class="tag" taget="_blank" href="/search/android/1.htm">android</a><a class="tag" taget="_blank" href="/search/Google/1.htm">Google</a><a class="tag" taget="_blank" href="/search/Blog/1.htm">Blog</a><a class="tag" taget="_blank" href="/search/F%23/1.htm">F#</a>
                                    <div>Intent 
    应该算是Android中特有的东西。你可以在Intent中指定程序 要执行的动作(比如:view,edit,dial),以及程序执行到该动作时所需要的资料 。都指定好后,只要调用startActivity(),Android系统 会自动寻找最符合你指定要求的应用 程序,并执行该程序。 
 
下面列出几种Intent 的用法 
显示网页: 
 
</div>
                                </li>
                                <li><a href="/article/898.htm"
                                       title="Spring定时器时间配置" target="_blank">Spring定时器时间配置</a>
                                    <span class="text-muted">adminjun</span>
<a class="tag" taget="_blank" href="/search/spring/1.htm">spring</a><a class="tag" taget="_blank" href="/search/%E6%97%B6%E9%97%B4%E9%85%8D%E7%BD%AE/1.htm">时间配置</a><a class="tag" taget="_blank" href="/search/%E5%AE%9A%E6%97%B6%E5%99%A8/1.htm">定时器</a>
                                    <div>红圈中的值由6个数字组成,中间用空格分隔。第一个数字表示定时任务执行时间的秒,第二个数字表示分钟,第三个数字表示小时,后面三个数字表示日,月,年,< xmlnamespace prefix ="o" ns ="urn:schemas-microsoft-com:office:office" />  
测试的时候,由于是每天定时执行,所以后面三个数</div>
                                </li>
                                <li><a href="/article/1025.htm"
                                       title="POJ 2421 Constructing Roads 最小生成树" target="_blank">POJ 2421 Constructing Roads 最小生成树</a>
                                    <span class="text-muted">aijuans</span>
<a class="tag" taget="_blank" href="/search/%E6%9C%80%E5%B0%8F%E7%94%9F%E6%88%90%E6%A0%91/1.htm">最小生成树</a>
                                    <div>来源:http://poj.org/problem?id=2421 
题意:还是给你n个点,然后求最小生成树。特殊之处在于有一些点之间已经连上了边。 
思路:对于已经有边的点,特殊标记一下,加边的时候把这些边的权值赋值为0即可。这样就可以既保证这些边一定存在,又保证了所求的结果正确。 
代码: 
 
#include <iostream>
#include <cstdio></div>
                                </li>
                                <li><a href="/article/1152.htm"
                                       title="重构笔记——提取方法(Extract Method)" target="_blank">重构笔记——提取方法(Extract Method)</a>
                                    <span class="text-muted">ayaoxinchao</span>
<a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E9%87%8D%E6%9E%84/1.htm">重构</a><a class="tag" taget="_blank" href="/search/%E6%8F%90%E7%82%BC%E5%87%BD%E6%95%B0/1.htm">提炼函数</a><a class="tag" taget="_blank" href="/search/%E5%B1%80%E9%83%A8%E5%8F%98%E9%87%8F/1.htm">局部变量</a><a class="tag" taget="_blank" href="/search/%E6%8F%90%E5%8F%96%E6%96%B9%E6%B3%95/1.htm">提取方法</a>
                                    <div>提取方法(Extract Method)是最常用的重构手法之一。当看到一个方法过长或者方法很难让人理解其意图的时候,这时候就可以用提取方法这种重构手法。 
  
下面是我学习这个重构手法的笔记: 
  
提取方法看起来好像仅仅是将被提取方法中的一段代码,放到目标方法中。其实,当方法足够复杂的时候,提取方法也会变得复杂。当然,如果提取方法这种重构手法无法进行时,就可能需要选择其他</div>
                                </li>
                                <li><a href="/article/1279.htm"
                                       title="为UILabel添加点击事件" target="_blank">为UILabel添加点击事件</a>
                                    <span class="text-muted">bewithme</span>
<a class="tag" taget="_blank" href="/search/UILabel/1.htm">UILabel</a>
                                    <div>    默认情况下UILabel是不支持点击事件的,网上查了查居然没有一个是完整的答案,现在我提供一个完整的代码。 
  
  UILabel *l = [[UILabel alloc] initWithFrame:CGRectMake(60, 0, listV.frame.size.width - 60, listV.frame.size.height)]</div>
                                </li>
                                <li><a href="/article/1406.htm"
                                       title="NoSQL数据库之Redis数据库管理(PHP-REDIS实例)" target="_blank">NoSQL数据库之Redis数据库管理(PHP-REDIS实例)</a>
                                    <span class="text-muted">bijian1013</span>
<a class="tag" taget="_blank" href="/search/redis/1.htm">redis</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a><a class="tag" taget="_blank" href="/search/NoSQL/1.htm">NoSQL</a>
                                    <div>一.redis.php 
<?php
      //实例化
      $redis = new Redis();
      //连接服务器
      $redis->connect("localhost");
      //授权
      $redis->auth("lamplijie");
      //相关操</div>
                                </li>
                                <li><a href="/article/1533.htm"
                                       title="SecureCRT使用备注" target="_blank">SecureCRT使用备注</a>
                                    <span class="text-muted">bingyingao</span>
<a class="tag" taget="_blank" href="/search/secureCRT/1.htm">secureCRT</a><a class="tag" taget="_blank" href="/search/%E6%AF%8F%E9%A1%B5/1.htm">每页</a><a class="tag" taget="_blank" href="/search/%E8%A1%8C%E6%95%B0/1.htm">行数</a>
                                    <div>SecureCRT日志和卷屏行数设置 
 
一、使用securecrt时,设置自动日志记录功能。 
 
1、在C:\Program Files\SecureCRT\下新建一个文件夹(也就是你的CRT可执行文件的路径),命名为Logs; 
 
2、点击Options -> Global Options -> Default Session -> Edite Default Sett</div>
                                </li>
                                <li><a href="/article/1660.htm"
                                       title="【Scala九】Scala核心三:泛型" target="_blank">【Scala九】Scala核心三:泛型</a>
                                    <span class="text-muted">bit1129</span>
<a class="tag" taget="_blank" href="/search/scala/1.htm">scala</a>
                                    <div>泛型类 
package spark.examples.scala.generics

class GenericClass[K, V](val k: K, val v: V) {
  def print() {
    println(k + "," + v)
  }
}

object GenericClass {
  def main(args: Arr</div>
                                </li>
                                <li><a href="/article/1787.htm"
                                       title="素数与音乐" target="_blank">素数与音乐</a>
                                    <span class="text-muted">bookjovi</span>
<a class="tag" taget="_blank" href="/search/%E7%B4%A0%E6%95%B0/1.htm">素数</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E5%AD%A6/1.htm">数学</a><a class="tag" taget="_blank" href="/search/haskell/1.htm">haskell</a>
                                    <div>    由于一直在看haskell,不可避免的接触到了很多数学知识,其中数论最多,如素数,斐波那契数列等,很多在学生时代无法理解的数学现在似乎也能领悟到那么一点。 
    闲暇之余,从图书馆找了<<The music of primes>>和<<世界数学通史>>读了几遍。其中素数的音乐这本书与软件界熟知的&l</div>
                                </li>
                                <li><a href="/article/1914.htm"
                                       title="Java-Collections Framework学习与总结-IdentityHashMap" target="_blank">Java-Collections Framework学习与总结-IdentityHashMap</a>
                                    <span class="text-muted">BrokenDreams</span>
<a class="tag" taget="_blank" href="/search/Collections/1.htm">Collections</a>
                                    <div>        这篇总结一下java.util.IdentityHashMap。从类名上可以猜到,这个类本质应该还是一个散列表,只是前面有Identity修饰,是一种特殊的HashMap。 
        简单的说,IdentityHashMap和HashM</div>
                                </li>
                                <li><a href="/article/2041.htm"
                                       title="读《研磨设计模式》-代码笔记-享元模式-Flyweight" target="_blank">读《研磨设计模式》-代码笔记-享元模式-Flyweight</a>
                                    <span class="text-muted">bylijinnan</span>
<a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E8%AE%BE%E8%AE%A1%E6%A8%A1%E5%BC%8F/1.htm">设计模式</a>
                                    <div>声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/ 
 
 
 



import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java</div>
                                </li>
                                <li><a href="/article/2168.htm"
                                       title="PS人像润饰&调色教程集锦" target="_blank">PS人像润饰&调色教程集锦</a>
                                    <span class="text-muted">cherishLC</span>
<a class="tag" taget="_blank" href="/search/PS/1.htm">PS</a>
                                    <div>  1、仿制图章沿轮廓润饰——柔化图像,凸显轮廓 
 
http://www.howzhi.com/course/retouching/ 
  新建一个透明图层,使用仿制图章不断Alt+鼠标左键选点,设置透明度为21%,大小为修饰区域的1/3左右(比如胳膊宽度的1/3),再沿纹理方向(比如胳膊方向)进行修饰。 
  所有修饰完成后,对该润饰图层添加噪声,噪声大小应该和</div>
                                </li>
                                <li><a href="/article/2295.htm"
                                       title="更新多个字段的UPDATE语句" target="_blank">更新多个字段的UPDATE语句</a>
                                    <span class="text-muted">crabdave</span>
<a class="tag" taget="_blank" href="/search/update/1.htm">update</a>
                                    <div>更新多个字段的UPDATE语句 
  
                 
                update tableA a
                   set (a.v1, a.v2, a.v3, a.v4) =   --使用括号确定更新的字段范围
          </div>
                                </li>
                                <li><a href="/article/2422.htm"
                                       title="hive实例讲解实现in和not in子句" target="_blank">hive实例讲解实现in和not in子句</a>
                                    <span class="text-muted">daizj</span>
<a class="tag" taget="_blank" href="/search/hive/1.htm">hive</a><a class="tag" taget="_blank" href="/search/not+in/1.htm">not in</a><a class="tag" taget="_blank" href="/search/in/1.htm">in</a>
                                    <div>本文转自:http://www.cnblogs.com/ggjucheng/archive/2013/01/03/2842855.html 
 
 
当前hive不支持 in或not in 中包含查询子句的语法,所以只能通过left join实现。 
 
假设有一个登陆表login(当天登陆记录,只有一个uid),和一个用户注册表regusers(当天注册用户,字段只有一个uid),这两个表都包含</div>
                                </li>
                                <li><a href="/article/2549.htm"
                                       title="一道24点的10+种非人类解法(2,3,10,10)" target="_blank">一道24点的10+种非人类解法(2,3,10,10)</a>
                                    <span class="text-muted">dsjt</span>
<a class="tag" taget="_blank" href="/search/%E7%AE%97%E6%B3%95/1.htm">算法</a>
                                    <div>这是人类算24点的方法?!!! 
 
事件缘由:今天晚上突然看到一条24点状态,当时惊为天人,这NM叫人啊?以下是那条状态 
 
朱明西 : 24点,算2 3 10 10,我LX炮狗等面对四张牌痛不欲生,结果跑跑同学扫了一眼说,算出来了,2的10次方减10的3次方。。我草这是人类的算24点啊。。 
 
然后么。。。我就在深夜很得瑟的问室友求室友算 
 
刚出完题,文哥的暴走之旅开始了 
 
5秒后</div>
                                </li>
                                <li><a href="/article/2676.htm"
                                       title="关于YII的菜单插件 CMenu和面包末breadcrumbs路径管理插件的一些使用问题" target="_blank">关于YII的菜单插件 CMenu和面包末breadcrumbs路径管理插件的一些使用问题</a>
                                    <span class="text-muted">dcj3sjt126com</span>
<a class="tag" taget="_blank" href="/search/yii/1.htm">yii</a><a class="tag" taget="_blank" href="/search/framework/1.htm">framework</a>
                                    <div>在使用 YIi的路径管理工具时,发现了一个问题。                    <?php         </div>
                                </li>
                                <li><a href="/article/2803.htm"
                                       title="对象与关系之间的矛盾:“阻抗失配”效应[转]" target="_blank">对象与关系之间的矛盾:“阻抗失配”效应[转]</a>
                                    <span class="text-muted">come_for_dream</span>
<a class="tag" taget="_blank" href="/search/%E5%AF%B9%E8%B1%A1/1.htm">对象</a>
                                    <div>概述 
  
“阻抗失配”这一词组通常用来描述面向对象应用向传统的关系数据库(RDBMS)存放数据时所遇到的数据表述不一致问题。C++程序员已经被这个问题困扰了好多年,而现在的Java程序员和其它面向对象开发人员也对这个问题深感头痛。 
  
“阻抗失配”产生的原因是因为对象模型与关系模型之间缺乏固有的亲合力。“阻抗失配”所带来的问题包括:类的层次关系必须绑定为关系模式(将对象</div>
                                </li>
                                <li><a href="/article/2930.htm"
                                       title="学习编程那点事" target="_blank">学习编程那点事</a>
                                    <span class="text-muted">gcq511120594</span>
<a class="tag" taget="_blank" href="/search/%E7%BC%96%E7%A8%8B/1.htm">编程</a><a class="tag" taget="_blank" href="/search/%E4%BA%92%E8%81%94%E7%BD%91/1.htm">互联网</a>
                                    <div>一年前的夏天,我还在纠结要不要改行,要不要去学php?能学到真本事吗?改行能成功吗?太多的问题,我终于不顾一切,下定决心,辞去了工作,来到传说中的帝都。老师给的乘车方式还算有效,很顺利的就到了学校,赶巧了,正好学校搬到了新校区。先安顿了下来,过了个轻松的周末,第一次到帝都,逛逛吧! 
接下来的周一,是我噩梦的开始,学习内容对我这个零基础的人来说,除了勉强完成老师布置的作业外,我已经没有时间和精力去</div>
                                </li>
                                <li><a href="/article/3057.htm"
                                       title="Reverse Linked List II" target="_blank">Reverse Linked List II</a>
                                    <span class="text-muted">hcx2013</span>
<a class="tag" taget="_blank" href="/search/list/1.htm">list</a>
                                    <div>Reverse a linked list from position m to n. Do it in-place and in one-pass. 
For example:Given 1->2->3->4->5->NULL, m = 2 and n = 4, 
return </div>
                                </li>
                                <li><a href="/article/3184.htm"
                                       title="Spring4.1新特性——页面自动化测试框架Spring MVC Test HtmlUnit简介" target="_blank">Spring4.1新特性——页面自动化测试框架Spring MVC Test HtmlUnit简介</a>
                                    <span class="text-muted">jinnianshilongnian</span>
<a class="tag" taget="_blank" href="/search/spring+4.1/1.htm">spring 4.1</a>
                                    <div>目录 
Spring4.1新特性——综述 
Spring4.1新特性——Spring核心部分及其他 
Spring4.1新特性——Spring缓存框架增强 
Spring4.1新特性——异步调用和事件机制的异常处理 
Spring4.1新特性——数据库集成测试脚本初始化 
Spring4.1新特性——Spring MVC增强 
Spring4.1新特性——页面自动化测试框架Spring MVC T</div>
                                </li>
                                <li><a href="/article/3311.htm"
                                       title="Hadoop集群工具distcp" target="_blank">Hadoop集群工具distcp</a>
                                    <span class="text-muted">liyonghui160com</span>

                                    <div>  
  
1. 环境描述 
两个集群:rock 和 stone 
rock无kerberos权限认证,stone有要求认证。 
1. 从rock复制到stone,采用hdfs 
Hadoop distcp -i hdfs://rock-nn:8020/user/cxz/input hdfs://stone-nn:8020/user/cxz/运行在rock端,即源端问题:报版本</div>
                                </li>
                                <li><a href="/article/3438.htm"
                                       title="一个备份MySQL数据库的简单Shell脚本" target="_blank">一个备份MySQL数据库的简单Shell脚本</a>
                                    <span class="text-muted">pda158</span>
<a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/%E8%84%9A%E6%9C%AC/1.htm">脚本</a>
                                    <div>  主脚本(用于备份mysql数据库):     该Shell脚本可以自动备份 
数据库。只要复制粘贴本脚本到文本编辑器中,输入数据库用户名、密码以及数据库名即可。我备份数据库使用的是mysqlump 命令。后面会对每行脚本命令进行说明。      
1. 分别建立目录“backup”和“oldbackup”     #mkdir /backup     #mkdir /oldbackup    </div>
                                </li>
                                <li><a href="/article/3565.htm"
                                       title="300个涵盖IT各方面的免费资源(中)——设计与编码篇" target="_blank">300个涵盖IT各方面的免费资源(中)——设计与编码篇</a>
                                    <span class="text-muted">shoothao</span>
<a class="tag" taget="_blank" href="/search/IT%E8%B5%84%E6%BA%90/1.htm">IT资源</a><a class="tag" taget="_blank" href="/search/%E5%9B%BE%E6%A0%87%E5%BA%93/1.htm">图标库</a><a class="tag" taget="_blank" href="/search/%E5%9B%BE%E7%89%87%E5%BA%93/1.htm">图片库</a><a class="tag" taget="_blank" href="/search/%E8%89%B2%E5%BD%A9%E6%9D%BF/1.htm">色彩板</a><a class="tag" taget="_blank" href="/search/%E5%AD%97%E4%BD%93/1.htm">字体</a>
                                    <div> 
 A. 免费的设计资源 
 
 
  Freebbble:来自于Dribbble的免费的高质量作品。 
  Dribbble:Dribbble上“免费”的搜索结果——这是巨大的宝藏。 
  Graphic Burger:每个像素点都做得很细的绝佳的设计资源。 
  Pixel Buddha:免费和优质资源的专业社区。 
  Premium Pixels:为那些有创意的人提供免费的素材。 
  </div>
                                </li>
                                <li><a href="/article/3692.htm"
                                       title="thrift总结 - 跨语言服务开发" target="_blank">thrift总结 - 跨语言服务开发</a>
                                    <span class="text-muted">uule</span>
<a class="tag" taget="_blank" href="/search/thrift/1.htm">thrift</a>
                                    <div>官网 
官网JAVA例子 
thrift入门介绍 
IBM-Apache Thrift - 可伸缩的跨语言服务开发框架 
Thrift入门及Java实例演示 
thrift的使用介绍 
  
RPC  
  
POM: 
<dependency>
  <groupId>org.apache.thrift</groupId>
  </div>
                                </li>
                </ul>
            </div>
        </div>
    </div>

<div>
    <div class="container">
        <div class="indexes">
            <strong>按字母分类:</strong>
            <a href="/tags/A/1.htm" target="_blank">A</a><a href="/tags/B/1.htm" target="_blank">B</a><a href="/tags/C/1.htm" target="_blank">C</a><a
                href="/tags/D/1.htm" target="_blank">D</a><a href="/tags/E/1.htm" target="_blank">E</a><a href="/tags/F/1.htm" target="_blank">F</a><a
                href="/tags/G/1.htm" target="_blank">G</a><a href="/tags/H/1.htm" target="_blank">H</a><a href="/tags/I/1.htm" target="_blank">I</a><a
                href="/tags/J/1.htm" target="_blank">J</a><a href="/tags/K/1.htm" target="_blank">K</a><a href="/tags/L/1.htm" target="_blank">L</a><a
                href="/tags/M/1.htm" target="_blank">M</a><a href="/tags/N/1.htm" target="_blank">N</a><a href="/tags/O/1.htm" target="_blank">O</a><a
                href="/tags/P/1.htm" target="_blank">P</a><a href="/tags/Q/1.htm" target="_blank">Q</a><a href="/tags/R/1.htm" target="_blank">R</a><a
                href="/tags/S/1.htm" target="_blank">S</a><a href="/tags/T/1.htm" target="_blank">T</a><a href="/tags/U/1.htm" target="_blank">U</a><a
                href="/tags/V/1.htm" target="_blank">V</a><a href="/tags/W/1.htm" target="_blank">W</a><a href="/tags/X/1.htm" target="_blank">X</a><a
                href="/tags/Y/1.htm" target="_blank">Y</a><a href="/tags/Z/1.htm" target="_blank">Z</a><a href="/tags/0/1.htm" target="_blank">其他</a>
        </div>
    </div>
</div>
<footer id="footer" class="mb30 mt30">
    <div class="container">
        <div class="footBglm">
            <a target="_blank" href="/">首页</a> -
            <a target="_blank" href="/custom/about.htm">关于我们</a> -
            <a target="_blank" href="/search/Java/1.htm">站内搜索</a> -
            <a target="_blank" href="/sitemap.txt">Sitemap</a> -
            <a target="_blank" href="/custom/delete.htm">侵权投诉</a>
        </div>
        <div class="copyright">版权所有 IT知识库 CopyRight © 2000-2050 E-COM-NET.COM , All Rights Reserved.
<!--            <a href="https://beian.miit.gov.cn/" rel="nofollow" target="_blank">京ICP备09083238号</a><br>-->
        </div>
    </div>
</footer>
<!-- 代码高亮 -->
<script type="text/javascript" src="/static/syntaxhighlighter/scripts/shCore.js"></script>
<script type="text/javascript" src="/static/syntaxhighlighter/scripts/shLegacy.js"></script>
<script type="text/javascript" src="/static/syntaxhighlighter/scripts/shAutoloader.js"></script>
<link type="text/css" rel="stylesheet" href="/static/syntaxhighlighter/styles/shCoreDefault.css"/>
<script type="text/javascript" src="/static/syntaxhighlighter/src/my_start_1.js"></script>





</body>

</html>