ButterFly导航栏居中
前言
之前样式的导航栏实际上倒也还好,只是在查找 ButterFly 美化时恰巧看到了这个,所以就做一下并且记录下来,原文请参考 butterfly博客导航栏居中
搜索按钮修改
按照如下代码修改文件 themes\butterfly\layout\includes\header\nav.pug
1234567891011121314151617181920nav#nav span#blog-info a(href=url_for('/') title=config.title) if theme.nav.logo img.site-icon(src=url_for(theme.nav.logo)) if theme.nav.display_title span.site-name=config.title #menus !=partial('includes/header/menu_item', {}, {cache: true}) ...
ButterFly主题美化
我这里只总结了自己用到的,可以看原教程:hexo主题butterfly配置
主题安装
在项目的根目录 Blog 右键打开终端,输入如下指令安装
1git clone -b master https://github.com/jerryc127/hexo-theme-butterfly.git themes/butterfly
安装 pug 和 stylus 渲染器
1npm install hexo-renderer-pug hexo-renderer-stylus --save
修改占点配置文件,开启主题
1theme: butterfly
为了減少升级主题带来的不便,可以把主题文件夹中的 _config.yml 重命名为 _config.butterfly.yml,复制到根目录下与站点配置文件同级。
Hexo 会自动合并主题中的 _config.yml 和 _config.butterfly.yml ,如果存在同名配置,会使用 _config.butterfly.yml 的配置,其优先度较高。所以像和博客网址相关联的固定资料可以设置在 _config.yml 中,比如博客的标题、作 ...
NexT主题美化
主题安装
当前用得最多的是next主题,下载地址:theme-next/hexo-theme-next
可以直接在博客根目录中打开终端,输入代码将主题下载到目录 Blog/themes 中
1git clone https://github.com/theme-next/hexo-theme-next themes/next
主题配置
打开根目录下的 _config.yml 文件(站点配置文件),查找并且修改
123456789101112title: LuosBlogsubtitle: ''description: 或许从未开始,或许已经结束,但是我该走了keywords:author: 落language: zh-CNtimezone: Asia/Shanghai# Extensions## Plugins: https://hexo.io/plugins/## Themes: https://hexo.io/themes/theme: next
将主题修改为 next ,主题的语言需要查看 themes/next/language 文件夹中的简体中文是 zh- ...
个人博客创建
绑定github
SSH与github
SSH(安全外壳协议,Secure Shell 的缩写)是建立在应用层基础上的安全协议。SSH 是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议,利用 SSH 协议可以有效防止远程管理过程中的信息泄露问题。简单来说,SSH就是保障你的账户安全,将你的数据加密压缩,不仅防止其他人截获你的数据,还能加快传输速度。
一般来说,安装 git bash 之后实际上是自带 SSH 的,所以可以检验一下,在终端输入指令 ssh 会显示出 usage 的内容,那就是装好了,有问题的话,可以自行百度一下。
没问题了就可以输入指令 ssh-keygen -t rsa ,使用 RSA 算法生成密钥,然后,如下
其中 红色圈里面是输入保存的地址,蓝色圈里输入的是 passphrase,可以不输入,直接回车就行。最终去你保存的地址找到它
接下来我们要做的事情就是把公钥 id.pub 的内容添加到 GitHub。复制公钥 id.pub 文件里的内容,你可以通过目录找到 id.pub 文件的位置,打开复制里面的内容。(文件名是与上述操作中文件名称有关,我的设置 ...
算法
单调栈
用于寻找一个数组内最大或者最小的元素,单调的意思就是栈内的数据排列是单调递增或者递减的
例如,如果是一个单调递增的栈,遇到比top元素更小的元素的话,就需要把top之前比该元素小的元素全部弹出,之后再将该元素放入,继续维持单调栈
1234567891011121314151617181920212223// leetcode 42int trap(vector<int>& height){ stack<int> stack; int n = height.size(); int res = 0; for (int i = 0; i < n; i++) { // 将栈顶中小的元素推出栈,并且计算这个范围内的数据 while (!stack.empty() && stack.top() < height[i]) { int top = stack.top(); stack.pop(); if (!stack.empty()) // 如果已经空了就中断不再进行 ...
数据结构
github仓库
链表
单向链表
单向链表每次查找只能从前向后查找,单向的,只会有一个指针并且指向下一个节点。所以每个节点只能找到自己后面的节点,但是无法找到之前的链表。
对于循环链表,最末端的节点会指向头节点,形成首尾相接的循环。
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631 ...
C++内存管理
四种内存分配和释放的方式
分配
释放
类型
是否可重载
malloc
free
C-function
否
new
delete
C+±expressions
否
::operator new()
::operator delete()
C+±function
可
allocator::allocate()
allocator::deallocate()
C+±STL
可自由设计并且搭配任何容器
memory primitives
malloc
free
不可重载
new
delete
不可重载
::operator new()
::operator delete()
可重载
allocator::allocate()
allocator::deallocate()
可以自由设计并搭配任何容器
new expression
new 有两个作用,申请内存→构造函数,申请内存使用 operator new 实际上使用的还是 malloc 函数来申请内存
12345678910111213141516Complex *pc = new ...
C++程序的生前死后
startup
默认的startup函数是由 linker(连接器) 自己选择的
1. 内存初始化
内存块:
从哪里来
大小多少
回收到哪
SBH(Small Block Heap):应付CRT本身以及main进去之后的所有内存(size=1024=1k)。
如果客户要的区块大小要小于sbh_threshold(size=1016,加上图中的上下的00000131(各占4个字节),1016+8=1024,即1K),将从sbh内部去申请内存。反之,使用HeapAlloc(win提供的API函数),让操作系统提供服务。
因此,内存小于等于1K的,VC6认为它足够小,它将使用SBH去服务它。反之,若大于1K,将有操作系统那些"池塘"(HeapAlloc等函数)来提供。(内存块从哪里来)
HeapAlloc:HeapAlloc是Windows提供的API,在进程初始化的时候,系统会在进程的地址空间中创建1M大小的堆,称为默认堆(Default Heap),该大小为默认值,可以通过/HEAP连接器开关进行修改。用户也可以通过HeapCreate创建额外的堆,堆的使用可以 ...
C++11STL
STL 六大部件
容器 Container
分配器 Allocators 用于为算法分配地址
算法 Algorithms
迭代器 Iterators 容器中就会有迭代器,用于遍历元素,就是可以表示容器中的所有种类的元素
适配器 Adapters 就像是一个泛化的指针, 对迭代器,仿函数,容器进行适配
仿函式 Functors 就是一种函数
数据在容器里,操作数据的函数在另外的类里
时间复杂度(Big-oh)
O(1),O(c)O(1),O(c)O(1),O(c) : 常数时间
O(n)O(n)O(n) :线性时间
O(lognx)O(\log_n x)O(lognx) :次线性时间
O(n2)O(n^2)O(n2) :平方时间
O(n3)O(n^3)O(n3) :立方时间
O(2n)O(2^n)O(2n) :指数时间
O(nlog2n)O(n\log_2n)O(nlog2n) :线性与二次方成长之间的模式
容器
Sequence Container(序列式)
Arrary (数组) 固定大小 12
Vector (向量) 末尾扩充 12
heap 以算法形式呈 ...
C++11新标准
variadic template
就是参数个数随意的模板,定义任意个参数的模板,可以是任意类型
而且可以依据参数重载,关键字 typename… 也可以实现递归,下面的这两种给方式可以并存
相较来看,第一个定义比较特化,第二个比较泛化,所以就会,如果传入参数是 1 + x 那么就调用第一个,否则调用第二个
12345template <typename... types>void func(size_t seed, types& ...args){return func(args...);}template <typename... types>void func(types& ...args){}
Space in Template Expressionn**ullptr & std::nullptr_t
左边是一个 object,就是0的空的指针,允许使用 null 代替0
auto
auto 表示不知道是什么类型的变量,可以把任意变量赋予 auto 变量
编译过程中,编译器会自动识别类型, ...