当前位置: 首页 > article >正文

QListWidget的函数,信号介绍

前言

Qt版本:6.8.0

该类用于列表模型/视图

QListWidgetItem函数介绍

作用

在这里插入图片描述

QListWidget是Qt框架中用于管理可交互列表项的核心组件,主要作用包括:

  1. 列表项管理
  • 支持动态添加/删除项:addItem(), takeItem()
  • 批量操作:addItems()添加多个项
  • 排序功能:sortItems()自动排序
  1. 交互功能
# 创建列表控件
list_widget = QListWidget()# 添加图标项
list_widget.addItem(QListWidgetItem(QIcon("icon.png"), "带图标的项"))# 信号处理
list_widget.itemClicked.connect(handle_click)
  1. 显示控制
  • 支持多种视图模式:setViewMode(QListView.IconMode)
  • 自定义项样式:通过setItemWidget()嵌入自定义控件
  • 调整布局:setFlow(QListView.LeftToRight)控制排列方向
  1. 数据绑定
  • 直接存取项数据:item.text()
  • 关联数据结构:setCurrentRow()同步选择状态

典型应用场景

  • 文件选择列表
  • 配置选项面板
  • 聊天消息记录
  • 可拖拽排序的任务列表

与QListView的区别在于:QListWidget提供了更简便的item-based API,适合快速开发;而QListView需要配合Model/View架构,适合处理复杂数据关系。

公共函数

构造函数与析构函数

QListWidget(QWidget *parent = nullptr)
  • 功能:创建列表控件
  • 参数
    • parent:父窗口指针(可选)
  • 示例
    QListWidget *listWidget = new QListWidget(this);  // 创建列表控件
    
virtual ~QListWidget()
  • 功能:析构函数,释放资源

基础操作函数

void addItem(QListWidgetItem *item)
  • 功能:添加自定义项到列表末尾
  • 参数
    • item:要添加的列表项指针
  • 示例
    QListWidgetItem *item = new QListWidgetItem("New Item");
    listWidget->addItem(item);  // 添加项到列表末尾
    
void addItem(const QString &label)
  • 功能:直接通过文本添加项到列表末尾
  • 参数
    • label:项显示的文本
  • 示例
    listWidget->addItem("Simple Item");  // 直接添加文本项
    
void addItems(const QStringList &labels)
  • 功能:批量添加多个文本项到列表末尾
  • 参数
    • labels:字符串列表
  • 示例
    QStringList items = {"Item1", "Item2", "Item3"};
    listWidget->addItems(items);  // 批量添加
    

编辑与查找

void closePersistentEditor(QListWidgetItem *item)
  • 功能:关闭项的持久编辑器
  • 参数
    • item:需要关闭编辑器的项
  • 示例
    listWidget->closePersistentEditor(item);  // 关闭指定项的编辑器
    
int count() const
  • 功能:返回列表项的个数
  • 返回值:整数型数量
  • 示例
    int total = listWidget->count();  // 获取总项数
    
QListWidgetItem *currentItem() const
  • 功能:返回当前选中的项
  • 返回值:项指针(未选中时返回 nullptr
  • 示例
    QListWidgetItem *current = listWidget->currentItem();
    if (current) qDebug() << "当前选中项:" << current->text();
    
int currentRow() const
  • 功能:返回当前选中项的行号(从 0 开始)
  • 返回值:行号(未选中返回 -1)
  • 示例
    int row = listWidget->currentRow();  // 获取当前行号
    

项管理

void editItem(QListWidgetItem *item)
  • 功能:启动指定项的编辑模式
  • 参数
    • item:要编辑的项
  • 示例
    listWidget->editItem(item);  // 进入编辑模式
    
QList<QListWidgetItem *> findItems(const QString &text, Qt::MatchFlags flags) const
  • 功能:根据匹配规则查找项
  • 参数
    • text:要匹配的文本
    • flags:匹配规则(如 Qt::MatchExactly
  • 返回值:符合条件的项列表
  • 示例
    auto items = listWidget->findItems("Test", Qt::MatchContains);  // 查找包含"Test"的项
    
QModelIndex indexFromItem(const QListWidgetItem *item) const
  • 功能:获取项的模型索引
  • 参数
    • item:目标项
  • 返回值:对应的 QModelIndex
  • 示例
    QModelIndex index = listWidget->indexFromItem(item);  // 获取索引
    

插入与移除

void insertItem(int row, QListWidgetItem *item)
  • 功能:在指定行插入自定义项
  • 参数
    • row:插入位置(0-based)
    • item:要插入的项
  • 示例
    QListWidgetItem *newItem = new QListWidgetItem("Inserted");
    listWidget->insertItem(2, newItem);  // 插入到第三行
    
void insertItem(int row, const QString &label)
  • 功能:在指定行插入文本项
  • 参数
    • row:插入位置
    • label:项文本
  • 示例
    listWidget->insertItem(0, "First Item");  // 插入到第一行
    
void insertItems(int row, const QStringList &labels)
  • 功能:在指定行批量插入多个文本项
  • 参数
    • row:起始行号
    • labels:要插入的文本列表
  • 示例
    listWidget->insertItems(1, {"A", "B", "C"});  // 从第二行开始插入
    

状态检查

bool isPersistentEditorOpen(QListWidgetItem *item) const
  • 功能:检查项是否处于持久编辑状态
  • 返回值true 表示编辑器已打开
  • 示例
    if (listWidget->isPersistentEditorOpen(item)) {// 处理编辑器已打开的情况
    }
    
bool isSortingEnabled() const
  • 功能:检查是否启用了自动排序
  • 返回值true 表示启用排序
  • 示例
    bool sorted = listWidget->isSortingEnabled();
    

项操作

QListWidgetItem *item(int row) const
  • 功能:获取指定行的项
  • 参数
    • row:行号
  • 返回值:项指针(无效行返回 nullptr
  • 示例
    QListWidgetItem *item = listWidget->item(3);  // 获取第四行的项
    
QListWidgetItem *itemAt(const QPoint &p) const
  • 功能:获取指定坐标处的项(相对列表控件)
  • 参数
    • p:坐标点
  • 返回值:项指针(无项返回 nullptr
  • 示例
    QListWidgetItem *item = listWidget->itemAt(QPoint(50, 100));  // 获取(50,100)处的项
    
QListWidgetItem *itemFromIndex(const QModelIndex &index) const
  • 功能:从模型索引获取项
  • 参数
    • index:模型索引
  • 返回值:对应的项指针
  • 示例
    QListWidgetItem *item = listWidget->itemFromIndex(index);
    

部件管理

QWidget *itemWidget(QListWidgetItem *item) const
  • 功能:获取项上设置的部件
  • 参数
    • item:目标项
  • 返回值:部件指针(未设置返回 nullptr
  • 示例
    QWidget *widget = listWidget->itemWidget(item);  // 获取自定义部件
    
void openPersistentEditor(QListWidgetItem *item)
  • 功能:为项打开持久编辑器(始终可编辑)
  • 示例
    listWidget->openPersistentEditor(item);  // 启用持久编辑
    
void removeItemWidget(QListWidgetItem *item)
  • 功能:移除项上的自定义部件
  • 示例
    listWidget->removeItemWidget(item);  // 移除部件
    

布局与选择

int row(const QListWidgetItem *item) const
  • 功能:返回项的行号
  • 参数
    • item:目标项
  • 返回值:行号(无效项返回 -1)
  • 示例
    int row = listWidget->row(item);  // 获取项的行号
    
QList<QListWidgetItem *> selectedItems() const
  • 功能:返回所有选中的项
  • 返回值:选中项列表
  • 示例
    auto selected = listWidget->selectedItems();  // 获取所有选中项
    

设置当前项

void setCurrentItem(QListWidgetItem *item)
  • 功能:设置当前选中项
  • 参数
    • item:目标项
  • 示例
    listWidget->setCurrentItem(item);  // 选中指定项
    
void setCurrentItem(QListWidgetItem *item, QItemSelectionModel::SelectionFlags command)
  • 功能:带选择模式的设置当前项
  • 参数
    • item:目标项
    • command:选择模式(如 QItemSelectionModel::Select
  • 示例
    listWidget->setCurrentItem(item, QItemSelectionModel::Toggle);  // 切换选中状态
    

排序与清理

void setSortingEnabled(bool enable)
  • 功能:启用/禁用自动排序
  • 参数
    • enabletrue 启用排序
  • 示例
    listWidget->setSortingEnabled(true);  // 启用自动排序
    
void sortItems(Qt::SortOrder order = Qt::AscendingOrder)
  • 功能:手动排序所有项
  • 参数
    • order:排序顺序(升序/降序)
  • 示例
    listWidget->sortItems(Qt::DescendingOrder);  // 降序排列
    

其他功能

QListWidgetItem *takeItem(int row)
  • 功能:移除并返回指定行的项
  • 参数
    • row:行号
  • 返回值:被移除的项指针(需手动管理内存)
  • 示例
    QListWidgetItem *removed = listWidget->takeItem(2);  // 移除第三行项
    delete removed;  // 手动释放内存
    
QRect visualItemRect(const QListWidgetItem *item) const
  • 功能:返回项在视图中的可视区域
  • 示例
    QRect rect = listWidget->visualItemRect(item);  // 获取项的位置和大小
    

重写的函数

virtual void setSelectionModel(QItemSelectionModel *selectionModel) override
  • 功能:设置自定义选择模型(高级用法)
  • 参数
    • selectionModel:自定义选择模型
  • 注意:通常不需要直接使用

公共槽函数

void clear()
  • 功能:清空所有项
  • 示例
    listWidget->clear();  // 清空列表
    
void scrollToItem(const QListWidgetItem *item, QAbstractItemView::ScrollHint hint = EnsureVisible)
  • 功能:滚动到指定项
  • 参数
    • item:目标项
    • hint:滚动策略(如 PositionAtTop
  • 示例
    listWidget->scrollToItem(item, QAbstractItemView::PositionAtCenter);  // 滚动到项并居中
    

信号

1. void currentItemChanged(QListWidgetItem *current, QListWidgetItem *previous)

  • 触发时机:当前选中的项发生改变时(例如点击新项、通过代码设置选中项)
  • 参数
    • current:新选中的项指针(未选中时为 nullptr
    • previous:之前选中的项指针(首次选中时为 nullptr
  • 典型用途:跟踪焦点项变化,更新界面状态
  • 示例
    connect(listWidget, &QListWidget::currentItemChanged, [](QListWidgetItem *current, QListWidgetItem *prev) {if (current) qDebug() << "选中了:" << current->text();if (prev)    qDebug() << "取消选中:" << prev->text();
    });
    

2. void currentRowChanged(int currentRow)

  • 触发时机:当前选中项的行号发生变化时
  • 参数
    • currentRow:新选中项的行号(从 0 开始,未选中时为 -1)
  • 典型用途:通过行号操作数据
  • 示例
    connect(listWidget, &QListWidget::currentRowChanged, [](int row) {qDebug() << "当前行号:" << row;});
    

3. void currentTextChanged(const QString &currentText)

  • 触发时机:当前选中项的文本发生改变(包括切换选中项或直接修改项文本)
  • 参数
    • currentText:新选中项的文本内容(未选中时为空字符串)
  • 典型用途:实时监控选中项的文本变化
  • 示例
    connect(listWidget, &QListWidget::currentTextChanged, [](const QString &text) {qDebug() << "当前文本:" << text;});
    

4. void itemActivated(QListWidgetItem *item)

  • 触发时机:用户通过 双击回车键 激活项时
  • 参数
    • item:被激活的项指针
  • 典型用途:实现双击打开/执行操作
  • 示例
    connect(listWidget, &QListWidget::itemActivated, [](QListWidgetItem *item) {qDebug() << "激活项:" << item->text();});
    

5. void itemChanged(QListWidgetItem *item)

  • 触发时机:项的 数据 发生改变(如文本、图标、复选框状态等)
  • 参数
    • item:被修改的项指针
  • 典型用途:同步数据到模型或数据库
  • 示例
    connect(listWidget, &QListWidget::itemChanged, [](QListWidgetItem *item) {qDebug() << "项被修改:" << item->text();});
    

6. void itemClicked(QListWidgetItem *item)

  • 触发时机:用户 单击 项时(即使项已被选中)
  • 参数
    • item:被点击的项指针
  • 典型用途:实现点击交互逻辑
  • 示例
    connect(listWidget, &QListWidget::itemClicked, [](QListWidgetItem *item) {qDebug() << "单击了:" << item->text();});
    

7. void itemDoubleClicked(QListWidgetItem *item)

  • 触发时机:用户 双击 项时
  • 参数
    • item:被双击的项指针
  • 典型用途:快速执行操作(如打开文件)
  • 示例
    connect(listWidget, &QListWidget::itemDoubleClicked, [](QListWidgetItem *item) {openFile(item->text()); // 自定义函数});
    

8. void itemEntered(QListWidgetItem *item)

  • 触发时机:鼠标 悬停进入 项的区域时
  • 参数
    • item:被悬停的项指针
  • 典型用途:显示工具提示或高亮效果
  • 示例
    connect(listWidget, &QListWidget::itemEntered, [](QListWidgetItem *item) {QToolTip::showText(QCursor::pos(), item->text());});
    

9. void itemPressed(QListWidgetItem *item)

  • 触发时机:用户 按下鼠标按钮 在项上时(在释放前触发)
  • 参数
    • item:被按下的项指针
  • 典型用途:实现拖拽操作的起点判断
  • 示例
    connect(listWidget, &QListWidget::itemPressed, [](QListWidgetItem *item) {qDebug() << "按下项:" << item->text();});
    

10. void itemSelectionChanged()

  • 触发时机:选中项集合发生改变时(适用于多选模式)
  • 参数:无
  • 典型用途:处理多选操作后的批量处理
  • 示例
    connect(listWidget, &QListWidget::itemSelectionChanged, [=]() {auto selected = listWidget->selectedItems();qDebug() << "已选中项数:" << selected.size();});
    

信号对比表

信号名称触发动作传递参数适用场景
currentItemChanged选中项改变新旧项指针焦点跟踪
currentRowChanged选中行改变行号行号相关操作
currentTextChanged选中项文本变化新文本文本监控
itemActivated双击/回车激活被激活的项执行默认操作
itemChanged项数据修改被修改的项数据同步
itemClicked单击项被点击的项简单交互
itemDoubleClicked双击项被双击的项快速操作
itemEntered鼠标悬停进入项区域被悬停的项提示信息
itemPressed按下鼠标按钮被按下的项拖拽起点判断
itemSelectionChanged选中项集合变化(多选模式)批量操作

使用建议

  1. 避免信号循环:在槽函数中修改项数据时,注意不要触发自身信号(例如在 itemChanged 中再次修改项)
  2. 性能优化:对高频信号(如 itemEntered)进行防抖处理
  3. 多选模式:使用 itemSelectionChanged 配合 selectedItems() 获取所有选中项
  4. 数据同步:优先使用 itemChanged 而非 currentTextChanged 跟踪数据变化,后者仅监控当前项

其他函数

在这里插入图片描述

示例

#include <QApplication>
#include <QListWidget>
#include <QListWidgetItem>
#include <QIcon>
#include <QMessageBox>int main(int argc, char *argv[])
{QApplication app(argc, argv);// 创建 QListWidgetQListWidget listWidget;listWidget.setWindowTitle("QListWidgetItem 示例");listWidget.resize(400, 300);// 1. 添加普通文本项QListWidgetItem *item1 = new QListWidgetItem("普通文本项");listWidget.addItem(item1);// 2. 添加带图标和文本的项QIcon icon(":/icon.png"); // 请确保有合适的图标资源QListWidgetItem *item2 = new QListWidgetItem(icon, "带图标的项");listWidget.addItem(item2);// 3. 添加带复选框的项QListWidgetItem *item3 = new QListWidgetItem("带复选框的项");item3->setFlags(item3->flags() | Qt::ItemIsUserCheckable);item3->setCheckState(Qt::Unchecked);listWidget.addItem(item3);// 4. 添加带自定义数据、颜色和提示的项QListWidgetItem *item4 = new QListWidgetItem("自定义项");item4->setData(Qt::UserRole, 12345); // 存储自定义数据item4->setBackground(Qt::yellow);item4->setForeground(Qt::blue);item4->setToolTip("这是一个带有自定义数据和颜色的项");listWidget.addItem(item4);// 5. 添加只读项QListWidgetItem *item5 = new QListWidgetItem("只读项");item5->setFlags(item5->flags() & ~Qt::ItemIsEditable);listWidget.addItem(item5);// 6. 响应点击,显示项的详细信息QObject::connect(&listWidget, &QListWidget::itemClicked, [&](QListWidgetItem *item){QString info;info += "文本: " + item->text() + "\n";info += "是否选中: " + QString(item->isSelected() ? "是" : "否") + "\n";info += "复选框状态: ";if (item->flags() & Qt::ItemIsUserCheckable)info += (item->checkState() == Qt::Checked ? "已选中" : "未选中");elseinfo += "无";info += "\n";info += "自定义数据: " + item->data(Qt::UserRole).toString() + "\n";info += "提示: " + item->toolTip() + "\n";QMessageBox::information(&listWidget, "项信息", info);});listWidget.show();return app.exec();
}

相关文章:

QListWidget的函数,信号介绍

前言 Qt版本:6.8.0 该类用于列表模型/视图 QListWidgetItem函数介绍 作用 QListWidget是Qt框架中用于管理可交互列表项的核心组件&#xff0c;主要作用包括&#xff1a; 列表项管理 支持动态添加/删除项&#xff1a;addItem(), takeItem()批量操作&#xff1a;addItems()…...

Python类属性与实例属性的覆盖机制:从Vector2d案例看灵活设计

类属性与实例属性的交互机制 Python中类属性与实例属性的关系体现了语言的动态特性。当访问一个实例属性时&#xff0c;Python会首先查找实例自身的__dict__&#xff0c;如果找不到&#xff0c;才会去查找类的__dict__。这种机制使得类属性可以优雅地作为实例属性的默认值。 …...

QML与C++交互2

在QML与C的交互中&#xff0c;主要有两种方式&#xff1a;在C中调用QML的方法和在QML中调用C的方法。以下是具体的实现方法。 在C中调用QML的方法 首先&#xff0c;我们需要在QML文件中定义一个函数&#xff0c;然后在C代码中调用它。 示例 //QML main.qml文件 import QtQu…...

EtherNet/IP机柜内解决方案在医疗控制中心智能化的应用潜能和方向分析

引言 在数智化转型浪潮席卷各行各业的今天,医疗领域同样面临着提升运营效率、改善患者体验和加强系统可靠性的多重挑战。Rockwell Automation于2025年5月20日推出的EtherNet/IP机柜内解决方案,为医疗中心的自动化升级提供了一种创新路径。本报告将深入分析这一解决方案的核心…...

springboot中各模块间实现bean之间互相调用(service以及自定义的bean)

springboot中各模块间实现bean之间互相调用&#xff08;service以及自定义的bean&#xff09; https://blog.csdn.net/qq_29477175/article/details/122827446?ops_request_misc&request_id&biz_id102&utm_termspringboot%E5%A4%9A%E6%A8%A1%E5%9D%97%E4%B9%8B%E…...

RabbitMQ 可靠性保障:消息确认与持久化机制(二)

四、持久化机制&#xff1a;数据安全的护盾 &#xff08;一&#xff09;交换机持久化 交换机持久化是确保消息路由稳定的重要保障 。在 RabbitMQ 中&#xff0c;交换机负责接收生产者发送的消息&#xff0c;并根据路由规则将消息路由到相应的队列 。如果交换机在 RabbitMQ 重…...

QML学习07Property

Property 1、Property1.1 定义控件1.2 给控件取别名&#xff0c;不向外暴露控件名字 2、总结 1、Property property int myTopMargin: 0 property int myBottomMargin: 0 property real myReal: 0.0 //双精度浮点数 property string myString: "test" property…...

Skywalking安装部署使用教程

目录 核心功能 架构设计 安装与配置 使用场景 社区与支持 总结 官网 https:///apache/skywalking 部署Skywalking 添加报警配置 自定义告警规则如果您需要自定义告警规则,则需要编辑 alarm-settings.yml 文件并添加自定义的规则。具体来说,您需要按照 YAML 格式定义…...

网络编程与axios技术

网络编程技术是指通过计算机网络实现不同设备之间数据交互的技术。它基于网络通信协议&#xff08;如TCP/IP、HTTP&#xff09;和编程语言的支持&#xff0c;结合库和API实现高效的数据传输与通信。以下是几种主流技术栈&#xff08;JavaScript、TypeScript、React、Next.js、P…...

【结构设计】以3D打印举例——持续更新

【结构设计】以立创EDA举例——持续更新 文章目录 [TOC](文章目录) 前言立创EDA官网教程一、3D外壳绘制二、3D外壳渲染三、3D外壳打印1.3D打印机——FDM2.3D打印机——光固化 四、3D外壳LOG设计1.激光雕刻机 总结 前言 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面…...

MySQL中的重要常见知识点(入门到入土!)

基础篇 基础语法 添加数据 -- 完整语法 INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...);-- 示例 insert into employee(id,workno,name,gender,age,idcard,entrydate) values(1,1,Itcast,男,10,123456789012345678,2000-01-01) 修改数据 -- 完整语法 UPDA…...

理解全景图像拼接

1 3D到2D透视投影 三维空间上点 p 投影到二维空间 q 有两种方式&#xff1a;1&#xff09;正交投影&#xff0c;2&#xff09;透视投影。 正交投影直接舍去 z 轴信息&#xff0c;该模型仅在远心镜头上是合理的&#xff0c;或者对于物体深度远小于其到摄像机距离时的近似模型。…...

云原生安全基石:Linux进程隔离技术详解

&#x1f525;「炎码工坊」技术弹药已装填&#xff01; 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 进程隔离是操作系统通过内核机制将不同进程的运行环境和资源访问范围隔离开的技术。其核心目标在于&#xff1a; 资源独占&#xff1a;确保…...

基于PySide6与pycatia的CATIA几何阵列生成器开发实践

引言:参数化设计的工业价值 在航空航天、汽车制造等领域,复杂几何图案的批量生成是模具设计与机械加工的核心需求。传统手动建模方式存在效率低下、参数调整困难等问题。本文基于PySide6+pycatia技术栈,实现了一套支持​​动态参数配置​​、​​智能几何阵列生成​​的自动…...

Linux学习心得问题总结(三)

day09 文件权限篇 文件权限的属性有哪些&#xff1f;我们应如何理解这些属性&#xff1f; 文件权限的属性包括可读&#xff08;r&#xff09;、可写&#xff08;w&#xff09;、可执行&#xff08;x&#xff09;三种权限&#xff0c;根据文件类型可分为普通文件&#xff08;.…...

蓝桥杯国14 不完整的算式

&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;理清思路 然后一步步写 问题描述 小蓝在黑板上写了一个形如 AopBC 的算式&#x…...

Anthropic推出Claude Code SDK,强化AI助理与自动化开发整合

Anthropic发布Claude Code SDK&#xff0c;协助开发团队将人工智慧助理整合进自动化开发流程&#xff0c;支援多轮对话、MCP协定及多元格式。 Anthropic推出Claude Code SDK&#xff0c;提供开发者与企业一套可程序化整合Claude AI助理至开发流程的工具。此SDK以命令列介面为基…...

6.4.1最小生成树

知识总览 生成树(一定是连通的)&#xff1a; 是连通的无向图的一个子图&#xff0c;子图包含这个无向图的所有顶点有n-1条边(少一条边&#xff0c;生成树就不连通了)即为生成树&#xff0c;一个连通图可能有多个生成树 最小生成树(最小代价树)&#xff1a; 只有连通的无向图才…...

DAY 33

知识点回顾&#xff1a; 1. PyTorch和cuda的安装 2. 查看显卡信息的命令行命令&#xff08;cmd中使用&#xff09; 3. cuda的检查 4. 简单神经网络的流程 a. 数据预处理&#xff08;归一化、转换成张量&#xff09; b. 模型的定义 i. 继承nn.Module类 ii. 定义…...

基于ICEEMDAN-SSA-BP的混合预测模型的完整实现过程

以下将为您详细阐述基于ICEEMDAN-SSA-BP的混合预测模型的完整实现过程,包含原理说明、算法实现、代码解析及优化策略。本教程分为六个核心部分,采用Python 3.9环境开发。 基于ICEEMDAN-SSA-BP的混合时间序列预测模型 一、模型架构设计 1.1 整体流程 #mermaid-svg-o4UD3HaTm…...

常见排序算法详解及其复杂度分析

常见排序算法详解及其复杂度分析 排序算法是数据结构与算法学习中的基础内容&#xff0c;也是面试高频考点。本文将系统介绍几种常见的排序算法&#xff0c;包括它们的原理、时间复杂度、空间复杂度以及 Python 实现方法。 一、冒泡排序&#xff08;Bubble Sort&#xff09; …...

DARLR用于具有动态奖励的推荐系统的双智能体离线强化学习(论文大白话)

1. 概述 离线强化学习是现在强化学习研究的一个重点。相比与传统的强化学习它不需要大量的实时交互数据&#xff0c;仅仅依赖历史交互日志就可以进行学习。本文就是将离线强化学习用于推荐系统的一篇文章。 这篇文章主要解决的核心问题有以下几个&#xff1a; 1&#xff09;…...

第35节:PyTorch与TensorFlow框架对比分析

引言 在深度学习领域,PyTorch和TensorFlow无疑是当前最受欢迎的两大开源框架。 自2015年TensorFlow由Google Brain团队发布,以及2016年Facebook的AI研究团队推出PyTorch以来,这两个框架一直在推动着深度学习研究和工业应用的发展。 本文将从多个维度对这两个框架进行详细对…...

企业级智能体 —— 企业 AI 发展的下一个风口?

在AI技术迅猛发展的当下&#xff0c;企业对AI的应用不断深入。企业级智能体逐渐受到关注&#xff0c;它会是企业AI发展的下一个风口吗&#xff1f;先来看企业典型的AI应用场景&#xff0c;再深入了解企业级智能体。 企业典型AI应用场景 1. 内容生成&#xff1a;2025年&#xf…...

【软考向】Chapter 2 程序设计语言基础知识

程序设计语言概述低级语言 —— 机器指令、汇编语言高级语言 ——翻译:汇编、解释和编译语言处理程序基础 —— 翻译给计算机,汇编、编译、解释三类编译程序基本原理 —— 词法分析、语法分析、语义分析、中间代码生成、代码优化、目标代码生成文法和语言的形式描述确定的有限…...

JavaWeb:SpringBootAOP切面实现统计方法耗时和源码解析

介绍 快速入门 1.导入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId> </dependency>2.切面类java Slf4j Aspect Component public class RecordTimeApsect {/*** 统计耗…...

RabbitMQ的其中工作模式介绍以及Java的实现

文章目录 前文一、模式介绍1. 简单模式2. 工作队列模式3. 广播模式4. 路由模式5. 通配符模式6. RPC模式7. 发布确认模式 二、代码实现1、简单模式2、工作队列模式生产者消费者消费者 1消费者 2 3、广播模式 (Fanout Mode)生产者消费者 4、路由模式 (Direct Mode)生产者消费者 5…...

vue2项目搭建

作者碎碎念&#xff1a;开历史倒车了&#xff0c;没想到不兼容&#xff0c;只能从vue3->vue2了。 1 vue3和vue2 这部分参考了官网的《vue3迁移指南》&#xff1a;Vue 3 的支持库进行了重大更新。以下是新的默认建议的摘要: 新版本的 Router, Devtools & test utils 来…...

Spring AI 源码解析:Tool Calling链路调用流程及示例

Tool工具允许模型与一组API或工具进行交互&#xff0c;增强模型功能&#xff0c;主要用于&#xff1a; 信息检索&#xff1a;从外部数据源检索信息&#xff0c;如数据库、Web服务、文件系统或Web搜索引擎等 采取行动&#xff1a;可用于在软件系统中执行特定操作&#xff0c;如…...

2025年- H48-Lc156 --236. 二叉树的最近公共祖先(递归、深搜)--Java版

1.题目描述 递归终止条件&#xff1a; 如果当前节点 root 为 null&#xff0c;表示到达了叶子节点的空子树&#xff1b; 如果当前节点是 p 或 q&#xff0c;就返回它&#xff08;因为从这里可以回溯寻找公共祖先&#xff09;。 2.思路 &#xff08;1&#xff09; 如果当前节…...