【Linux】进程概念解释和linux环境变量
进程相关概念解释和linux环境变量
【C++】异常处理
本篇博客让我们来认识一下C++中对于异常的处理机制 [TOC] 1.概念1.1 C语言对于异常的处理在之前我们遇到一些bug的时候,通常会用if判断或者assert断言等问题进行处理。但这种方式太过暴力,会直接中断程序的运行 另外一种办法是返回错误码,C语言的报错大多使用这种方式。不过这需要程序的用户自己去查对应的错误码表格,较为麻烦 1.2 C++异常所谓异常,便是程序运行过程中可能遇到的bug或者问题。程序可以有选择地抛出一个异常,告知用户程序运行出现了问题。 C++标准库中便使用了一个exception类来进行异常的处理,我们运行程序中遇到的一些报错,其实就是标准库里面抛出了对应的 ...
【C++】C++11的那些新特性
本篇博客,让我们一起来看看C++11的那些新特性! 所使用的编译器:VS2019 本篇博客所有的测试源码都可以在我的GITEE仓库找到 [TOC] 1.前言C++11是C++的标准委员会在2011年更新的C++新特性。说白了就是一个升级包。和JAVA\PYTHON这种更新比较频繁的语言相比,C++更新的就没有那么顺风顺水了,而且每一次更新虽然修复了一些问题,但也带来了更多的“没太大必要”的更新 比如没啥用的array容器,和int arr[10]这种内置方式的区别主要在于越界检查 不过咱们这种小菜鸡,只有学习的权力,哪有啥资格评定C++标准呢?我听大佬说,现在最关注的C++更新便 ...
【Linux】进程概念
本篇博客是有关进程状态的,好久没有写Linux的博客了,一起来看看吧! 实验系统:CentOS 7.6 1.系统进程的运行状态当我们想到进程的时候,一定要首先想到task_struct结构体。该结构体内部有一个state状态码,用于标识当前进程处于什么状态 1.1 运行态CPU会有一个进程队列(双链表),队列的每一个成员都是一个task_struct结构体,用来维护即将运行的进程。当轮到某个进程运行的时候,CPU就会将这个进程的数据和代码放入内存和自己的寄存器,并开始运行 只要进入了运行队列的进程,就是运行态的进程 所以运行态并不是正在运行的进程 为什么我们对这件事的感知不大呢? ...
【C++】STL的map和set
本篇博客让我们来了解一下STL库里面的map/set的使用,并尝试用自己写的红黑树封装一个类似的map/set出来 所用编译器:VS2019 [TOC] 1 setset就是二叉搜索树中只有单个key的树,它有下面的函数可供使用 1.1 构造函数、迭代器构造函数、迭代器什么的都很简单,在这里就提到了,和其他STL基本一致 1.2 节点计数 sizeset自带节点计数,我们可以之间获取二叉树中节点的个数,或判断set是否为空 1.3 插入删除插入删除等函数在这里不过多解释,使用方法和string、vector完全一致。如果大家的stl是从string一路学习过来,那么对于 ...
【Python】关于vip和普通用户商店返回值图片出错的问题定位+大白话说明
在开发阿狸的过程中,遇到了一个全局变量写错而导致的bug…… 问题引出如果你最近几天有用过shop查询功能,可能会遇到下面的情况 上图为普通用户的商店用了vip用户16-9的图片; 下图为vip用户的商店用了普通用户1-1的图片 简单说来,vip的商店返回值是16-9的图片,而普通用户的商店是1-1的图片。 在上面的三个每日商店返回值中,就出现了vip用户的商店用了1-1的图,或者普通用户的商店用了16-9的图。 这个bug昨天(22.09.12)我就发现了,是一位vip用户的商店返回值里面用了普通用户的图片。而我昨天定位bug的时候,测试bot保存了画出来的4个小图,没有问题;然后 ...
【牛客网】HJ92 在字符串中找出连续最长的数字串
HJ92 在字符串中找出连续最长的数字串 题目来源 牛客网 HJ92 描述输入一个字符串,返回其最长的数字子串,以及其长度。若有多个最长的数字子串,则将它们全部输出(按原字符串的相对位置) 本题含有多组样例输入。 数据范围:字符串长度 1 \le n \le 200 \1≤n≤200 , 保证每组输入都至少含有一个数字 输入描述:输入一个字符串。1<=len(字符串)<=200 输出描述:输出字符串中最长的数字字符串和它的长度,中间用逗号间隔。如果有相同长度的串,则要一块儿输出(中间不要输出空格) 123456789输入:abcd12345ed125ss123 ...
【C++】红黑树的性质和实现
上篇博客我们了解了AVL树,这篇博客就让我们来看看另外一个二叉树:红黑树 使用的编译器:VS2019 [TOC] 博客里面引用了一些百度搜到的图片(自己懒的画了,呜呜) 1.概念AVL树是一个几乎完全平衡的搜素二叉树,其左右子树的高度差不会超过1。与之相对应的,是每一次插入都有可能需要旋转多次,插入的效率较低。 而红黑树则选择了“相对平衡”,并拥有以下的特性: 红黑树可以保证最长路径的小于最短路径的2倍 比如最短路径为30,那么最长路径就不能超过60 对于cpu来说,AVL树遍历20次(百万级数据)和红黑树遍历40次的时间差距极小。所以红黑树即保持了相对平衡,又减小了AVL树 ...
【Python】动手写一个git自动上传脚本!
本篇博客来教你用Python写一个简单的git自动上传脚本 前言为什么需要一个这样的东西? 有的时候,我的学习代码其实没啥好commit的,写一个自动上传的脚本,就可以自动执行完所有的命令,而不需要自己手动进行git三板斧操作 项目代码已开源 https://gitee.com/musnow/learn_python_code/tree/master/code/22-09-02%20auto_git 效果如下把EXE文件丢进你的git仓库路径,点一下就会自动执行命令 打开你的仓库可以看到,成功上传了 源码实现其实很简单,就是用OS往系统的命令行里面写命令而已 123456789 ...
【C++】AVL树(平衡搜索二叉树)
在上一篇C++博客中,讲述了关于搜索二叉树以及KVL树的实现。也提到了搜索二叉树的最坏情况:插入的数据已经有序。 而本篇博客涉及到的AVL树,又称平衡搜索二叉树。就是为了解决搜索二叉树的最坏情况而生的。 [TOC] 1. 什么是AVL树二叉搜索树虽然缩短了查找的效率,但是数据有序的时候,就会出现一边非常长的情况,导致原本的O(logN)时间复杂度被迫变成了O(N) 平衡树也是搜索二叉树,其引入了一个平衡因子的概念,用于控制搜索二叉树的平衡。它会保证左右子树的高度之差(绝对值)不超过1。当新插入节点导致高度之差超过1时,便会触发旋转,使得树的高度降低。 简单说来:AVL树能保证两边高度的相 ...