自定义博客皮肤VIP专享

*博客头图:

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

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

博客底图:

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

栏目图:

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

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+

c++小白的博客

纯属个人娱乐

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

原创 linux常用工具介绍

linux常用命令记录

2023-07-14 15:45:23 1591 3

原创 MySQL行转列的问题

mysql行转列

2023-02-07 18:05:24 499 1

原创 C语言学习推荐---小游戏

C语言推荐小游戏学习之路

2022-10-31 20:46:02 7219

原创 gcc/g++链接时候库的顺序

gcc

2022-09-14 05:03:16 1074

原创 Webbench阅读

Webbench工具

2022-09-08 18:01:46 199

原创 ubuntu jsoncpp 1.9.5 编译使用

目录下载编译拷贝头文件和库文件测试代码下载jsoncpp 1.9.5 好像不支持scons编译了,使用cmake编译原始仓库: https://github.com/open-source-parsers/jsoncppgitee仓库:https://gitee.com/mirrors/jsoncpp/tree/master选择版本下载编译搞到linux上解压执行cmake CMakeLists.txt,发现了编译攻略:按照上面的操作:创建目录:注:这边cp的文件是重新解压缩的,

2022-04-29 17:56:20 1169 7

原创 MyTinySTL阅读笔记---概述

文章目录简介分配器c++中的new和deletenew operatoroperator newplacement new实际测试deleteSTL分配器一级配置器二级配置器一级二级配置器统一的接口内存池实现MyTinySTL分配器allocatorconstructdestroy内存池实现allocatedeallocatereallocate迭代器概述类型traits萃取指针行为反向迭代器 r...

2021-11-08 15:56:43 5462 1

原创 MyTinySTL阅读笔记---容器

容器概述分类:序列容器关联容器序列式容器vector动态增长数组关联式容器

2021-11-08 15:54:29 1754 2

原创 MyTinySTL阅读笔记---算法

算法

2021-10-29 17:03:40 969

原创 MyTinySTL阅读笔记---仿函数和配接器

仿函数所谓仿函数也就是函数对象, 以前是这样称呼它的, 只是一直沿用至今了。仿函数就是一种具有函数特质的对象.。可以将部分操作由用户自己来定义然后传入自定义的函数名就可以被调用。根据参数个数分类一元仿函数一元仿函数基类:template <class Arg, class Result>struct unary_function { typedef Arg argument_type; // 参数类型别名 typedef Result result_type; //

2021-10-29 17:02:57 486 2

原创 MyTinySTL阅读笔记---迭代器

迭代器概述迭代器提供一种方法使它能够依顺序访问聚合物(容器)所含的各个元素,而又无需暴露改聚合物的内部表述方式。迭代器可被用来访问一个容器类的所包函的全部元素,其行为像一个指针(对operator *和operator->进行重载)。设计算法时,如果可能,尽量针对某种特定迭代器提供一个明确定义,并针对更强化的某种迭代器提供另一种定义,这样能在不同情况下提供最大效率。class与typename的区别typename和class在作为参数类型时用法一样, 没有区别typename主要用

2021-10-28 17:49:20 1781 12

原创 MyTinySTL阅读笔记---分配器

分配器c++中的new和delete1、new operatornew operator就是new操作符,平时使用的new(如int *pt = new object(...);)主要完成两个工作:分配足够的内存以便容纳所需类型的对象(operator new)调用构造函数初始化内存中的对象(placement new)2、operator newnew操作符为分配内存所调用函数的名字是operator new,就是间接性的调用了 malloc函数。源码:void* __CRTDECL

2021-10-28 17:47:51 1443 2

原创 linux c语言线程池

文章目录线程池原理线程池原理我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题:如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的效率,因为频繁创建线程和销毁线程需要时间。那么有没有一种办法使得线程可以复用,就是执行完一个任务,并不被销毁,而是可以继续执行其他的任务呢?线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。每个线程都使用默认的堆栈大小,以默认的

2021-10-22 17:17:09 633

原创 联机版贪吃蛇

sss

2021-10-15 01:06:39 3219 9

原创 c++11/14特性整理

auto 关键字for-each 循环右值及移动构造函数 + std::forward + std::move + stl 容器新增的 emplace_back() 方法std::thread 库、std::chrono 库智能指针系列(std::shared_ptr/std::unique_ptr/std::weak_ptr),智能指针的实现原理一定要知道,最好是自己实现过线程库 std::thread + 线程同步技术库 std::mutex/std::condition_variable/std::l

2021-07-29 10:21:05 1320

原创 win32 纸牌

实现效果具体实现牌分为三个部分,鼠标可以拿起若干牌,可以拖动,按照一定规则放置到其他位置,当所有的牌都放在上方时游戏就赢了。牌的随机排列使用random_shuffle乱序之后,把m_vtr当做索引就行了。CCardCtrl::CCardCtrl(): m_vtr(52){ 。。。 for (int i = 0; i < 52; i++) { m_vtr[i] = i; } srand((unsigned int)time(NULL)); random_shuffle(

2021-07-19 11:40:13 214

原创 Tinyhttpd源码阅读

文章目录简介tinyhttpd的职责http请求和响应报文格式请求响应运行代码代码执行流程源代码windows版简介tinyhttpd 是一个超轻量型 Http Server,使用C语言开发,全部代码只有502行(包括注释),附带一个简单的Client,用来学习非常不错,可以通过阅读这段代码理解一个 Http Server 的本质。tinyhttpd的职责接收客户端链接读取客户端发送的信息解析请求处理请求(可能会执行对应的脚本)返回响应http请求和响应报文格式参照菜鸟教程请求一

2021-03-03 18:23:43 528 1

原创 23种设计模式---概述

文章目录设计模式简介设计模式分类设计模式之间的关系面向对象设计原则为什么要用面向对象设计?例子重新认识面向对象设计原则开放封闭原则(OCP)Liskov替换原则(LSP)依赖倒置原则(DIP)单一职责原则(SRP)接口隔离原则(ISP)参考网站:菜鸟教程 C语言中文网设计模式简介设计模式设计模式代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

2021-02-02 17:20:46 891

原创 23种设计模式---解释器模式

解释器模式动机在软件构建过程中,如果某一特定领域的问题比较复杂,类似的结构不断重复出现,如果使用普通的编程方式来实现将面临非常频繁的变化。在这种情况下,将特定领域的问题表达为某种语法规则下的句子,然后构建一个解释器来解释这样的句子,从而达到解决问题的目的。解决方法给定一个语言,定义它的文法的一种表示,并定义一种解释器,这个解释器使用该表示来解释语言中的句子。例子#include <iostream>#include <map>#include <stack&g

2021-02-02 17:19:15 151

原创 23种设计模式---访问者模式

访问者模式动机在软件构建过程中,由于需求的改变,某些类层次结构中常常需要增加新的行为(方法) 。如果直接在基类中做这样的更改,将会给子类带来很繁重的变更负担,甚至破坏原有设计。如何在不更改类层次结构的前提下,在运行时根据需要透明地为类层次结构上的各个类动态添加新的操作,从而避免上述问题?解决方法表示一个作用于某对象结构中的各元素的操作。使得可以在不改变(稳定)各元素的类的前提下定义(扩展)作用于这些元素的新操作(变化)。例子#include <iostream>using na

2021-02-02 17:09:23 140

原创 23种设计模式---命令模式

命令模式动机在软件构建过程中,“行为请求者"与"行为实现者"通常呈现一种"紧耦合”。但在某些场合-比如需要对行为进行"记录、撤销/重(undo/redo)、事务"等处理,这种无法抵御变化的紧耦合是不合适的。在这种情况下,如何将"行为请求者"与“行为实现者"解耦?将一组行为抽象为对象,可以实现二者之间的松耦合。解决方法将一个请求(行为)封装为一个对象,从而使你可用不同的请求对客户进行参数化;对请求排队或记录请求日志,以及支持可撤销的操作。例子#include <iostream>#

2021-02-02 16:38:12 119

原创 23种设计模式---责任链模式

责任链模式动机在软件构建过程中,一个请求可能被多个对象处理,但是每个请求在运行时只能有一个接受者,如果显式指定,将必不可少地带来请求发送者与接受者的紧耦合。如何使请求的发送者不需要指定具体的接受者?让请求的接受者自己在运行时决定来处理请求,从而使两者解耦。解决方法使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递请求,直到有一个对象处理它为止。例子#include <iostream>#include <strin

2021-02-02 16:30:26 101

原创 23种设计模式---迭代器模式

迭代器模式动机在软件构建过程中,集合对象内部结构常常变化各异。但对于这些集合对象,我们希望在不暴露其内部结构的同时,可以让外部客户代码透明地访问其中包含的元素;同时这种"透明遍历"也为 ,"同一种算法在多种集合对象上进行操作"提供了可能。使用面向对象技术将这种遍历机制抽象为"迭代器对象"为"应变化中的集合对象"提供了一种优雅的方式。...

2021-02-02 16:20:45 110

原创 23种设计模式---组合模式

组合模式动机在软件在某些情况下,客户代码过多地依赖于对象容器复杂的内部实现结构,对象容器内部实现结构(而非抽象接口)的变化将引引起客户代码的频繁变化,带来了代码的维护性、扩展性等弊端。如何将"客户代码与复杂的对象容器结构"解耦?让对象容器自己来实现自身的复杂结构,从而使得客户代码就像处理简单对象样来处理复杂的对象容器?解决方法将对象组合成树形结构以表示"部分-整体"的层次结构。使得用户对单个对象和组合对象的使用具有一致性(稳定)。例子#include <iostream>#inc

2021-02-02 16:05:08 116

原创 23种设计模式---备忘录模式

备忘录模式动机在软件构建过程中,某些对象的状态在转换过程中,可能由于某种需要,要求程序能够回溯到对象之前处于某个点时的状态。如果使用一些公有接口来让其他对象得到对象的状态,便会暴露对象的细节实现。如何实现对象状态的良好保存与恢复?但同时又不会因此而破坏对象本身的封装性。解决方法在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。这样以后就可以将该对象恢复到原先保存的状态。例子class Memento{ string state; // ..publ

2021-02-02 15:52:48 93

原创 23种设计模式---状态模式

状态模式动力在软件构建过程中,某些对象的状态如果改变,其行为也会随之而发生变化,比如文档处于只读状态,其支持的行为和读写状态支持的行为就可能完全不同。如何在运行时根据对象的状态来透明地更改对象的行为?而不会对对象的操作和状态转化之间引入紧耦合?解决方法允许一个对象在其内部状态改变时改变它的行为。从而使对象看起来似乎修改了其行为。例子enum NetworkState{ Network_Open, Network_Close, Network_Connect,};

2021-02-02 15:44:50 102

原创 23种设计模式---中介者模式

中介者模式动机在软件构建过程中,经常会出现多个对象互相关联交互的情况对象之间常常会维持一种复杂的引用关系,如果遇到一些需求的更改,这种直接的引用关系将面临不断的变化。在这种情况下,我们可使用一个"中介对象"来管理对象间的关联关系,避免相互交互的对象之间的紧耦合引用关系,从而更好地氏御变化。解决方法用一个中介对象来封装(封装变化)一系列的对象交互。中介者使各对象不需要显式的相互引用(编译时依赖->运行时依赖) ,从而使其耦合松散(管理变化) ,而且可以独立地交。例子// 抽象同事类c

2021-02-01 15:56:34 128

原创 23种设计模式---适配器模式

适配器模式动机在软件系统中,由于应用环境的变化,常常需要将"一些现存的对象"放在新的环境中应用,但是新环境要求的接口是这些现存对象所不满足的。如何应对这种"迁移的变化" ?如何既能利用现有对象的良好实现,同时又能满足新的应用环境所要求的接口?解决方法将一个类的接口转换成客户希望的另一个接口。Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。例子// 目标接口(新接口)class ITarget{public: virtual void process()

2021-02-01 14:52:49 84

原创 23种设计模式---代理模式

代理模式动机在面向对象系统中,有些对象由于某种原因(比如对象创建的开销很大,或者某些操作需要安全控制,或者需要进程外的访问等) ,直接访问会给使用者、或者系统结构带来很多麻烦。如何在不失去透明操作对象的同时来管理/控制这些对象特有的复性?增加一层间接层是软件开发中常见的解决方式。解决方法为其他对象提供一种代理以控制(隔离,使用接口)对这个对象的访问。例子class ISubject{public: virtual void process();};class RealSubj

2021-02-01 14:40:31 104

原创 23种设计模式---外观模式

外观模式动机随着软件的开发,组件的客户和组件中各种复杂的子系统有了过多的耦合,随着外部客户程序和各子系统的演化,这种过多的耦合面临很多变化的挑战。如何简化外部客户程序和系统间的交互接口?如何将外部客户程序的演化和内部子系统的变化之间的依赖相互解耦?解决方法为子系统中的一组接口提供一个一致(稳定)的界面,门面模式定义了一个高层接口,这个接口使得这一子系统更加容易使用(复用)。例子用户需要了解所有类// 子系统角色class SubSystem01{public: void method

2021-02-01 14:26:39 113

原创 23种设计模式---桥接模式

桥接模式动机由于某些类型的固有的实现逻辑,使得它们具有两个变化的维度,乃至多个纬度的变化。如何应对这种“多维度的变化”?如何利用面向对象技术来使得类型可以轻松地沿着两个乃至多个方向变化,而不引入额外的复杂度?解决方法将抽象部分(业务功能)与实现部分(平台实现)分离,使它们都可以独立地变化。例子制作一个通讯工具:class Messager{public: virtual void Login(string username, string password) = 0;

2021-02-01 14:07:17 122

原创 23种设计模式---装饰模式

装饰模式动机在某些情况下我们可能会“过度地使用继承来扩展对象的功能”, 由于继承为类型引入的静态特质,使得这种扩展方式缺乏灵活性; 并且随着子类的增多(扩展功能的增多),各种子类的组合(扩展功能的组合)会导致更多子类的膨胀。如何使“对象功能的扩展”能够根据需要来动态地实现?同时避免“扩展功能的增多”带来的子类膨胀问题?从而使得任何“功能扩展变化”所导致的影响将为最低?解决方法动态(组合)地给一个对象增加一些额外的职责。就增加功能而言,装饰模式比生成子类(继承)更为灵活(消除重复代码 & 减

2021-01-31 14:37:52 95 1

原创 23种设计模式---观察者模式

观察者模式动机在软件构建过程中,我们需要为某些对象建立一种“通知依赖关系” ——一个对象(目标对象)的状态发生改变,所有的依赖对象(观察者对象)都将得到通知。如果这样的依赖关系过于紧密, 将使软件不能很好地抵御变化。使用面向对象技术,可以将这种依赖关系弱化,并形成一种稳定的依赖关系。从而实现软件体系结构的松耦合。解决方法定义对象间的一种一对多(变化)的依赖关系,以便当一个对象(Subject)的状态发生改变时,所有依赖于它的对象都得到通知并自动更新。例子文件分割器:简单实现:class M

2021-01-31 13:52:15 113

原创 23种设计模式---策略模式

策略模式动机在软件构建过程中,某些对象使用的算法可能多种多样,经常改变,如果将这些算法都编码到对象中,将会使对象变得异常复杂; 而且有时候支持不使用的算法也是一个性能负担。如何在运行时根据需要透明地更改对象的算法?将算法与对象本身解耦,从而避免上述问题?解决方法定义一系列算法,把它们一个个封装起来,并且使它们可互相替换(变化)。该模式使得算法可独立于使用它的客户程序(稳定)而变化(扩展,子类化)。例子计算财务报表(支持跨国税率):一种实现:enum TaxBase{ CN_Tax,

2021-01-31 13:25:38 111

原创 23种设计模式---模板模式

模板模式动机在软件构建过程中,对于某一项任务,它常常有稳定的整体操作结构,但各个子步骤却有很多改变的需求,或者由于固有的原因(比如说框架与应用之间的关系)而无法和任务的整体结构同时实现。如何在确定稳定操作的前提下,来灵活应对各个子步骤的变化或者晚期的需求?解决方法定义一个操作中的算法的骨架 (稳定),而将一些步骤延迟 (变化)到子类中。模板模式使得子类可以不改变 (复用)一个算法的结构即可重定义(override 重写)该算法的某些特定步骤。例子数据库开发人员定义了几个步骤:// 程序库开发

2021-01-31 13:07:02 103

原创 23种设计模式---建造者模式

建造者模式动机在软件系统中,有时候面临着“一个复杂对象”的创建工作,其通常由各个部分的子对象用一定的算法构成;由于需求的变化,这个复杂对象的各个部分经常面临着剧烈的变化,但是将它们组合在一起的算法却相对稳定。如何应对这种变化?如何提供一种“封装机制”来隔离出“复杂对象的各个部分”的变化,从而保持系统中的“稳定构建算法”不随着需求改变而改变?解决方法将一个复杂对象的构建与其表示相分离,使得同样的构建过程(稳定)可以创建不同的表示(变化)。例子创建房子:class House{ //

2021-01-31 11:49:34 108

原创 23种设计模式---原型模式

原型模式动机在软件系统中,经常面临着“某些结构复杂的对象”创建工作;由于需求的变化, 需要创建的对象的具体类型经常变化,但是它们却有比较稳定一致的接口。如何应对这种变化?如何向客户程序(使用这些对象的程序)“隔离出”这些易变对象,从而使得“依赖这些易变对象的客户程序”不随着需求改变而改变?解决方法实现了一个原型接口,该接口用于创建当前对象的克隆。当直接创建对象的代价比较大时,则采用这种模式。例如,一个对象需要在一个高代价的数据库操作之后被创建。我们可以缓存该对象,在下一个请求时返回它的克隆,在需要

2021-01-30 17:38:05 79

原创 23种设计模式---抽象工厂模式

抽象工厂模式动机在软件系统中,经常面临着“一系列相互依赖的对象”的创建工作;同时由于需求的变化,往往存在更多系列对象的创建工作。如何应对这种变化?如何绕过常规的对象创建方法(new),提供一种“封装机制”来避免客户程序和这种“多系列具体对象创建工作” 的紧耦合?解决方法提供一个接口,让该接口负责创建一系列“相关或者相互依赖的对象”,无需指定它们具体的类。例子数据库连接:class EmployeeDAO{ public: vector<EmployeeDO> G

2021-01-30 16:46:54 106

原创 23种设计模式---工厂模式

工厂模式动机在软件系统中,经常面临着创建对象的工作;由于需求的变化, 需要创建的对象的具体类型经常变化。如何应对这种变化?如何绕过常规的对象创建方法(new),提供一 种“封装机制”来避免客户程序和这种“具体对象创建工作”的紧耦合?解决方法定义一个用于创建对象的接口,让子类决定实例化哪一个类。 工厂模式使得一个类的实例化延迟(目的:解耦, 手段:虚函数)到子类。我们在创建对象时不会对客户端暴露创建逻辑,并且是通过使用一个共同的接口来指向新创建的对象。例子文件分割:class ISplitte

2021-01-29 18:30:03 121

原创 23种设计模式---享元模式

文章目录享元模式动机解决方法例子享元模式动机在软件系统采用纯粹对象方案的问题在于大量细粒度的对象会很快充斥在系统中,从而带来很高的运行时代价-主要指内存需求方面的代价。解决方法享元模式尝试重用现有的同类对象,用唯一标识码(比如说id、hash等)判断,如果在内存中有,则返回这个唯一标识码所标识的对象,如果未找到匹配的对象,则创建新对象。例子细粒度对象(字体类):class Font{private: // 键 string key; // 对象状态

2021-01-29 11:31:18 99

空空如也

空空如也

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

TA关注的人

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