墨水屏显示模拟器程序解读
程序如下:出处https://github.com/tsl0922/EPD-nRF5?tab=readme-ov-file
// GUI emulator for Windows
// This code is a simple Windows GUI application that emulates the display of an e-paper device.
#include <windows.h>
#include <stdint.h>
#include <time.h>
#include "GUI.h"#define BITMAP_WIDTH 400
#define BITMAP_HEIGHT 300
#define WINDOW_WIDTH 400
#define WINDOW_HEIGHT 340
#define WINDOW_TITLE TEXT("Emurator")// Global variables
HINSTANCE g_hInstance;
HWND g_hwnd;
display_mode_t g_display_mode = MODE_CALENDAR; // Default to calendar mode
BOOL g_bwr_mode = TRUE; // Default to BWR mode
time_t g_display_time;
struct tm g_tm_time;// Convert bitmap data from e-paper format to Windows DIB format
static uint8_t *convertBitmap(uint8_t *bitmap, uint16_t x, uint16_t y, uint16_t w, uint16_t h) {int bytesPerRow = ((w + 31) / 32) * 4; // Round up to nearest 4 bytesint totalSize = bytesPerRow * h;// Allocate memory for converted bitmapuint8_t *convertedBitmap = (uint8_t*)malloc(totalSize);if (convertedBitmap == NULL) return NULL;memset(convertedBitmap, 0, totalSize);int ePaperBytesPerRow = (w + 7) / 8; // E-paper buffer stridefor (int row = 0; row < h; row++) {for (int col = 0; col < w; col++) {// Calculate byte and bit position in e-paper bufferint bytePos = row * ePaperBytesPerRow + col / 8;int bitPos = 7 - (col % 8); // MSB first (typical e-paper format)// Check if the bit is set in the e-paper bufferint isSet = (bitmap[bytePos] >> bitPos) & 0x01;// Calculate byte and bit position in Windows DIBint dibBytePos = row * bytesPerRow + col / 8;int dibBitPos = 7 - (col % 8); // MSB first for DIB too// Set the bit in the Windows DIB if it's set in the e-paper bufferif (isSet) {convertedBitmap[dibBytePos] |= (1 << dibBitPos);}}}return convertedBitmap;
}// Implementation of the buffer_callback function
void DrawBitmap(uint8_t *black, uint8_t *color, uint16_t x, uint16_t y, uint16_t w, uint16_t h) {HDC hdc;RECT clientRect;int scale = 1;// Get the device context for immediate drawinghdc = GetDC(g_hwnd);if (!hdc) return;// Get client area for positioningGetClientRect(g_hwnd, &clientRect);// Calculate position to center the entire bitmap in the windowint drawX = (clientRect.right - BITMAP_WIDTH * scale) / 2;int drawY = (clientRect.bottom - BITMAP_HEIGHT * scale) / 2;// Create DIB for visible pixelsBITMAPINFO bmi;ZeroMemory(&bmi, sizeof(BITMAPINFO));bmi.bmiHeader.biSize = sizeof(BITMAPINFOHEADER);bmi.bmiHeader.biWidth = w;bmi.bmiHeader.biHeight = -h; // Negative for top-down bitmapbmi.bmiHeader.biPlanes = 1;bmi.bmiHeader.biBitCount = 1;bmi.bmiHeader.biCompression = BI_RGB;uint8_t *convertedBitmap = convertBitmap(black, x, y, w, h);if (convertedBitmap == NULL) {ReleaseDC(g_hwnd, hdc);return;}// Set colors for black and white displaybmi.bmiColors[0].rgbBlue = 0;bmi.bmiColors[0].rgbGreen = 0;bmi.bmiColors[0].rgbRed = 0;bmi.bmiColors[0].rgbReserved = 0;bmi.bmiColors[1].rgbBlue = 255;bmi.bmiColors[1].rgbGreen = 255;bmi.bmiColors[1].rgbRed = 255;bmi.bmiColors[1].rgbReserved = 0;// Draw the black layerStretchDIBits(hdc,drawX + x * scale, drawY + y * scale, // Destination positionw * scale, h * scale, // Destination size0, 0, // Source positionw, h, // Source sizeconvertedBitmap, // Converted bitmap bits&bmi, // Bitmap infoDIB_RGB_COLORS, // UsageSRCCOPY); // Raster operation codefree(convertedBitmap);// Handle color layer if present (red in BWR displays)if (color) {// Allocate memory for converted color bitmapuint8_t *convertedColor = convertBitmap(color, x, y, w, h);if (convertedColor) {// Set colors for red overlaybmi.bmiColors[0].rgbBlue = 255;bmi.bmiColors[0].rgbGreen = 255;bmi.bmiColors[0].rgbRed = 0;bmi.bmiColors[0].rgbReserved = 0;bmi.bmiColors[1].rgbBlue = 0;bmi.bmiColors[1].rgbGreen = 0;bmi.bmiColors[1].rgbRed = 0;bmi.bmiColors[1].rgbReserved = 0;// Draw red overlayStretchDIBits(hdc,drawX + x * scale, drawY + y * scale, // Destination positionw * scale, h * scale, // Destination size0, 0, // Source positionw, h, // Source sizeconvertedColor, // Converted bitmap bits&bmi, // Bitmap infoDIB_RGB_COLORS, // UsageSRCINVERT); // Use XOR operation to blendfree(convertedColor);}}// Release the device contextReleaseDC(g_hwnd, hdc);
}// Window procedure
LRESULT CALLBACK WndProc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam) {switch (message) {case WM_CREATE:// Initialize the display timeg_display_time = time(NULL) + 8*3600;// Set a timer to update the CLOCK periodically (every second)SetTimer(hwnd, 1, 1000, NULL);return 0;case WM_TIMER:if (g_display_mode == MODE_CLOCK) {g_display_time = time(NULL) + 8*3600;if (g_display_time % 60 == 0) {InvalidateRect(hwnd, NULL, FALSE);}}return 0;case WM_PAINT: {PAINTSTRUCT ps;HDC hdc = BeginPaint(hwnd, &ps);// Get client rect for calculationsRECT clientRect;GetClientRect(hwnd, &clientRect);// Clear the entire client area with a solid colorHBRUSH bgBrush = CreateSolidBrush(RGB(240, 240, 240));FillRect(hdc, &clientRect, bgBrush);DeleteObject(bgBrush);// Use the stored timestampgui_data_t data = {.bwr = g_bwr_mode,.width = BITMAP_WIDTH,.height = BITMAP_HEIGHT,.timestamp = g_display_time,.temperature = 25,.voltage = 3.2f,};// Call DrawGUI to render the interface, passing the BWR modeDrawGUI(&data, DrawBitmap, g_display_mode);EndPaint(hwnd, &ps);return 0;}case WM_KEYDOWN:// Toggle display mode with spacebarif (wParam == VK_SPACE) {if (g_display_mode == MODE_CLOCK)g_display_mode = MODE_CALENDAR;elseg_display_mode = MODE_CLOCK;InvalidateRect(hwnd, NULL, TRUE);}// Toggle BWR mode with R keyelse if (wParam == 'R') {g_bwr_mode = !g_bwr_mode;InvalidateRect(hwnd, NULL, TRUE);}// Handle arrow keys for month/day adjustmentelse if (wParam == VK_UP || wParam == VK_DOWN || wParam == VK_LEFT || wParam == VK_RIGHT) {// Get the current time structureg_tm_time = *localtime(&g_display_time);// Up/Down adjusts monthif (wParam == VK_UP) {g_tm_time.tm_mon++;if (g_tm_time.tm_mon > 11) {g_tm_time.tm_mon = 0;g_tm_time.tm_year++;}}else if (wParam == VK_DOWN) {g_tm_time.tm_mon--;if (g_tm_time.tm_mon < 0) {g_tm_time.tm_mon = 11;g_tm_time.tm_year--;}}// Left/Right adjusts dayelse if (wParam == VK_RIGHT) {g_tm_time.tm_mday++;}else if (wParam == VK_LEFT) {g_tm_time.tm_mday--;}// Convert back to time_tg_display_time = mktime(&g_tm_time);// Force redrawInvalidateRect(hwnd, NULL, TRUE);}return 0;case WM_DESTROY:KillTimer(hwnd, 1);PostQuitMessage(0);return 0;default:return DefWindowProc(hwnd, message, wParam, lParam);}
}// Main entry point
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow) {g_hInstance = hInstance;// Register window classWNDCLASSA wc = {0}; // Using WNDCLASSA for ANSI versionwc.style = CS_HREDRAW | CS_VREDRAW;wc.lpfnWndProc = WndProc;wc.hInstance = hInstance;wc.hCursor = LoadCursor(NULL, IDC_ARROW);wc.hbrBackground = (HBRUSH)(COLOR_WINDOW+1);wc.lpszClassName = "BitmapDemo"; // No L prefix - using ANSI stringsif (!RegisterClassA(&wc)) {MessageBoxA(NULL, "Window Registration Failed!", "Error", MB_ICONEXCLAMATION | MB_OK);return 0;}// Create the window - explicit use of CreateWindowA for ANSI versiong_hwnd = CreateWindowA("BitmapDemo","Emurator", // Using simple titleWS_OVERLAPPEDWINDOW,CW_USEDEFAULT, CW_USEDEFAULT,WINDOW_WIDTH, WINDOW_HEIGHT,NULL, NULL, hInstance, NULL);if (!g_hwnd) {MessageBoxA(NULL, "Window Creation Failed!", "Error", MB_ICONEXCLAMATION | MB_OK);return 0;}// Show windowShowWindow(g_hwnd, nCmdShow);UpdateWindow(g_hwnd);// Main message loopMSG msg;while (GetMessage(&msg, NULL, 0, 0)) {TranslateMessage(&msg);DispatchMessage(&msg);}return (int)msg.wParam;
}
代码功能概述
这段 C 语言代码是一个 Windows GUI 应用程序,用于模拟电子纸显示设备的界面。它支持黑白和黑白红 (BWR) 两种显示模式,并能在时钟和日历两种显示模式间切换。程序通过 Windows API 创建窗口,处理用户输入,并模拟电子纸的显示效果。
主要模块与功能分析
1. 全局变量与宏定义
#define BITMAP_WIDTH 400
#define BITMAP_HEIGHT 300
#define WINDOW_WIDTH 400
#define WINDOW_HEIGHT 340
#define WINDOW_TITLE TEXT("Emurator")
HINSTANCE g_hInstance;
HWND g_hwnd;
display_mode_t g_display_mode = MODE_CALENDAR;
BOOL g_bwr_mode = TRUE;
time_t g_display_time;
struct tm g_tm_time;
定义了显示区域和窗口的尺寸
声明了窗口句柄、显示模式和时间相关变量
默认显示模式为日历,默认支持 BWR (黑白红) 模式
2. 位图转换函数 convertBitmap
static uint8_t *convertBitmap(uint8_t *bitmap, uint16_t x, uint16_t y, uint16_t w, uint16_t h) {
// 计算行字节数并分配内存
int bytesPerRow = ((w + 31) / 32) * 4;
int totalSize = bytesPerRow * h;
uint8_t *convertedBitmap = (uint8_t*)malloc(totalSize);
memset(convertedBitmap, 0, totalSize);
// 转换电子纸格式(MSB优先)到位图格式
int ePaperBytesPerRow = (w + 7) / 8;
for (int row = 0; row < h; row++) {
for (int col = 0; col < w; col++) {
// 计算电子纸缓冲区中的位位置
int bytePos = row * ePaperBytesPerRow + col / 8;
int bitPos = 7 - (col % 8);
int isSet = (bitmap[bytePos] >> bitPos) & 0x01;
// 设置Windows DIB中的对应位
int dibBytePos = row * bytesPerRow + col / 8;
int dibBitPos = 7 - (col % 8);
if (isSet) {
convertedBitmap[dibBytePos] |= (1 << dibBitPos);
}
}
}
return convertedBitmap;
}
将电子纸设备使用的位图格式转换为 Windows DIB (设备无关位图) 格式
处理了位序转换 (MSB 优先) 和行字节对齐问题
支持黑白和彩色 (红色) 两层显示
DrawBitmap 函数详解
该函数是电子纸模拟器的核心绘制函数,负责将电子纸的位图数据(黑白层和彩色层)转换为 Windows 窗口可显示的位图,并完成最终渲染。
以下从功能流程、关键技术点和代码细节三方面展开分析:
一、函数功能与流程总览
输入参数:
• black:黑白层位图数据(1 位单色,MSB 优先)
• color:彩色层位图数据(可选,通常用于红色显示)
• x/y:绘制起点坐标(相对于显示区域)
• w/h:绘制区域的宽度和高度
核心流程:
1. 获取绘图环境:获取窗口的设备上下文(HDC)和客户区尺寸。
2. 配置位图信息:定义 Windows 位图格式(BITMAPINFO),包括尺寸、位深、颜色表等。
3. 绘制黑白层: ◦ 调用 convertBitmap 转换电子纸格式为 Windows 位图。 ◦ 使用 StretchDIBits 绘制黑色前景和白色背景。
4. 绘制彩色层(可选): ◦ 转换彩色层数据并设置颜色表(红色通过黄色与黑色异或实现)。 ◦ 使用 SRCINVERT 光栅操作混合颜色层。
5. 释放资源:归还设备上下文,避免内存泄漏。
二、关键技术点解析
1. 设备上下文(HDC)与窗口坐标系
• GetDC(g_hwnd):获取窗口的设备上下文,用于直接在窗口上绘制图形。
• GetClientRect:获取窗口客户区(不含边框和标题栏)的尺寸,
用于计算位图居中显示的位置:
int drawX = (clientRect.right - BITMAP_WIDTH * scale) / 2;
int drawY = (clientRect.bottom - BITMAP_HEIGHT * scale) / 2;
(代码中虽未显式计算 scale,但通过 StretchDIBits 的缩放参数实现自适应显示)
2. 位图信息头(BITMAPINFO)配置
BITMAPINFO bmi = {0};
bmi.bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
bmi.bmiHeader.biWidth = w; // 位图宽度(像素)
bmi.bmiHeader.biHeight = -h; // 负高度表示位图数据从上到下存储(正向显示)
bmi.bmiHeader.biPlanes = 1; // 平面数,固定为1
bmi.bmiHeader.biBitCount = 1; // 1位单色位图(每个像素占1位,0=黑色,1=白色)
bmi.bmiHeader.biCompression = BI_RGB; // 无压缩,使用RGB颜色表
• 负高度的作用:
Windows 位图有两种存储方式:
◦ 正高度:位图数据从下到上存储(原点在左下角)。
◦ 负高度:位图数据从上到下存储(原点在左上角),更符合常规坐标系,便于直接绘制。
3. 位图格式转换(convertBitmap)
• 电子纸格式特点:
◦ 1 位单色,MSB 优先(最高位为第一个像素)。
◦ 行字节数为 (宽度 + 7) / 8(向上取整到字节)。
• Windows DIB 格式要求: ◦ 1 位位图使用 BI_RGB 压缩,行字节数需为 4 的倍数(通过 ((w + 31) / 32) * 4 计算)。 • 转换逻辑: c // 电子纸缓冲区中的位位置(MSB优先)
int bitPos = 7 - (col % 8);
// Windows DIB 中的位位置(同样MSB优先)
int dibBitPos = 7 - (col % 8);
通过逐行逐位复制,将电子纸的 “位掩码” 转换为 Windows 可识别的位图数据。 4. 颜色表与绘制逻辑 • 黑白层绘制: c bmi.bmiColors[0] = RGB(0, 0, 0); // 索引0对应黑色(位图中值为0的像素)
bmi.bmiColors[1] = RGB(255, 255, 255); // 索引1对应白色(位图中值为1的像素)
StretchDIBits(..., SRCCOPY); // 直接复制像素,黑色前景覆盖白色背景
• 彩色层(红色)绘制:
◦ 电子纸彩色层通常为红色,但 Windows 位图不支持直接绘制红色单通道,因此通过 异或(XOR)操作 模拟:
bmi.bmiColors[0] = RGB(255, 255, 0); // 黄色(R=255, G=255, B=0)
bmi.bmiColors[1] = RGB(0, 0, 0); // 黑色(背景)
StretchDIBits(..., SRCINVERT); // 异或操作:黄色 ^ 白色 = 红色,黄色 ^ 黑色 = 黄色
◦ 异或原理:
◦ 白色背景区域(RGB (255,255,255)):黄色(RGB (255,255,0))与白色异或后为红色(RGB (255,0,0))。
◦ 黑色前景区域(RGB (0,0,0)):黄色与黑色异或后保持黄色,但因黑色层已覆盖,实际不显示。 三、代码细节与注意事项
1. 内存管理
• 动态分配与释放:
uint8_t *convertedBitmap = convertBitmap(...); // 分配内存
// 使用后立即释放
free(convertedBitmap);
避免因忘记释放内存导致程序泄漏。
2. 光栅操作码(Raster Operation)
• SRCCOPY:直接复制源位图到目标区域,覆盖原有像素(用于黑白层)。
• SRCINVERT:源位图与目标区域像素异或(用于彩色层叠加)。
3. 电子纸特性模拟
• 分层绘制:电子纸通常支持黑白层和彩色层独立更新,此处通过两次 StretchDIBits 调用模拟分层。
• 低刷新率:电子纸实际刷新较慢,但代码中未模拟延迟,仅通过定时器控制界面更新频率。 四、总结 DrawBitmap 函数通过以下步骤实现电子纸显示模拟:
1. 格式适配:将电子纸的位掩码格式转换为 Windows 位图,处理位序和行对齐问题。
2. 分层渲染:先绘制黑白层作为基础,再通过异或操作叠加彩色层(红色)。
3. 资源管理:及时释放内存和设备上下文,确保程序稳定性。 该函数是电子纸模拟器的核心渲染引擎,结合窗口消息处理和用户输入,最终实现了可交互的电子纸界面效果。
相关文章:
墨水屏显示模拟器程序解读
程序如下:出处https://github.com/tsl0922/EPD-nRF5?tabreadme-ov-file // GUI emulator for Windows // This code is a simple Windows GUI application that emulates the display of an e-paper device. #include <windows.h> #include <stdint.h>…...
【图像生成大模型】Step-Video-T2V:下一代文本到视频生成技术
Step-Video-T2V:下一代文本到视频生成技术 引言Step-Video-T2V 项目概述核心技术1. 视频变分自编码器(Video-VAE)2. 3D 全注意力扩散 Transformer(DiT w/ 3D Full Attention)3. 视频直接偏好优化(Video-DPO…...
【Java学习笔记】【第一阶段项目实践】房屋出租系统(面向对象版本)
房屋出租系统(面向对象版本) 整体思想:采用数组存储房屋信息,深刻体会面向对象的好处和过程 一、实现需求 (1)用户层 系统菜单显示 提示用户输入对应的数字选择功能 各个功能界面操作提示(底…...
18. 结合Selenium和YAML对页面继承对象PO的改造
18. 结合Selenium和YAML对页面继承对象PO的改造 一、架构改造核心思路 1.1 改造前后对比 #mermaid-svg-ziagMhNLS5fIFWrx {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-ziagMhNLS5fIFWrx .error-icon{fill:#5522…...
Vue-监听属性
监听属性 简单监听 点击切换名字,来回变更Tom/Jerry,输出 你好,Tom/Jerry 代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><title>监听属性</title><!-- …...
AI写PPT可以用吗?我测试了3款AI写PPT工具,分享感受
上周五临下班,领导突然让我周末赶出一份季度营销报告 PPT,还要求周一晨会展示。看着空荡荡的 PPT 页面,我满心都是绝望 —— 周末不仅泡汤,搞不好还得熬夜到凌晨。好在同部门的前辈给我推荐了几款 AI 写 PPT 工具,没想…...
FreeSWITCH 简单图形化界面43 - 使用百度的unimrcp搞个智能话务台,用的在线的ASR和TTS
FreeSWITCH 简单图形化界面43 - 使用百度的unimrcp搞个智能话务台 0、一个fs的web配置界面预览1、安装unimrcp模块2、安装完成后,配置FreeSWITCH。2.1 有界面的配置2.1.1 mod_unimrcp模块配置2.1.2 mod_unimrcp客户端配置 2.2 无界面的配置 3、呼叫规则4、编写流程4…...
C 语言学习笔记(函数)
内容提要 函数 函数的概述函数的分类函数的定义形参和实参函数的返回值 函数 函数的概述 **函数:**实现一定功能的,独立的代码模块,对于函数的使用,一定是先定义,后使用。 使用函数的优势: ①我们可以…...
数据结构 -- 树形查找(二)平衡二叉树
平衡二叉树 定义 平衡二叉树(AVL树) – 树上的任意一点的左子树和右子树的高度之差不超过1 节点的平衡因子 左子树高-右子树高 平衡二叉树的结点的平衡因子的值只可能是-1、0、1 //平衡二叉树结点 typedef struct AVLNode{int key; //数据域int bal…...
day 29
类装饰器 类有修饰器,他的逻辑:接收一个类,返回一个修改后的类。例如 1. 添加新的方法或属性(如示例中的 log 方法)。 2. 修改原有方法(如替换 __init__ 方法,添加日志)。 3. 甚…...
Java 并发编程
黑马程序员深入学习Java并发编程 进程与线程 预备知识 java8,pom.xml <dependencies><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.10</version></depe…...
windows笔记本连接RKNN3588网络配置解析
这几天拿到了一块RKNN3588的板子,准备做视觉和Ros开发用,但是拿到后就蒙蔽了,不知道怎么ssh连到板子上去,更甚者不知道怎么配置网络让RKNN能够联网更新环境,这里记录一下整个过程。主要包括以下两个内容: 1.adb连接RKNN3588开发 2. 网口连接RKNN更新板子环境开发 adb连…...
C++ asio网络编程(8)处理粘包问题
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 粘包问题一、粘包原因总结: 二、如何处理粘包处理方法 三、完善消息节点MsgNode代码部分细节详解memcpy(_data, &max_len, HEAD_LENGTH);_data…...
【架构美学】Java 访问者模式:解构数据与操作的双重分发哲学
一、模式定义与核心思想 访问者模式(Visitor Pattern)是一种行为型设计模式,其核心目标是将数据操作与数据结构分离。通过定义一个独立的访问者类,使得新增对数据结构中元素的操作时,无需修改元素本身的类结构&#x…...
UE5无法编译问题解决
1. vs编译 2. 删除三个文件夹 参考...
Java可变参数与Collections工具类详解
Java可变参数与Collections工具类详解 一、可变参数(Variable Arguments) 1.1 基本概念 可变参数是Java 5引入的特性,允许在方法中定义数量可变的形参。其核心特点是:形参个数可以动态变化(0个、1个、多个ÿ…...
Git版本管理命令reset
目录 命令 git reset 场景一只回退 工作区代码 场景二回退暂存库与工作区 场景三回退暂存库,工作区,版本库内容 命令 git reset git reset --[soft/mixed(默认)/hard] [文件] soft:只回退版本库中内容 mixed:回退暂存区&…...
改进模糊C均值时序聚类+编码器状态识别!IPOA-FCM-Transformer组合模型
改进模糊C均值时序聚类编码器状态识别!IPOA-FCM-Transformer组合模型 目录 改进模糊C均值时序聚类编码器状态识别!IPOA-FCM-Transformer组合模型效果分析基本描述程序设计参考资料 效果分析 基本描述 1.创新未发表!研究亮点!时序…...
Zookeeper入门(三)
Zookeeper Java 客户端 项目构建 ookeeper 官方的客户端没有和服务端代码分离,他们为同一个jar 文件,所以我们直接引入 zookeeper的maven即可, 这里版本请保持与服务端版本一致,不然会有很多兼容性的问题 1 <dependency>…...
使用Redission来实现布隆过滤器
简述布隆过滤器 布隆过滤器是一种概率型数据结构,它可以用来判断一个元素是否在一个集合中。我们当时使用的是Redisson实现的布隆过滤器。它的底层原理是,先初始化一个比较大的数组,里面存放的是二进制0或1。一开始都是0,当一个k…...
Seata源码—6.Seata AT模式的数据源代理一
大纲 1.Seata的Resource资源接口源码 2.Seata数据源连接池代理的实现源码 3.Client向Server发起注册RM的源码 4.Client向Server注册RM时的交互源码 5.数据源连接代理与SQL句柄代理的初始化源码 6.Seata基于SQL句柄代理执行SQL的源码 7.执行SQL语句前取消自动提交事务的源…...
Spring-Beans的生命周期的介绍
目录 1、Spring核心组件 2、Bean组件 2.1、Bean的定义 2.2、Bean的生命周期 1、实例化 2、属性填充 3、初始化 4、销毁 2.3、Bean的执行时间 2.4、Bean的作用域 3、常见问题解决方案 4、与Java对象区别 前言 关于bean的生命周期,如下所示: …...
目标检测新突破:用MSBlock打造更强YOLOv8
文章目录 YOLOv8的现状与挑战YOLO-MS的MSBlock简介MSBlock的工作原理MSBlock的优势 利用MSBlock改进YOLOv8替换YOLOv8主干网络中的部分模块代码实现:替换CSP模块为MSBlock 在YOLOv8的颈部(Neck)中插入MSBlock代码实现:在颈部区域插…...
[SpringBoot]Spring MVC(4.0)
获取Header 传统获取 header 从 HttpServletRequest 中获取 RequestMapping("/r8")public String r8(HttpServletRequest request) {String userAgent request.getHeader("User-Agent");return "userAgent: "userAgent;}使用浏览器访问后&…...
Linux概述:从内核到开源生态
Linux概述:从内核到开源生态 Linux 是当今计算机领域最核心的开源操作系统内核,其影响力已渗透到服务器、嵌入式设备、云计算甚至超级计算机等各个领域。本章将深入解析Linux的本质、核心架构及其背后的开源哲学。 1. Linux的本质:不只是“操…...
【ubuntu24.04】pycharm 死机结束进程
windows 远程pycharm到ubuntu执行程序 pycharm 在调试过程中,内存耗尽,然后死机了 pycharm 进程 (base) rootk8s-master-pfsrv:/home/zhangbin/下载# ps -ef | grep pycharm root 121245 3230568 0 5月14 pts/8 00:00:00 /bin/bash --rcfile …...
【PRB】深度解析GaN中最浅的受主缺陷
2025 年 1 月 16 日,Virginia Commonwealth University 的 M. A. Reshchikov 和 SUNY–Albany 的 B. McEwen 等人在《Physical Review B》期刊发表了题为《Identity of the shallowest acceptor in GaN》的文章,基于对 50 多个 Be 掺杂 GaN 样品的光致发光实验以及 Heyd-Scus…...
Flink CEP是什么?
Apache Flink 的 CEP(Complex Event Processing,复杂事件处理) 是 Flink 提供的一个库,用于在无界数据流中检测符合特定模式的事件组合。 🎯 一、什么是 CEP? ✅ 定义: CEP 是一种从连续的数据…...
基于STM32的多传感器融合的设施农业小型搬运机器人避障控制系统设计
一、系统总体设计目标 针对设施农业场景中狭窄通道、障碍物多样(如农机具、作物植株、水管)的特点,设计一款基于 STM32 的小型搬运机器人避障控制系统。系统通过多传感器融合实现 360 环境感知,采用模糊 PID 控制算法实现平滑避障,满足温室、大棚等场景的搬运需求。 二、…...
从零开始实现大语言模型(十六):加载开源大语言模型参数
1. 前言 预训练大语言模型的难点不在于算法,而在于数据和算力,绝大多数企业和机构都没有预训练大语言模型的算力资源。在工业界的大语言模型应用实践中,通常会使用领域数据微调开源大语言模型参数,以构建领域大语言模型。 本文介…...
Spark,数据提取和保存
以下是使用 Spark 进行数据提取(读取)和保存(写入)的常见场景及代码示例(基于 Scala/Java/Python,不含图片操作): 一、数据提取(读取) 1. 读取文件数据&a…...
java19
1.集合体系结构 注意: 2.collection遍历之迭代器遍历 一次循环只能一次next方法的原因: 原因:集合长度是单数就报错 3.collection遍历之增强for遍历 如何代码简写呢:集合名.for回车 4.collection遍历之Lambda表达式遍历 5.使用多态…...
从0到1吃透卷积神经网络(CNN):原理与实战全解析
一、开篇:CNN 在 AI 领域的地位 在当今人工智能(AI)飞速发展的时代,卷积神经网络(Convolutional Neural Network,简称 CNN)无疑是深度学习领域中最为耀眼的明星之一 。它就像是 AI 世界里的超级…...
建一个结合双向长短期记忆网络(BiLSTM)和条件随机场(CRF)的模型
构建一个结合双向长短期记忆网络(BiLSTM)和条件随机场(CRF)的模型,通常用于序列标注任务,如命名实体识别(NER)、词性标注(POS Tagging)等。下面我将通过口述的…...
mvc-ioc实现
IOC 1)耦合/依赖 依赖,是谁离不开谁 就比如上诉的Controller层必须依赖于Service层,Service层依赖于Dao 在软件系统中,层与层之间存在依赖。我们称之为耦合 我们系统架构或者设计的一个原则是ÿ…...
符合Python风格的对象(再谈向量类)
再谈向量类 为了说明用于生成对象表示形式的众多方法,我们将使用一个 Vector2d 类,它与第 1 章中的类似。这一节和接下来的几节会不断实 现这个类。我们期望 Vector2d 实例具有的基本行为如示例 9-1 所示。 示例 9-1 Vector2d 实例有多种表示形式 &g…...
4.1.8文件共享
知识总览 基于索引节点的共享方式(硬链接): 让不同用户的文件目录项指向同一个文件的索引节点 用户1创建文件1,并让文件目录项aaa指向了文件1,这个文件对应了一个索引节点,这个索引节点 包含了文件的物理地址和文件的其他属性信…...
[LevelDB]LevelDB版本管理的黑魔法-为什么能在不锁表的情况下管理数据?
文章摘要 LevelDB的日志管理系统是怎么通过双链表来进行数据管理为什么LevelDB能够在不锁表的情况下进行日志新增 适用人群: 对版本管理机制有开发诉求,并且希望参考LevelDB的版本开发机制。数据库相关从业者的专业人士。计算机狂热爱好者,对计算机的…...
普通用户的服务器连接与模型部署相关记录
普通用户的服务器连接与模型部署相关记录 一、从登录到使用自己的conda 1.账号登陆: ssh xxx172.31.226.236 2.下载与安装conda: 下载conda: wget -c https://repo.anaconda.com/archive/Anaconda3-2023.03-1-Linux-x86_64.sh 安装con…...
WebSocket解决方案的一些细节阐述
今天我们来看看WebSocket解决方案的一些细节问题: 实际上,集成WebSocket的方法都有相关的工程挑战,这可能会影响项目成本和交付期限。在最简单的层面上,构建 WebSocket 解决方案似乎是添加接收实时更新功能的前进方向。但是&…...
架构思维:构建高并发扣减服务_分布式无主架构
文章目录 Pre无主架构的任务简单实现分布式无主架构 设计和实现扣减中的返还什么是扣减的返还返还实现原则原则一:扣减完成才能返还原则二:一次扣减可以多次返还原则三:返还的总数量要小于等于原始扣减的数量原则四:返还要保证幂等…...
C++函数基础:定义与调用函数,参数传递(值传递、引用传递)详解
1. 引言 函数是C编程中的核心概念之一,它允许我们将代码模块化,提高代码的可读性、复用性和可维护性。本文将深入探讨: 函数的定义与调用参数传递方式(值传递 vs 引用传递)应用场景与最佳实践 2. 函数的定义与调用 …...
深入解析Python中的Vector2d类:从基础实现到特殊方法的应用
引言 在Python面向对象编程中,特殊方法(或称魔术方法)是实现对象丰富行为的关键。本文将以Vector2d类为例,详细讲解如何通过特殊方法为自定义类添加多种表示形式和操作能力。 Vector2d类的基本行为 Vector2d类是一个二维向量类…...
【25软考网工】第六章(7)网络安全防护系统
博客主页:christine-rr-CSDN博客 专栏主页:软考中级网络工程师笔记 大家好,我是christine-rr !目前《软考中级网络工程师》专栏已经更新三十多篇文章了,每篇笔记都包含详细的知识点,希望能帮助到你&#x…...
Mac下载bilibili视频
安装 安装 yt-dlp brew install yt-dlp安装FFmpeg 用于合并音视频流、转码等操作 brew install ffmpeg使用 下载单个视频 查看可用格式 yt-dlp -F --cookies-from-browser chrome "https://www.bilibili.com/video/BV15B4y1G7F3?spm_id_from333.788.recommend_more_vid…...
6个月Python学习计划:从入门到AI实战(前端开发者进阶指南)
作者:一名前端开发者的进阶日志 计划时长:6个月 每日学习时间:2小时 覆盖方向:Python基础、爬虫开发、数据分析、后端开发、人工智能、深度学习 📌 目录 学习目标总览每日时间分配建议第1月:Python基础与编…...
批量处理 Office 文档 高画质提取图片、视频、音频素材助手
各位办公小能手们!你们有没有遇到过想从 Office 文档里提取图片、音频和视频,却又搞得焦头烂额的情况?今天就给大家介绍一款超厉害的工具——OfficeImagesExtractor! 这货的核心功能那可真是杠杠的!首先是高画质提取&a…...
【甲方安全建设】Python 项目静态扫描工具 Bandit 安装使用详细教程
文章目录 一、工具简介二、工具特点1.聚焦安全漏洞检测2.灵活的扫描配置3.多场景适配4.轻量且社区活跃三、安装步骤四、使用方法场景1:扫描单个Python文件场景2:递归扫描整个项目目录五、结果解读六、总结一、工具简介 Bandit 是由Python官方推荐的静态代码分析工具(SAST)…...
【推荐】新准则下对照会计报表172个会计科目解释
序号 科目名称 对应的会计报表项目 序号 科目名称 对应的会计报表项目 一、资产类 二、负债类 1 1001 库存现金 货币资金 103 2001 短期借款 短期借款 2 1002 银行存款 货币资金 104 2101 交易性金融负债 易性金融负债 3 1012 其他货币资…...
IntelliJ IDEA设置编码集
在IntelliJ IDEA中设置Properties文件的编码格式,主要涉及以下步骤和注意事项: 1. 全局和项目编码设置 打开设置界面:File -> Settings -> Editor -> File Encodings。在Global Encoding和Project Encoding下拉菜单中均选择UT…...