自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+

Potato_10的博客

跬步至千里

  • 博客(23)
  • 收藏
  • 关注

原创 并查集算法与应用

相关概念:并查集的最重要两个操作:1、合并操作merge(x, y)。即合并两个原本不相交的集合,此所谓 “并”。2、查找操作find(x)。即检索某一个元素属于哪个集合,此所谓 “查”。并查集的朴素实现只需要一个数组就能表示集合,我们用fset[i]表示元素i所在的集合编号。1、初始化每个元素一个集合:fset[i] = i2、查找x属于属于哪个集合,直接通过下标索引3、合并x、y的操作,需要判断x、y是否相等朴素算法实现中,合并操作的时间复杂度太高。如果有n次合并操作,那么总的时间复

2021-08-13 14:18:00 268

原创 最小生成树算法

相关概念:  连通图:在无向图中,任意两个顶点都有路径相连,则称为连通图。  连通网:在连通图中,若图的边具有一定的意义,每一条边都对应着一个数,称为权;权代表着连接连个顶点的代价,称这种连通图叫做连通网。  生成树:一个连通图的生成树是指一个连通子图,它含有图中全部n个顶点,但只有足以构成一棵树的n-1条边。一颗有n个顶点的生成树有且仅有n-1条边,如果生成树中再添加一条边,则必定成环。  最小生成树:在连通网的所有生成树中,所有边的代价和最小的生成树,称为最小生成树。实际问题描述:  有一张

2021-08-12 16:37:58 643

原创 HTTP如何实现有状态协议

  HTTP是一种无状态协议,即服务器不保留与客户交易时的任何状态。也就是说,上一次的请求对这次的请求没有任何影响,服务端也不会对客户端上一次的请求进行任何记录处理。  带来的问题:用户登录后,切换到其他界面,进行操作,服务器端是无法判断是哪个用户登录的。 每次进行页面跳转的时候,得重新登录。  两种用于保持HTTP状态的技术就应运而生了,一个是 Cookie,而另一个则是 Session。一、Cookie的概念及实现  Cookie 是客户端的存储空间,由浏览器来维持。  具体来说 cookie

2021-08-09 22:31:18 670

原创 静态链接与动态链接、静态库与动态库、硬链接与软链接

一、C++从代码到可执行程序经历了什么?(1)预编译:主要处理源代码文件中的以“#”开头的预编译指令。(预编译后形成 .i 文件)处理规则见下:  删除所有的#define,展开所有的宏定义。  处理所有的条件预编译指令,如“#if”、“#endif”、“#ifdef”、“#elif”和“#else”。  处理“#include”预编译指令,将文件内容替换到它的位置,这个过程是递归进行的,文件中包含其他文件。  删除所有的注释,“//”和“/**/”。(2)编译:把预编译之后生成的xxx.i或

2021-07-29 15:56:28 410

原创 高并发服务器的发展

高并发高性能服务器是如何实现的?一、多进程  历史上最早出现也是最简单的一种并行处理多个请求的方法就是利用多进程。比如在Linux世界中,我们可以使用fork、exec等系统调用创建多个进程,我们可以在父进程中接收用户的连接请求,然后创建子进程去处理用户请求。这种方法的优点就在于:  编程简单,非常容易理解;  由于各个进程的地址空间是相互隔离的,因此一个进程崩溃后并不会影响其它进程;  充分利用多核资源。多进程并行处理的优点很明显,但是缺点同样明显:  各个进程地址空间相互隔离,这一优点

2021-07-29 15:05:17 137

原创 HTTP请求报文与响应报文

一、HTTP的请求报文格式:HTTP的请求报文内容包括:  请求行(request line)、请求头部(header)、空行 和 请求数据(request data) 四个部分组成。请求行主要包括:请求方法、URL、协议版本请求头部包括:各类配置信息的key-value值二、HTTP响应报文格式:HTTP的响应报文内容包括:  状态行、响应头、空行、数据(响应体)四个部分组成。状态行主要包括:协议版本、状态码、状态值响应头主要包括:各类配置信息的key-value值三、响应报文

2021-07-29 11:55:51 3416

原创 Web网页请求过程

在浏览器中输入一个网址到获得一个页面,这个过程中有用到哪些协议?  本地主机与服务器间的通信是两个进程间相互发送报文,而进程是通过 socket套接字发送和接收报文的,想要收发 socket,首先主机与服务器需要通过TCP三次握手建立τCP连接,连接建立之后,把请求报文放入套接字,然后经过传输层、网络层、数据链路层,层层封装,最终经过以太网路由转发给目的服务器;服务器收到请求后,返回响应报文,本地主机接收到响应报文之后,经由浏览器渲染展示。一、DHCP动态主机配置协议  需要一个IP地址,告诉网络我是

2021-07-29 11:06:14 237

原创 多线程、线程池技术及代码

多线程、线程池技术及代码一、线程池的概念:  线程池是由服务器预先创建的一组子线程,线程池中的线程数量应该和 CPU 数量差不多。线程池中的所有子线程都运行着相同的代码。当有新的任务到来时,主线程将通过某种方式选择线程池中的某一个子线程来为之服务。相比与动态的创建子线程,选择一个已经存在的子线程的代价显然要小得多。  主线程选择哪个子线程来为新任务服务,则有多种方式:主线程使用某种算法来主动选择子线程。最简单、最常用的算法是随机算法和 Round Robin(轮流选取)算法,但更优秀、更智能的算法

2021-07-25 20:27:48 91

原创 服务器编程事件处理模式

一、服务器编程基本框架:  服务器种类繁多,但基本框架一样,不同处在于逻辑处理。模块功能I/O 处理单元处理客户连接,读写网络数据逻辑单元业务进程或线程网络存储单元数据库、文件或缓存请求队列各单元之间的通信方式  I/O 处理单元是服务器管理客户连接的模块。它通常要完成以下工作:等待并接受新的客户连接,接收客户数据,将服务器响应数据返回给客户端。但是数据的收发不一定在 I/O 处理单元中执行,也可能在逻辑单元中执行,具体在何处执行取决于事件处理模式。

2021-07-25 19:39:15 141

原创 阻塞与非阻塞、同步与异步

阻塞与非阻塞、同步与异步一个网络IO过程主要分两部分:数据准备(数据就绪)、数据读写。一、数据准备阶段(数据就绪阶段)  数据准备阶段分为两种情况:阻塞接收与非阻塞接收。阻塞接收:调用IO方法的线程进入阻塞状态。非阻塞接收:不会改变线程的状态,通过返回值判断。二、数据读写阶段  数据读写也分为两种方式:同步写和异步写。同步写:应用程序自己负责读写过程。异步写:操作系统负责读写,读写完毕通过通知的方式告知应用程序。在处理IO的时候,阻塞和非阻塞都是同步IO,只有使用了特殊的API才是异步I

2021-07-25 19:05:39 142

原创 TCP可靠传输

TCP可靠传输  TCP协议保证数据传输可靠性的方式主要有:校验和、序列号与确认应答、超时重传、流量控制、拥塞控制.一、校验和:循环冗余检验(CRC):  收发双方约定一个生成式多项式G(x),发送方基于带发送数据和生成式多项式计算出差错检测码(冗余码),添加到传输数据后一起传输,接收方通过生成式多项式计算收到数据是否产生了误码。二、序列号与确认应答:  序列号:TCP传输时将每个字节的数据都进行了编号,这就是序列号。  确认应答:TCP传输的过程中,每次接收方收到数据后,都会对传输方进行确认

2021-07-23 10:37:27 232

原创 数据库事务

一、事务的组成:  事务可由一条非常简单的SQL语句组成,也可以由一组复杂的SQL语句组成。  在事务中的操作,要么都执行修改,要么都不执行,这就是事务的目的,也是事务模型区别于文件系统的重要特征之一。二、事务的四大特性:A( atomicity),原子性。  原子性指整个数据库事务是不可分割的工作单位。只有使事务中所有的数据库操作都执行成功,整个事务的执行才算成功。事务中任何一个SQL语句执行失败,那么已经执行成功的SQL语句也必须撤销,数据库状态应该退回到执行事务前的状态。C( consis

2021-07-22 20:34:45 71

原创 IO高并发模型

一、IO概念  IO (Input/Output,输入/输出)即数据的读取(接收)或写入(发送)操作。  通常用户进程中的一个完整IO分为两阶段:(1)设备空间(磁盘、网络等)  到   内核空间;(2)内核空间   到   用户进程空间。  IO有内存IO、网络IO和磁盘IO三种,通常我们说的IO指的是后两者。  Linux中进程无法直接操作I/O设备,其必须通过系统调用来协助完成I/O动作;内核会为每个I/O设备维护一个缓冲区。  对于一个输入操作来说,进程IO系统调用后,内核会先看缓冲

2021-07-22 17:50:21 169

原创 大小端问题

一、大小端的概念  小端模式:低有效字节储存在低的存储地址,小端一般为主机字节序。  大端模式:高有效字节存储在低的储存地址,大端为网络字节序。二、如何判断主机字节序是大端还是小端?实现方式:  使用强制类型转换。代码实现:#include<iostream>using namespace std;int main(){ int a = 0x1234; //由于int和char的长度不同,借助int转换成char,只保留低地址部分 char c = (char)a; i

2021-07-22 16:57:38 69

原创 进程相关问题

进程通信方式:  匿名管道、命名管道、信号量; 共享内存、消息队列、信号;socket匿名管道:管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程之间使用。进程的亲缘关系通常是指父子进程关系命名管道:有名管道也是半双工的通信方式,但是允许在没有亲缘关系的进程之间使用,管道是先进先出的通信方式。信号量:信号量是一个计数器,可以用来控制多个进程对共享资源的访问。它常作为一种锁机制,实现进程、线程的对临界区的同步及互斥访问。共享内存:共享内存就是映射一段能被其他进程所访问

2021-07-21 17:50:16 185

原创 操作系统中的几种调度算法

一、页面置换算法1. 先进先出置换算法(FIFO):  每次选择淘汰的页面是最早进入内存的页面。  实现方法:把调入内存的页面根据调入的先后顺序排成一个队列,需要换出页面时选择队头,页面队列的最大长度取决于系统为进程分配了多少个内存块。  FIFO算法虽然实现简单,但是该算法与进程实际运行时的规律不适应,因为先进入的页面也有可能最经常被访问。2. 最近最久未使用置换算法(LRU):  每次淘汰的页面是最近最久未使用的页面。  当需要置换一页时,选择在最近一段时间里没有使用过的页面予以置换。 

2021-07-21 16:53:05 3001

原创 页面置换算法

一、虚拟内存与物理内存首先说一下物理内存与虚拟内存:物理内存:  物理内存有四个层次:分别是寄存器、高速缓存、主存、磁盘。  寄存器:速度最快、量少、价格贵。  高速缓存:次之。  主存:再次之。  磁盘:速度最慢、量多、价格便宜。  操作系统会对物理内存进行管理,有一个部分称为内存管理器( memory manager),主要工作是有效的管理内存,记录哪些内存是正在使用的,在进程需要时分配内存以及在进程完成时回收内存。虛拟内存:  操作系统为每一个进程分配一个独立的地址空间,但是虚

2021-07-21 15:08:10 375

原创 常用设计模式(C++版本)

设计模式一、单例模式:  保证一个类仅有一个实例,该实例被所有的程序模块共享。  该类不能被复制,该类不能被公开创造,构造函数为private,不能被外界实例化,只有一个实例。懒汉式单例模式(第一次使用时初始化,单线程安全,多线程不安全)class singleton{private: singleton(); static singleton* instance;public: static singleton* get_instance(){ i

2021-07-21 11:59:30 174

原创 排序算法的各类变形问题

排序算法的各类变形一、快速选择排序(top K问题)1、快速排序算法:  随便选择一个数字作为中间点,小于放在左边,大于放在右边。递归对左右两个部分排序。  时间复杂度O(nlogn),空间复杂度O(1)。代码实现:int partition(int a[], int left, int right){ int pivot = a[left]; //主元值 int i = left; for (int j = left;

2021-07-20 19:31:53 182

原创 排序算法及其应用(C++实现)

排序算法及其应用(C++实现)一、 常见排序算法:冒泡排序、选择排序、插入排序、归并排序、快速排序、堆排序…冒泡排序:  从第0号元素到第n-1号元素遍历,若前面一个元素大于后面一个元素,则交换两个元素,这样可将整个序列中最大的元素冒泡到最后。然后再从第0号到第n-2号遍历,如此往复,直到只剩一个元素。void bubbleSort(int a[], int n){ for(int i = 0; i < n; ++i){ for(int j = 0; j < n

2021-07-19 22:28:20 310

原创 C++队列

C++队列一、基本概念:队列是一种线性储存数据结构,数据元素遵循“先进先出”(First in First out (FIFO))的原则添加元素在队尾(只允许添加元素)实现,删除元素在对头(只允许删除元素)实现二、队列的操作:判断队列是否为空入队,通常命名为push()出队,通常命名为pop()获取队头元素,通常命名为front()求队列中元素个数三、 队列的分类;基于数组的循环队列(循环队列)基于链表的队列(链表队列)四、基于数组的循环队列数组存储的缺点:入队操作

2020-08-20 17:27:33 5798

原创 C++栈

C++栈一、栈的特点栈是一种线性储存结构;栈是一种后进先出(last-in-first-out)(LIFO)的数据结构;存储数据只能限定在栈顶进行插入和删除操作。二、栈的相关概念(1)栈顶与栈底:允许元素插入与删除的一端称为栈顶,另一端称为栈底。(2)压栈:栈的插入操作,叫做进栈,也称压栈、入栈。(3)弹栈:栈的删除操作,也叫做出栈。三、栈的储存方式(1)基于数组的栈——以数组为底层数据结构时,通常以数组头为栈底,数组头到数组尾为栈顶的生长方向。(2)基于单链表的栈——以链表为底层的数

2020-08-15 16:38:04 182

原创 C++线性表

C++线性表(arrayList)线性表根据存储方式分为:顺序存储(数组描述)、链式存储(链表描述)线性表的抽象类(常用的API):判断是否为空;返回元素个数;返回索引元素;返回指定元素第一次出现的索引值;删除索引元素;将指定元素插入指定索引位置;输出线性表。template<class T>class LineList{public: virtual ~LineList() {};

2020-08-12 22:48:44 1455

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除