移植live555 上的 rtsp
一、V4L2视频采集模块(完整示例)
#include <linux/videodev2.h>
#include <sys/ioctl.h>
#include <fcntl.h>// 初始化V4L2摄像头
int init_v4l2_camera(const char* dev_path, int width, int height) {int fd = open(dev_path, O_RDWR);if (fd < 0) {perror("Failed to open V4L2 device");return -1;}// 设置视频格式(YUV422)struct v4l2_format fmt = {0};fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;fmt.fmt.pix.width = width;fmt.fmt.pix.height = height;fmt.fmt.pix.pixelformat = V4L2_PIX_FMT_YUYV; // 海思可能要求NV12fmt.fmt.pix.field = V4L2_FIELD_NONE;if (ioctl(fd, VIDIOC_S_FMT, &fmt) < 0) {perror("Failed to set video format");close(fd);return -1;}// 申请视频缓冲区(MMAP方式)struct v4l2_requestbuffers req = {0};req.count = 4;req.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;req.memory = V4L2_MEMORY_MMAP;if (ioctl(fd, VIDIOC_REQBUFS, &req) < 0) {perror("Failed to request buffers");close(fd);return -1;}// 映射缓冲区到用户空间struct v4l2_buffer buf = {0};for (int i = 0; i < req.count; ++i) {buf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;buf.memory = V4L2_MEMORY_MMAP;buf.index = i;if (ioctl(fd, VIDIOC_QUERYBUF, &buf) < 0) {perror("Failed to query buffer");close(fd);return -1;}void* buffer = mmap(NULL, buf.length, PROT_READ | PROT_WRITE, MAP_SHARED, fd, buf.m.offset);// 保存buffer指针...}// 启动视频流enum v4l2_buf_type type = V4L2_BUF_TYPE_VIDEO_CAPTURE;if (ioctl(fd, VIDIOC_STREAMON, &type) < 0) {perror("Failed to start streaming");close(fd);return -1;}return fd; // 返回设备句柄
}
关键点解释:
- 海思平台可能要求输入NV12格式,需根据硬件文档调整
V4L2_PIX_FMT_*
- MMAP方式减少内存拷贝,适合高帧率场景
- 需循环调用
VIDIOC_QBUF
和VIDIOC_DQBUF
获取视频帧
二、海思H.264硬件编码模块
#include "hi_comm_venc.h"
#include "mpi_venc.h"// 初始化海思编码通道
HI_S32 init_hisi_venc(int width, int height, int fps) {HI_S32 s32Ret;VENC_CHN VencChn = 0;VENC_ATTR_S stVencAttr;// 配置编码参数memset(&stVencAttr, 0, sizeof(VENC_ATTR_S));stVencAttr.enType = PT_H264;stVencAttr.stRcAttr.enRcMode = VENC_RC_MODE_H264CBR;stVencAttr.stRcAttr.stH264Cbr.u32Gop = fps * 2; // GOP为2秒stVencAttr.stRcAttr.stH264Cbr.u32BitRate = 2000; // 2000kbpsstVencAttr.stVencAttr.stAttrH264e.u32MaxPicWidth = width;stVencAttr.stVencAttr.stAttrH264e.u32MaxPicHeight = height;stVencAttr.stVencAttr.stAttrH264e.u32PicWidth = width;stVencAttr.stVencAttr.stAttrH264e.u32PicHeight = height;// 创建编码通道s32Ret = HI_MPI_VENC_CreateChn(VencChn, &stVencAttr);if (s32Ret != HI_SUCCESS) {printf("Create VENC channel failed: 0x%x\n", s32Ret);return s32Ret;}// 设置帧率VENC_PARAM_FRMRATE_PARA_S stFrmRate;stFrmRate.stSrcFrmRate.s32FrmRate = fps * 1000; // 以毫秒为单位stFrmRate.stDstFrmRate.s32FrmRate = fps * 1000;HI_MPI_VENC_SetFrmRate(VencChn, &stFrmRate);return HI_SUCCESS;
}// 获取编码后的H.264流
void get_h264_stream(VENC_CHN VencChn, unsigned char** ppBuffer, HI_U32* pSize) {VENC_STREAM_S stStream;HI_S32 s32Ret = HI_MPI_VENC_GetStream(VencChn, &stStream, 2000); // 2秒超时if (s32Ret == HI_SUCCESS) {*ppBuffer = stStream.pstPack[0].pu8Addr;*pSize = stStream.pstPack[0].u32Len;HI_MPI_VENC_ReleaseStream(VencChn, &stStream); // 必须释放}
}
关键点:
- 使用
HI_MPI_VENC_GetStream
非阻塞方式获取码流 - 必须调用
HI_MPI_VENC_ReleaseStream
释放资源,否则会导致内存泄漏 - 海思SDK要求严格的内存对齐,需按照文档配置参数
三、ALSA音频采集与AAC编码
#include <alsa/asoundlib.h>
#include <fdk-aac/aacenc_lib.h>// 初始化ALSA音频采集
snd_pcm_t* init_alsa(const char* device, int sample_rate, int channels) {snd_pcm_t* handle;snd_pcm_hw_params_t* params;if (snd_pcm_open(&handle, device, SND_PCM_STREAM_CAPTURE, 0) < 0) {fprintf(stderr, "ALSA open error\n");return NULL;}snd_pcm_hw_params_malloc(¶ms);snd_pcm_hw_params_any(handle, params);// 设置参数snd_pcm_hw_params_set_access(handle, params, SND_PCM_ACCESS_RW_INTERLEAVED);snd_pcm_hw_params_set_format(handle, params, SND_PCM_FORMAT_S16_LE);snd_pcm_hw_params_set_channels(handle, params, channels);snd_pcm_hw_params_set_rate_near(handle, params, (unsigned int*)&sample_rate, 0);// 应用参数if (snd_pcm_hw_params(handle, params) < 0) {fprintf(stderr, "ALSA set params failed\n");snd_pcm_close(handle);return NULL;}return handle;
}// 初始化AAC编码器
AACENCODER* init_aac_encoder(int sample_rate, int channels) {AACENCODER* hEncoder;if (aacEncOpen(&hEncoder, 0, channels) != AACENC_OK) {return NULL;}// 设置编码参数aacEncoder_SetParam(hEncoder, AACENC_AOT, AOT_AAC_LC);aacEncoder_SetParam(hEncoder, AACENC_SAMPLERATE, sample_rate);aacEncoder_SetParam(hEncoder, AACENC_CHANNELMODE, MODE_2);aacEncoder_SetParam(hEncoder, AACENC_BITRATE, 64000); // 64kbpsif (aacEncEncode(hEncoder, NULL, NULL, NULL, NULL) != AACENC_OK) {aacEncClose(&hEncoder);return NULL;}return hEncoder;
}
四、live555自定义FramedSource实现
#include <liveMedia.hh>class Hi3516VideoSource : public FramedSource {
public:static Hi3516VideoSource* createNew(UsageEnvironment& env, VENC_CHN vencChn) {return new Hi3516VideoSource(env, vencChn);}protected:Hi3516VideoSource(UsageEnvironment& env, VENC_CHN vencChn) : FramedSource(env), mVencChn(vencChn) {}virtual void doGetNextFrame() {// 从海思编码器获取H.264数据unsigned char* pData = nullptr;HI_U32 dataSize = 0;get_h264_stream(mVencChn, &pData, &dataSize);if (dataSize > 0) {if (dataSize > fMaxSize) { // 处理分包fNumTruncatedBytes = dataSize - fMaxSize;dataSize = fMaxSize;}memcpy(fTo, pData, dataSize);fFrameSize = dataSize;// 设置时间戳(使用系统时钟)gettimeofday(&fPresentationTime, NULL);} else {fFrameSize = 0;}// 立即通知框架可以发送数据afterGetting(this);}private:VENC_CHN mVencChn;
};
关键逻辑:
doGetNextFrame()
是live555的核心回调函数,当需要发送数据时自动触发- 时间戳必须转换为RTP时间基准(视频:90000Hz,音频:采样率)
- 若数据超过缓冲区大小,需设置
fNumTruncatedBytes
五、RTSP服务端搭建
#include "liveMedia.hh"
#include "BasicUsageEnvironment.hh"void start_rtsp_server() {TaskScheduler* scheduler = BasicTaskScheduler::createNew();UsageEnvironment* env = BasicUsageEnvironment::createNew(*scheduler);// 创建RTSP服务器(端口554需要root权限)RTSPServer* rtspServer = RTSPServer::createNew(*env, 554, NULL);if (rtspServer == NULL) {*env << "Failed to create RTSP server: " << env->getResultMsg() << "\n";exit(1);}// 创建媒体会话(H.264 + AAC)ServerMediaSession* sms = ServerMediaSession::createNew(*env, "live", "Hi3516 Live Stream", "Session for Hi3516");// 添加视频子会话sms->addSubsession(H264VideoFileServerMediaSubsession::createNew(*env, "dummy", NULL)); // 实际应使用自定义Source// 添加音频子会话(AAC)sms->addSubsession(ADTSAudioFileServerMediaSubsession::createNew(*env, "dummy", NULL));rtspServer->addServerMediaSession(sms);// 打印RTSP URLchar* url = rtspServer->rtspURL(sms);*env << "RTSP URL: " << url << "\n";delete[] url;env->taskScheduler().doEventLoop(); // 进入主循环
}
六、音视频同步策略
// 全局时间戳生成器(单位:微秒)
uint64_t get_ntp_timestamp() {struct timeval tv;gettimeofday(&tv, NULL);return (uint64_t)tv.tv_sec * 1000000 + tv.tv_usec;
}// 在FramedSource中设置时间戳
void Hi3516VideoSource::doGetNextFrame() {// ... 获取数据 ...uint64_t now = get_ntp_timestamp();fPresentationTime.tv_sec = now / 1000000;fPresentationTime.tv_usec = now % 1000000;
}// 音频同步需转换为采样数
uint32_t audio_rtp_timestamp(uint64_t ntp_ts, int sample_rate) {return (uint32_t)((ntp_ts * sample_rate) / 1000000);
}
七、完整流程整合
-
初始化硬件模块
int v4l2_fd = init_v4l2_camera("/dev/video0", 1280, 720); init_hisi_venc(1280, 720, 30); snd_pcm_t* audio_handle = init_alsa("default", 44100, 2); AACENCODER* aac_enc = init_aac_encoder(44100, 2);
-
启动RTSP服务线程
std::thread rtsp_thread(start_rtsp_server); rtsp_thread.detach();
-
主循环采集数据
while (1) {// 视频采集->编码->存入队列struct v4l2_buffer buf = {0};ioctl(v4l2_fd, VIDIOC_DQBUF, &buf);HI_MPI_VENC_SendFrame(vencChn, &raw_frame); // 送入编码器ioctl(v4l2_fd, VIDIOC_QBUF, &buf);// 音频采集->编码->存入队列snd_pcm_readi(audio_handle, pcm_buffer, samples);aacEncEncode(aac_enc, ...); }
八、调试技巧
-
验证视频编码
# 将H.264流保存为文件 ./your_program > test.h264 # 使用ffplay播放 ffplay -f h264 test.h264
-
分析RTSP协议
wireshark -f "tcp port 554 or udp port range 6970-6999"
-
海思SDK调试
HI_MPI_LOG_SetLevel(LOG_LEVEL_DEBUG); // 开启海思SDK日志
通过以上完整实现,您可以在hi3516平台上构建稳定的RTSP音视频服务。实际部署时需根据硬件特性调整缓冲区大小、线程优先级等参数。
相关文章:
移植live555 上的 rtsp
一、V4L2视频采集模块(完整示例) #include <linux/videodev2.h> #include <sys/ioctl.h> #include <fcntl.h>// 初始化V4L2摄像头 int init_v4l2_camera(const char* dev_path, int width, int height) {int fd open(dev_path, O_RD…...
基于SpringBoot的“宠物救助及领养平台”的设计与实现(源码+数据库+文档+PPT)
基于SpringBoot的“宠物救助及领养平台”的设计与实现(源码数据库文档PPT) 开发语言:Java 数据库:MySQL 技术:SpringBoot 工具:IDEA/Ecilpse、Navicat、Maven 系统展示 系统整体功能图 系统首页界面 系统注册页面…...
Gemini 2.0助力科学突破,AI联合科学家系统登场
每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…...
electron提升软件运行权限,以管理员权限运行
大家有任何想法,都可以联系博主沟通。 本系列为实战文章,最终实现的桌面工具软件,获取方式:百度网盘地址:https://pan.baidu.com/s/1yrl0jYpti7QCn8CHBRT2lw?pwd1234 正文开始 前言一、提升electron运行权限的三种方…...
Docker 容器调试技巧
在开发和运维过程中,调试 Docker 容器中的应用或服务是一个常见且重要的任务。由于容器是相互隔离的,容器内部的日志和错误信息可能不像传统的服务器那样直观,因此掌握 Docker 容器调试技巧对于快速定位和解决问题至关重要。 本文将介绍一些…...
TSMaster【第七篇:千机百变——面板设计艺术】
武侠场景导入:唐门暗器阁的启示 江湖传言,唐门暗器之所以独步天下,全凭其「千机匣」中七十二种机关变化。TSMaster面板设计恰似打造暗器机关——控件如同飞镖、机簧、毒针,组合方式不同则威力迥异。昔日某新势力车型因仪表盘刷新…...
ctfshow——robots后台泄露
题目提示:总有人把后台地址写入robots,帮黑阔大佬们引路 题目如上图所示 根据提示,我们可以在URL上查看是否存在robots文件 打开后发现其中的内容如上图所示,存在一个flagishere.txt文件,我们可以继续在URL上进行操作…...
普通人怎样用好Deepseek?
第一章:准备篇(30分钟上手) DeepSeek 是一款功能强大的数据处理和分析工具,广泛应用于数据挖掘、机器学习、商业智能等领域。 本文将通过图文结合的方式,详细介绍 DeepSeek 的安装、配置、基本使用、高级功能以及实用…...
负载均衡集群( LVS 相关原理与集群构建 )
目录 1、LVS 相关原理 1.1、LVS集群的体系结构以及特点 1.1.1 LVS简介 1.1.2 LVS体系结构 1.1.3 LVS相关术语 1.1.4 LVS工作模式 1.1.5 LVS调度算法 1.2 LVS-DR集群介绍 1.2.1 LVS-DR模式工作原理 1.2.2 LVS-DR模式应用特点 1.2.3 LVS-DR模式ARP抑制 1.3 LVS – NA…...
前端面试-JavaScript 数据类型检测全解
目录 一、基础检测方法 二、方法深度解析 1. typeof 运算符 2. instanceof 运算符 3. 终极检测方案 三、特殊场景检测方案 四、手写实现原理 1. 通用类型检测函数 2. 改进版数组检测(兼容旧浏览器) 五、常见面试陷阱 六、最佳实践指南 七、扩…...
百度百舸 DeepSeek 一体机发布,支持昆仑芯 P800 单机 8 卡满血版开箱即用
在私有云环境中成功部署 DeepSeek 满血版并实现性能调优,并不是一件容易的事情。选择合适的 GPU 配置、安装相应的环境、成功部署上线业务、加速推理任务加速、支撑多用户并发 …… 完成业务测试,成功融入生产业务中。 为了帮助企业快速实现 DeepSeek 服…...
微软CEO-纳德拉访谈-AGI计划
在与知名科技播客主播 Dwarkesh Patel 的深度访谈中,微软 CEO 萨提亚・纳德拉围绕 AI、量子计算、微软发展等多方面分享深刻见解,下面是针对访谈内容的介绍,其中还是有很多值得我们学习的地方。 1 AI 领域见解 影响力评估:纳德拉直言行业所标榜的 AGI 里程碑是 “无意义的基…...
Web自动化中Selenium下Chrome与Edge的Webdriver常用Options参数
目录 引言 说明 Add_argument() 添加方式 常用参数 Add_experimental_option() 添加方式 常用方法 任务结束后仍然保持浏览器打开 禁用“Chrome 正受到自动测试软件的控制”提示 设置下载路径 禁用弹窗拦截 禁用图片加载 禁用 JavaScript 注意 引言 …...
1.4 嵌入式系统的软件
嵌入式系统的开发流程中,硬件和固件设计完成后,嵌入式软件承担起实现功能、用户交互、系统集成和性能优化等任务;嵌入式系统软件分为设备驱动、操作系统和应用程序三个层面。 因此嵌入式系统软件开发工程师通常分为三类:嵌入式系统…...
深蓝学院自主泊车第3次作业-IPM
目录 1 题目介绍2 求解 1 题目介绍 已知鱼眼相机的参数, image_width,表示图像的宽度image_height,表示图像的高度 ξ \xi ξ,表示鱼眼相机参数 k 1 k_1 k1、 k 2 k_2 k2,表示径向相机参数 p 1 p_1 p1、 p 2 p…...
Confluence 8.5.18 - windows 安装部署详解
本文我们所讲述的是Confluence - 8.5.18 -windows版本版本的详细安装破解步骤,与Confluence - 8.0.0之前的版本不同的是,部分文件名称发生了变化,以前的破解方式已不适用。 1.首先我们先准备安装所需要的文件 atlassian-confluence-8.5.18-x64.exemysql-connector-java-8.0…...
深入解析过滤器模式:数据筛选与处理的高效工具
过滤器模式:数据筛选与处理的高效工具 在软件开发的复杂领域中,数据的筛选与处理是常见的任务。过滤器模式作为一种实用的设计模式,为解决这类问题提供了有效的解决方案。它允许开发者根据不同的标准对一组对象进行过滤操作,从而…...
linux常用基础命令_最新版
常用命令 查看当前目录下个各个文件大小查看当前系统储存使用情况查看当前路径删除当前目录下所有包含".log"的文件linux开机启动jar更改自动配置文件后操作关闭自启动linux静默启动java服务查询端口被占用查看软件版本重启关机开机启动取别名清空当前行创建文件touc…...
曝光铁三角
一、曝光铁三角的关系解析 光圈(Aperture) 作用:控制光线进入相机的孔径大小,同时影响景深(画面清晰范围)。 数值规则:光圈值(如F/1.8、F/8)越小,孔径越大&am…...
reacct hook useState
useState useState 是一个 React Hook,允许函数组件在内部管理状态。 使用方法 let [str,setStr] useState(‘three’) useState接受的参数为初始值;返回一个数组 第一个元素:当前的状态值;第二个元素:一个更新该状…...
政安晨【零基础玩转各类开源AI项目】DeepSeek 多模态大模型Janus-Pro-7B,本地部署!支持图像识别和图像生成
政安晨的个人主页:政安晨 欢迎 👍点赞✍评论⭐收藏 希望政安晨的博客能够对您有所裨益,如有不足之处,欢迎在评论区提出指正! 目录 下载项目 创建虚拟环境 安装项目依赖 安装 Gradio(UI) 运…...
计算机毕业设计SpringBoot+Vue.js学生读书笔记共享(源码+LW文档+PPT+讲解+开题报告)
温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…...
QEMU源码全解析 —— 内存虚拟化(17)
接前一篇文章:QEMU源码全解析 —— 内存虚拟化(16) 本文内容参考: 《趣谈Linux操作系统》 —— 刘超,极客时间 《...
Maven 构建中的安全性与合规性检查
在现代软件开发中,确保应用程序的安全性和合规性至关重要。随着开源软件和第三方依赖的广泛使用,构建过程中对依赖的安全性和合规性检查变得尤为重要。通过 Maven 构建工具,我们可以集成多种安全性和合规性检查机制,帮助开发者检测…...
Deepseek R1 和其他的大模型 共同辅助决策交通出行方案
比一比各家大模型 问题描述一、Deepseek R1通勤方式评估报告(一)评分模型说明(二)各选项评分明细(三)加权总分计算(四)结论 二、文心一言通勤方式评估(一)时间…...
HTTPS 通信流程
HTTPS 通信流程时序图: #mermaid-svg-HWoTbFvfih6aYUu6 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-HWoTbFvfih6aYUu6 .error-icon{fill:#552222;}#mermaid-svg-HWoTbFvfih6aYUu6 .error-text{fill:#…...
C++——list模拟实现
目录 前言 一、list的结构 二、默认成员函数 构造函数 析构函数 clear 拷贝构造 赋值重载 swap 三、容量相关 empty size 四、数据访问 front/back 五、普通迭代器 begin/end 六、const迭代器 begin/end 七、插入数据 insert push_back push_front 八、…...
开发指南103-jpa的find**/get**全解
平台使用jpa来访问数据库。在dao层可以通过定义find**/get**函数,通过名字直接绑定数据库字段。find**和get**有一定区别: 1.get**方法查询不到数据抛出异常,find**方法查询不到数据则返回null。 2.get**是延迟加载,在真正访问返…...
初学者如何设置以及使用富文本编辑器[eclipse版]
手把手教你设置富文本编辑器 参考来源:UEditor Docs 初学者按我的步骤来就可以啦 一、设置ueditor编辑器 1.提取文件[文章最底部有链接提取方式] 2.解压文件并放到自己项目中,在WebContent目录下: 3. 修改jar包位置路径 到--> 注意&a…...
Flutter 启动优化
Dart VM在Flutter中的作用是什么?它负责执行Dart代码,无论是JIT还是AOT模式都需要它。在JIT模式下,VM随应用一起运行,而在AOT模式下,代码已经被编译成机器码,VM可能不需要运行时存在?不过实际上…...
Java Idea配置问题
在 cmd 里手动切换: set JAVA_HOMEC:\Program Files\Java\jdk1.8.0_192 set PATH%JAVA_HOME%\bin;%PATH%在Idea的终端查看: java -versionClass com.sun.tools.javac.tree.JCTree$JCImport does not have member field ‘com.sun.tools.javac.tre JDK 版本不匹配 …...
百度搜索,能否将DeepSeek变成“内功”?
最近,所有的云平台和主流APP都在努力接入DeepSeek。其中,搜索类APP与搜索引擎更是“战况激烈”。那么问题来了,接入DeepSeek已经变成了标准配置,到底应该如何做出差异化?接入DeepSeek这件事能不能实现11大于2的效果&am…...
【C++委托与事件】函数指针,回调机制,事件式编程与松耦合的设计模式(上)
前言 上一次发文章已经是在两个月前了hhh,期间也是忙忙碌碌做了不少事情也鸽了不少东西… 本文我们来讲讲博主最近在项目中频繁使用的,也就是广泛运用于C#或者Java的一个常用编程机制(思路)-----委托和事件。由于C在语言特性上没…...
【Java学习】抽象类与接口
面向对象系列四 一、抽象方法 二、抽象类 三、意义检查 1.抽象方法的意义 2.意义检查 体现 四、接口 1.级别层次 2.接口变量 3.意义 4.成员 成员变量: 成员方法: 一、抽象方法 没有方法体即没有任何实现的方法是抽象方法,只有在…...
体育电竞比分网开发流程
开发一个体育电竞比分网的流程可以分为以下几个主要步骤: 1. 需求分析 目标用户:确定网站的主要用户群体,如体育迷、电竞爱好者等。 功能需求:列出网站需要实现的功能,如实时比分更新、赛事日程、新闻资讯、用户评论…...
vue2和vue3的主要区别
Vue 2 和 Vue 3 之间有几个主要区别,涉及到性能、功能和架构上的改进。以下是一些核心的区别: Composition API(组合式 API): Vue 2 使用的是选项式 API(Options API),即通过 data, …...
粘贴到Word里的图片显示不全
粘贴到Word里的图片显示不全,可从Word设置、图片本身、软件与系统等方面着手解决,具体方法如下: Word软件设置 经实践发现,图片在word行距的行距出现问题,可以按照如下调整行距进行处理 修改段落行距: 选…...
直角三角堰计算公式
直角三角堰的计算公式通常用于确定流经直角三角形形状的堰的流量。河北瑾航科技遥测终端机 通过采集液位数据(模拟量、串口485/232),计算得到瞬时流量,然后通过积分进行累计算出累积量;直角三角堰的流量计算公式为: 直角三角堰 计…...
细说Java 引用(强、软、弱、虚)和 GC 流程(一)
一、引用概览 1.1 引用简介 JDK1.2中引入了 Reference 抽象类及其子类,来满足不同场景的 JVM 垃圾回收工作: SoftReference 内存不足,GC发生时,引用的对象(没有强引用时)会被清理;高速缓存使用…...
C++,设计模式,【工厂方法模式】
文章目录 如何用汽车生产线理解工厂方法模式?一、传统生产方式的困境二、工厂方法模式解决方案三、模式应用场景四、模式优势分析五、现实应用启示✅C++,设计模式,【目录篇】 如何用汽车生产线理解工厂方法模式? 某个早晨,某车企CEO看着会议室里堆积如面的新车订单皱起眉…...
分布式之分布式ID
目录 需求 1. 全局唯一性 2. 高性能 3. 高可用性 4. 可扩展性 5. 有序性 6. 时间相关 7. 长度适中 8. 安全性 9. 分布式一致性 10. 易于集成 常见解决方案 选择依据 数据库号段模式 核心概念 工作流程 优点 缺点 实现示例 优化策略 适用场景 Snowflake雪…...
Innovus中快速获取timing path逻辑深度的golden脚本
在实际项目中我们经常会遇到一条timing path级数特别多,可能是一两页都翻不完。此时,我们大都需要手工去数这条path上到底有哪些是设计本身的逻辑,哪些是PR工具插入的buffer和inverter。 数字IC后端手把手培训教程 | Clock Gating相关clock …...
tortoiseGit的使用和上传拉取
tortoiseGit的使用和上传拉取 下载TortoiseGit 通过网盘分享的文件:tortoiseGit.zip 链接: https://pan.baidu.com/s/1EOT_UsM9_OysRqXa8gES4A?pwd1234 提取码: 1234 在电脑桌面新建文件夹并进入 右击鼠标 将网址复制上去 用户名和密码是在git注册的用户名和…...
简单工厂模式 (Simple Factory Pattern) 在Spring Boot 中的应用
简单工厂模式(Simple Factory Pattern)虽然不属于 GoF 23 种经典设计模式,但在实际开发中非常常用,尤其是在 Spring Boot 项目中。它提供了一种简单的方式来创建对象,将对象的创建逻辑集中到一个工厂类中。 一、简单工…...
前端排序算法完全指南:从理论到实践
<!DOCTYPE html> <html> <head><title>前端排序算法终极指南</title><style>.container { max-width: 1000px; margin: 0 auto; padding: 20px; }.demo-container { margin: 30px 0; border: 1px solid #eee; padding: 20px; }.bars-wrapp…...
【LeetCode Hot100 矩阵】矩阵置零、螺旋矩阵、旋转图像、搜索二维矩阵II
矩阵 1. 矩阵置零(Set Matrix Zeroes)解题思路步骤: 代码实现 2. 螺旋矩阵(Spiral Matrix)解题思路具体步骤: 代码实现 3. 旋转矩阵 90 度解决思路代码实现 5. 搜索二维矩阵中的目标值解决思路代码实现 1. …...
最新版IDEA下载安装教程
一、下载IDEA 点击前往官网下载 或者去网盘下载 点击前往百度网盘下载 点击前往夸克网盘下载 进去后点击IDEA 然后点击Download 选择自己电脑对应的系统 点击下载 等待下载即可 二、安装IDEA 下载好后双击应用程序 点击下一步 选择好安装目录后点击下一步 勾选这两项后点击…...
Embedding模型
检索的方式有那些 关键字搜索:通过用户输入的关键字来查找文本数据。 语义搜索:它的目标是理解用户查询的真实意图,不仅考虑关键词的匹配,还考虑词汇之间的语义 (文字,语音,语调...࿰…...
WSL进阶使用指南
WSL2通过 Hyper-V 技术创建了一个轻量级的虚拟机(VM),在这个虚拟机之上可以运行一个真正的 Linux 内核,这给希望同时使用 Windows 和 Linux 的开发人员提供了无缝高效的体验。本文会介绍一些使用WSL的知识,帮助你更好地…...
JavaScript函数-函数的参数
在JavaScript编程语言中,函数是组织代码和实现复杂逻辑的基本单元。而函数参数则是这些功能的重要组成部分,它们允许我们将数据传递给函数,从而使得函数更加通用和灵活。本文将深入探讨JavaScript函数参数的各种特性及其最佳实践。 参数基础…...