Cpp std::filesystem 学习笔记
关于 C++17 标准库 std::filesystem 的整理笔记。 概述 std::filesystem 是 C++17 引入的标准库模块,用于对文件和目录进行跨平台操作。 它提供了文件路径管理、目录操作、文件判断、遍历、创建和删除等功能,使用时无需依赖操作系统特定 API。 由于 Linux 系统和 Windows 系统的文件系统确实存在很多差异,虽然 std::filesystem 的设计目标是屏蔽平台差异,但实际使用中仍然会存在细微差异。 这里以 Linux 平台为主进行实验,Windows 平台会存在分隔符等差异。 在导入头文件时,一般对命名空间使用如下别名缩写 123#include <filesystem>namespace fs = std::filesystem; 路径基础 std::filesystem 的核心类型是 std::filesystem::path,用于表示文件或目录的路径,它并不会具体指代相对路径或绝对路径,只是简化了一些对路径常用的字符串解析操作,然后再对接底层提供的文件系统操作。 创建路径对象 可以直接使用字符串创建路径 12s...
LaTeX Tikz 绘图积累
Tikz 绘图的内容非常复杂,目前没有精力去仔细学习,只是简单记录一些可能用到的例子。一部分例子是我自己绘制的,更多的则是参考的网上公开资料。 Tikz 相关教程例如:TikZBolg。 有一些在线绘图工具可以可视化绘制简单图形,并导出 Tikz 代码,例如:Mathcha。 对于更复杂的需求,可以使用专业的矢量图绘制软件(例如 Inkscape) 绘制并导出 Tikz 代码。 函数图像 1234567891011121314151617181920\documentclass[border=2mm]{standalone}\usepackage{amsmath,amssymb,amsfonts,amsthm}\usepackage[dvipsnames]{xcolor}\usepackage{tikz}\begin{document}\begin{tikzpicture} \draw[->] (-0.5, 0) -- (6, 0) node[ab...
Cpp 练习——模仿Qt的信号槽
基本概念 首先定义如下的概念: 接收元件:Receiver<Y,Ym> 发送元件:Sender<Ym> 接收者:拥有至少一个接受元(公开成员)的类 发送者:拥有至少一个发送元件(公开成员)的类 中转者:既是发送者也是接收者的类 其中:Ym是信息类型, Y是接收者类型,接收元件和发送元件必须使用同样的信息类型Ym, 才能建立联系进行信息传递。 信息会从建立连接的发送元件传递到接收元件,发送元件和接收元件之间可以是一对多或多对多地建议联系。 具体说明 元件之间的连接 发送元件和接收元件之间的连接是双向且对等的(与QT的信号和槽函数机制不同), 它们都可以与对方绑定与解绑(一对多,多对多) 1234567sender.bind(receiver); // 发送元件可以绑定接收元件sender.unbind(receiver); // 发送元件可以解绑接收元件sender.unbind_all(); // 发送元件可以解绑所有的接收元件, 在析构时会自动调用receiver.bind(sender); // 接收元件可以绑定发送元件receiver.unbin...
Cpp 练习——编译期异类词典
代码参考:《C++模板元编程实战:一个深度学习框架的初步实现》。 实现代码如下 var_type_dict.hpp12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218...
Cpp 练习——侵入式的调用栈追踪
基于 C++20 的 std::source_location 和宏实现侵入式的函数调用栈追踪。 mtracer.hpp12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970#pragma once#include <algorithm>#include <cstddef>#include <source_location>#include <stack>#include <string>class MTracer {public: // NOLINTNEXTLINE(fuchsia-default-arguments-declarations) explicit MTracer(const std::source_location &location = ...
基于 SVD 实现图片压缩
图像本质上就是一个或多个矩阵,并且通常具有低秩结构,可以利用SVD分解舍弃低奇异值的部分来实现图片的压缩存储。 简单的 Python 示例实现如下 1234567891011121314151617181920212223242526import numpy as npimport matplotlib.pyplot as pltfrom PIL import Imagedef compress_img_first_k(img_array, k): if img_array.ndim == 2: img_array = img_array[:, :, np.newaxis] m, n, c = img_array.shape compressed_channels = [] for i in range(c): channel = img_array[:, :, i] U, S, VT = np.linalg.svd(channel, full_matrices=False) channel_k =...
Python 单元测试 unittest / pytest
整理一下 Python 单元测试的内容,包括: 内置的单元测试模块 unittest 第三方测试工具 pytest 除此之外,其实还有直接解析源码注释,获取测试用例的内置模块 doctest。 准备 为了便于描述,下面准备两个函数和一个类作为测试目标,构成 my_module.py my_module.py1234567891011121314151617181920def my_add(a, b): return a + bdef my_divide(a, b): return a / bclass MyDict(dict): def __init__(self, **kw): super().__init__(**kw) def __getattr__(self, key): try: return self[key] except KeyError: raise AttributeError(r"'MyDict' object ha...
基于 BibTeX 构建可视化合作网络
在科研中,作者之间的合作关系往往蕴含了很多信息,比如谁是核心作者、合作紧密的团队以及跨学科合作的桥梁。 通过对 BibTeX 文件中的作者信息解析可以获取作者之间的合作关系,并生成可视化图表。 脚本内容 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716...
DLL 注入攻击
概念介绍 DLL 注入攻击(DLL Injection)是一种将动态链接库(DLL)强制加载到目标进程中的技术,使得攻击者编写的代码能在目标进程的地址空间中运行。 在 Windows 中,DLL 注入是系统提供的合法功能,主要用于调试器和辅助工具,但也可以被用于攻击,不过这种攻击手段是非常明显且初等的,一般的防护软件都会识别并阻止这种行为。 简易实现 可以使用最经典的 CreateRemoteThread + LoadLibraryA 方法实现 DLL 注入攻击,下面是主要的代码思路。 代码参考:idea4good/AbuCoding Loader 目标是让目标进程(这里以记事本Notepad.exe为例)加载提供的 DLL,实现步骤: 查找并获取目标进程句柄:使用 CreateToolhelp32Snapshot 遍历系统进程列表;调用 OpenProcess(PROCESS_ALL_ACCESS, ...) 在目标进程分配内存并写入 DLL 路径:VirtualAllocEx 为 DLL 路径字符串留空间;WriteProcessMemory 将 DLL 路径写到目标进程 ...
Python 日志库 logging
Python 标准库中的 logging 模块提供了功能完备、可高度自定义的日志记录方案,适用于从简单脚本到复杂应用程序的各种场景。 许多 C/C++ 项目都依赖自行实现的简单日志库或成熟的第三方日志库(如 spdlog、log4cpp 等),与之不同的是,Python 内置的 logging 模块已经可以满足绝大多数开发需求,各种语言的日志库使用逻辑具有很多共性。 基本使用 先讨论在简单脚本文件中的日志使用,不涉及 logger 以及复杂的日志配置逻辑。 极简示例 导入日志库之后,无需任何配置就可以直接使用 1234567import logginglogging.debug("This is a debug message.")logging.info("This is an info message.")logging.warning("This is a warning message.")logging.error("This is an error message.")logging....
