0

0

c++怎么操作vulkan图形api_c++ 物理设备枚举与指令缓冲创建【案例】

冰火之心

冰火之心

发布时间:2026-01-07 18:37:02

|

549人浏览过

|

来源于php中文网

原创

vkEnumeratePhysicalDevices 返回 VK_INCOMPLETE 表示设备数量超出传入数组容量,需先用 nullptr 获取真实数量再二次调用;选 VkPhysicalDevice 应基于特性支持与 API 版本而非设备类型;vkBeginCommandBuffer 返回 VK_ERROR_INITIALIZATION_FAILED 通常因 Primary 命令缓冲区误设 pInheritanceInfo;命令池生命周期必须严格绑定逻辑设备。

c++怎么操作vulkan图形api_c++ 物理设备枚举与指令缓冲创建【案例】

vkEnumeratePhysicalDevices 为什么返回 VK_INCOMPLETE

调用 vkEnumeratePhysicalDevices 时返回 VK_INCOMPLETE 不是错误,而是 Vulkan 的标准分页机制:你传入的 physicalDeviceCount 指针值小于实际可用设备数,Vulkan 只填满你给的数组并告知“没写完”。

  • 必须先传 nullptr&deviceCount 获取真实数量,再分配数组
  • 第二次调用前确保 deviceCount 值未被意外修改(比如被其他线程覆盖)
  • 若两次调用间显卡热插拔(如笔记本独显/核显切换),仍可能不一致——此时应重新枚举或忽略新增设备
uint32_t deviceCount = 0;
vkEnumeratePhysicalDevices(instance, &deviceCount, nullptr);
std::vector devices(deviceCount);
vkEnumeratePhysicalDevices(instance, &deviceCount, devices.data());

如何选对 VkPhysicalDevice(不止看 VK_PHYSICAL_DEVICE_TYPE_DISCRETE_GPU)

编码只选独显会失败:Mac 上 M 系列芯片返回 VK_PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU 但性能极强;某些嵌入式平台甚至没有离散 GPU。关键看能力而非类型。

  • 优先检查 vkGetPhysicalDeviceFeatures 是否支持你需要的特性(如 geometryShadertessellationShader
  • vkGetPhysicalDevicePropertiesdeviceNameapiVersion,过滤掉太旧(如 apiVersion )的设备
  • 调用 vkGetPhysicalDeviceQueueFamilyProperties 确认存在支持图形+传输+计算的队列族(尤其注意 queueFlags & VK_QUEUE_GRAPHICS_BIT

vkAllocateCommandBuffers 失败常见原因

VK_ERROR_OUT_OF_HOST_MEMORYVK_ERROR_OUT_OF_DEVICE_MEMORY 很可能不是真内存不足,而是参数配置错位。

DeepAI
DeepAI

为天生具有创造力的人提供的AI工具

下载
  • commandPool 必须由当前 physicalDevice 对应的 device 创建(不能跨 device 复用)
  • allocateInfo.level 设为 VK_COMMAND_BUFFER_LEVEL_PRIMARY 时,该 command pool 必须在创建时指定 flags & VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT == 0
  • 如果 commandBufferCount > 65535,部分驱动会静默失败(尤其是 Intel Windows 驱动),建议单次不超过 1024 个
VkCommandBufferAllocateInfo allocInfo{};
allocInfo.sType = VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO;
allocInfo.commandPool = commandPool;
allocInfo.level = VK_COMMAND_BUFFER_LEVEL_PRIMARY;
allocInfo.commandBufferCount = 1;
std::vector buffers(1);
vkAllocateCommandBuffers(device, &allocInfo, buffers.data());

vkBeginCommandBuffer 返回 VK_ERROR_INITIALIZATION_FAILED 怎么办

这个错误几乎总是因为 VkCommandBufferBeginInfo 中的 pInheritanceInfo 字段非法:它仅对 VK_COMMAND_BUFFER_LEVEL_SECONDARY 有效,Primary 缓冲区传非空指针会直接触发该错误。

立即学习C++免费学习笔记(深入)”;

  • Primary 缓冲区必须设 beginInfo.pInheritanceInfo = nullptr
  • Secondary 缓冲区才需填充 VkCommandBufferInheritanceInfo,且其中 renderPasssubpass 必须与将来调用它的 Primary 缓冲区匹配
  • 即使你确定要用 Secondary,也先用 Primary 跑通流程——多数初学者根本不需要 Secondary
Vulkan 的物理设备和指令缓冲链路里,最易被忽略的是「命令池生命周期必须严格绑定到逻辑设备」:一旦 vkDestroyDevice,所有从它分配的 command pool 和 command buffer 都立即失效,哪怕还没提交。别试图复用或延迟销毁。

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

476

2023.08.10

空指针异常处理
空指针异常处理

本专题整合了空指针异常解决方法,阅读专题下面的文章了解更多详细内容。

22

2025.11.16

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

564

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1083

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

775

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

447

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2345

2023.08.08

windows自动更新
windows自动更新

Windows操作系统的自动更新功能可以确保系统及时获取最新的补丁和安全更新,以提高系统的稳定性和安全性。然而,有时候我们可能希望暂时或永久地关闭Windows的自动更新功能。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

773

2023.08.10

Golang 分布式缓存与高可用架构
Golang 分布式缓存与高可用架构

本专题系统讲解 Golang 在分布式缓存与高可用系统中的应用,涵盖缓存设计原理、Redis/Etcd集成、数据一致性与过期策略、分布式锁、缓存穿透/雪崩/击穿解决方案,以及高可用架构设计。通过实战案例,帮助开发者掌握 如何使用 Go 构建稳定、高性能的分布式缓存系统,提升大型系统的响应速度与可靠性。

27

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.8万人学习

Excel 教程
Excel 教程

共162课时 | 11.1万人学习

PHP基础入门课程
PHP基础入门课程

共33课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号