最新资讯

  • 游戏引擎学习第198天

游戏引擎学习第198天

2025-05-01 22:39:25 130 阅读

回顾并为今天的内容设定

今天我们有一些代码需要处理。昨天我们进行了一些调试界面的整合工作,之前我们做了一些临时的、粗糙的操作,将一些东西读进来并放到调试界面中。今天,我们并不打算进行大规模的工作,更多的是对之前的代码进行整理和优化,因为毕竟今天是周五,大家可能不希望深陷在复杂的工作中。

对于接下来的工作,我并不打算过多关注如何优化界面或让配置文件接口运作流畅。下周的重点应该是创建更加清晰的配置文件接口,以便于切换和其他操作。今天的任务主要是对现有的代码做一些整理,尤其是在硬件接口部分。通过整理这些部分,我们可以为将来加入更多的高级功能打下基础,使得整个系统的运行更加平稳流畅。

我个人并不擅长构建非常复杂的配置文件界面,之前也只是做过一些简单的记录和时间跟踪工作。而现在,我们手上有了更多关于线程和数据的详细信息,这让我不得不思考如何将这些信息转化为用户可以轻松理解和操作的形式。对此,接下来的几天或许会花更多时间讨论如何设计这样一个界面,使它既有用又易于理解。

此外,还可以在调试界面中打开性能分析器,查看完整的性能数据,并且调整分析器的大小。虽然在某些时候调试界面可能显示不完,或者超出屏幕,但这并不影响整体的调试能力。你可以同时打开多个界面,进行多重调试操作,所有的界面和操作都可以动态响应,简便而且实用。

接下来,我想做的一件事是实现“拆分”功能。例如,在调试界面中,如果我正在查看某个元素,应该能够把它从主界面中提取出来,变成一个独立的窗口或者面板。这种“拆分”操作在调试过程中非常有用,尤其是当我们希望同时查看多个独立的调试数据时。目前,调试界面只能通过开关来控制显示和隐藏,接下来的目标是让它支持更自由的拆分和拖动操作。

实现这一功能其实并不复杂,我想通过这个简单的例子来演示如何快速制作出一些具有交互能力的界面。通过简单的几行代码,就可以制作出一个非常实用的调试界面,而无需依赖复杂的UI库。这也说明了在游戏开发中,如何快速、有效地加入一些功能,而无需担心UI的复杂性。

总的来说,我们今天的目标是让调试界面能够支持更多的交互功能,特别是拆分功能,让开发者能够根据需要将不同的调试窗口分开处理。

game_debug.h: 介绍 debug_variable_reference

我们现在已经进入了调试代码的部分。从当前结构来看,我们使用了变量组来管理调试变量,而每个调试变量实际上保存着要编辑的数据。这些调试变量在当前实现中是直接存储数据的,问题在于这种结构让我们很难将一个调试变量放在多个地方进行引用。

理想的做法是通过某种方式间接引用这些变量。我们希望每个调试变量能够在多个地方同时被引用,而不必重复存储其数据。为了实现这一点,我们只需要引入一个间接引用的列表。这种结构我们之前讨论过,但在游戏开发中并不常见,因为链表这种结构在游戏中并不像在编辑器或类似的应用程序中那样常见。然而,在一些特定的情况下,链表结构仍然会派上用场,尤其是在我们处理一些较为复杂的引用关系时。

为了实现这一目标,我们将引入一个新的结构,专门用来存储引用关系。这些引用关系将独立于原始的调试变量存储,并且允许多个地方引用同一个变量。这样,无论有多少个引用需要使用这些变量,它们都可以独立存在,不会相互干扰。

我们只需要修改那些使用调试变量的部分,把原本直接引用变量的地方,改成引用调试变量引用的链表。举个例子,原来一个组可能直接保存了一些调试变量,现在我们希望它保存的是调试变量的引用链,而不是直接保存变量数据。同样地,调试变量的层级结构也需要做类似的调整,让它们存储的是引用而非实际的变量。

不过,考虑到层级结构的实现,我认为可能会有些不同的处理方式。所以,我决定暂时不修改这一部分,先集中精力处理将调试变量改为引用链表的工作。

目前,已经完成了调试变量引用部分的工作。接下来,我会确保这些引用结构能正确地与其他部分进行交互,确保它们能够按预期动态处理。这是我们在调试系统中所需要的一项重要改进,让调试变量能够在多个地方灵活地引用和使用。

game_debug_variables.h: 介绍 DEBUGAddUnreferencedVariable

在当前的调试过程中,目标是创建一个新的变量,并为该变量添加引用。这一步骤的关键是实现一种引用机制,方便在后续过程中进行变量引用和管理。首先,创建一个名为 debug variable 的变量,这个变量将作为引用的基础。

接下来,需要做的是在创建变量的同时,还要创建一个调试变量引用。这个调试变量引用将与之前创建的变量保持关联。具体来说,调试变量引用将处理与变量直接相关的部分,而不涉及分组或其他复杂的结构。这一步的目的是确保能够通过引用访问变量,而不仅仅依赖变量本身。

在实现时,需要定义一个 DEBUGAddVariable 类型,它将包含指向实际变量的引用。关键的是,引用能够访问变量,而变量本身不能直接访问引用,因此,引用是获取变量的一个有效途径。

总之,当前的目标是通过创建变量和调试引用来构建一个清晰的调试系统,其中引用和变量能够互相配合工作,确保变量的灵活性和可访问性。

game_debug.h: 为 debug_variable_reference 添加 debug_variable *Var

在这里,调试变量引用的实现只需要一个能够指向实际变量的机制。具体来说,我们需要创建一个 DEBUGAddVariable,它的作用就是指向之前定义的调试变量(debug variable)。这个引用将能够间接访问该变量,从而实现更灵活的操作和管理。

实现这个引用非常简单,只需要确保它能够准确地指向目标变量,并且在需要时能够通过该引用访问变量的值或进行修改。通过这种方式,引用成为了访问变量的有效途径,而不再直接依赖变量本身。

总结来说,目标是确保调试系统中的每个变量都可以通过引用来访问,引用结构的引入能够提高代码的灵活性和可维护性,使得调试过程更加清晰和便捷。

game_debug_variables.h: 介绍 DEBUGAddVariableReference

在创建调试变量引用时,主要的任务是将调试变量引用推送到内存池(arena)中,并设置引用,使其指向我们给定的调试变量。这意味着,所有原本与变量相关的操作,将改为通过引用进行处理。引用允许我们间接访问变量,因此这里的核心目标是确保所有的操作都通过引用来管理,而不是直接操作变量本身。

接下来,在构建树形结构时,父节点(parent)同样需要使用引用来构建。每个树节点都应当指向其他变量或节点,并且这种关系应通过引用进行管理。通过这种方式,可以实现更灵活的树结构,其中每个节点指向的变量或数据可能随时变化,而引用会确保每个节点都始终指向正确的对象。

在具体操作中,如果树形结构中的父节点引用不为空,我们将通过引用获取父节点对应的变量。这种方法使得树形结构的构建更加灵活和高效,因为树结构的父子关系能够通过引用动态地维护,而不必依赖静态的直接变量指针。

总结来说,重点在于通过引用来管理树形结构和调试变量,以实现更高效的内存管理和更灵活的调试操作。这种方式能够更好地处理复杂的数据结构和变量间的关系,使得代码更加可扩展和易于维护。

game_debug_variables.h: 清理编译错误

在处理调试变量引用时,遇到了一些问题,最初的错误是因为忘记在代码中使用指针。具体来说,调试变量的引用未能正确转换,原因是缺少指针,导致编译错误。通过修复这个问题,可以继续进行调试变量的操作。

在处理这一过程时,重点是将调试变量和变量组等结构更改为引用类型,这使得变量和组能够被更灵活地引用和操作。这种更改并不会涉及太复杂的逻辑,只是将原本的直接访问变为间接引用,这样可以方便后续的扩展和调整。

此外,调试变量组和其他结构的返回类型也被修改为引用类型,确保这些对象可以通过引用进行处理和传递。整个过程虽然看起来简单,但需要进行一定的代码更改,以确保数据可以通过引用有效管理。

整个实现过程中并没有涉及太多复杂的设计或算法,主要的变化是将数据结构的引用方式从直接指向改为通过引用间接操作,这为后续的扩展和维护提供了更多灵活性。尽管这些改动相对简单,但它们在实际实现中有助于代码的结构化和优化。

总的来说,这些更改并不涉及复杂的功能或算法,只是对数据访问方式进行了优化,确保变量和数据结构的引用更符合需求,并且便于未来的扩展。

game_debug.cpp: 传播 Ref

在继续处理过程中,目标是将之前的改动进一步传播到更高一级的结构,即根组结构。此时,根组需要使用调试变量引用,而不是直接使用变量。这意味着我们需要修改代码,使得在处理这些结构时,所有的变量操作都通过引用来进行。

为了实现这一点,在编写代码时,根组的操作将改为通过引用访问调试变量。变量不再直接存储数据,而是通过引用指向数据,这样就能确保变量的数据是间接访问的。代码中的 ref 关键字被用来替代原来的直接变量引用。这样做的目的是为了提高代码的灵活性和扩展性,尤其是当涉及到多层次的结构时,引用管理会使得操作更加高效。

具体操作包括修改迭代器,使其迭代的是引用而非变量本身,这样可以避免直接操作数据,而是通过引用来操作数据。这一改动是为了保持数据的一致性和灵活性,尤其是在处理更复杂的数据结构时。

在调整完成后,代码的逻辑并没有发生本质的变化,唯一的区别在于现在操作的是引用而非直接的变量。所有的变量访问都通过引用进行,这确保了数据结构能够以更灵活的方式进行管理和操作。

总的来说,这些修改是为了将数据管理从直接访问改为通过引用操作,增强了数据结构的灵活性和可扩展性,同时保持了原有代码的逻辑和功能。

编译并确认仍然可以正常运行

到目前为止,所有的修改看起来都已经完成,并且代码的功能在理论上应该能够正常运行,和之前的操作逻辑类似。尽管我们对代码结构做了一些调整,但系统仍然能够按预期遍历数据和执行操作。整体来看,修改后的代码表现良好,功能正常,迭代过程也没有问题。

这些改动的关键在于如何通过引用来管理数据,而不是直接操作数据本身。通过这种方式,可以确保更高效、更灵活的引用管理,同时不影响原有的迭代和数据操作。总的来说,修改后的代码结构应该能够在不破坏现有功能的基础上,提供更强的扩展性和可维护性。

在进一步的测试中,预计不会遇到太大问题,因为所有的基本操作依然能够按预期执行。

game_debug_variables.h: 尝试将 UseDebugCamRef 添加到两个不同的组中

首先,想要测试变量引用的功能,目的是确保能够将同一个调试变量添加到两个不同的组中。具体步骤是:

  1. 先定义一个调试变量,例如 debug camera distance,然后为这个变量创建一个引用。
  2. 然后,使用这个变量引用,确保它能够在多个组中共存,即将同一个调试变量添加到不同的组中。这里需要注意的是,确保能够通过引用管理这个变量,而不是直接复制它。

在实现中,通过定义 debug camera reference 来引用调试变量,并将其添加到目标组中。在这个过程中,通过创建引用来保持变量的唯一性,但允许它出现在不同的地方。测试时,需要注意检查是否能够成功地将相同的变量添加到多个组中,而不会产生冲突或错误。

整体上,这个操作是为了验证引用机制是否有效,确保能够通过引用的方式对变量进行管理和操作,而不影响它的本质或数据一致性。在执行时,需要去掉一些不必要的代码或错误部分,保证程序的正确运行。

运行游戏并查看 UseDebugCam 是否出现在两个组中

在测试过程中,运行时可以看到新的调试变量(例如“debug camera”)成功地添加到多个位置,并且它们之间的关联得到了验证。这个变量现在出现在了不同的地方,并且可以在多个位置进行修改,而且它们的值是同步变化的。

具体来说,当将相同的变量添加到多个组时,不会产生任何性能上的问题,也不会有额外的复杂性。这种设计使得能够在不同的地方引用相同的变量,而不会出现重复或冲突的情况。这是为了确保在多处使用同一个变量时,不会有任何额外的开销,同时保证变量值的一致性。

另外,通过对调试变量进行高亮显示,可以直观地验证它们是否正确关联。当鼠标悬停在这些变量上时,能够看到它们都被高亮显示,并且在修改其中一个变量时,其他引用相同变量的地方也会同步变化。这进一步验证了引用机制的有效性和正确性。

总的来说,整个过程确保了能够在多个地方灵活地使用同一个变量,而不会导致重复或数据不同步的问题。

game_debug.cpp: 实现支持多个 debug_variable_hierarchy

在实现过程中,首先需要更多的内存来支持调试系统的扩展。由于当前的内存分配限制,无法创建更多的功能或增加新的菜单,因此需要增加内存的使用量,以便能够在需要时创建更多的调试项或功能。

当前实现中,调试系统使用了一个“调试区域”来进行临时存储和计算,但这个区域并未使用全部可用内存。因此,实际上在内存分配上还有一定的剩余空间,这意味着如果需要更多的内存空间来处理更多的调试任务,是可以做到的。

为了扩展功能,目标是能够绘制多个调试变量层级,而不仅仅是一个单一的调试菜单。现有的实现只能显示一个硬编码的调试层级,但希望通过修改,能够实现动态的、多层次的调试变量层级的绘制。这个目标的实现方式是通过使用循环遍历调试层级,允许多个调试菜单独立显示,并且每个菜单都可以根据需要进行修改。

此外,当前的实现存在一些问题,比如调试菜单的位置和附加的方式还不明确,属于一些较为粗糙的设计,需要后续的优化。在代码中,调试变量的管理通过“层级引用”的方式进行控制,接下来的目标是能允许更多层次的调试变量体系,从而使得在不同的上下文中可以灵活地引用和修改这些变量。

为了解决这些问题,计划引入一个“层级哨兵”概念,通过遍历这些层级,允许更多的调试菜单实例同时存在,并能够在每个菜单中显示特定的调试信息。同时,也会增加一个函数 AddHierarchy,用于动态地添加新的调试层级,确保每个新的调试项都能被正确地管理和展示。

简而言之,整体目标是增强调试系统的扩展性,使得可以更灵活地管理调试变量,动态添加更多的调试层级,而不会受到当前内存和设计的限制。

game_debug.cpp: 引入 AddHierarchy

在实现过程中,目的是通过修改代码来支持调试系统的扩展,以便可以创建和管理多个调试变量层级。首先,构建调试变量引用时,需要初始化各个指针和节点,确保它们可以正确地连接和引用。

使用了双向链表的结构来管理调试变量层级。在实现时,首先创建一个新的调试变量层级(debug variable hierarchy),并初始化相关字段。例如,初始化它的组(group),这通常是一个根组(RootGroup),但随着后续操作,它可能变成其他的组。链表的“前驱”和“后继”指针也需要初始化,以确保链表的正确性。

具体来说,链表的操作需要设置节点之间的连接关系。每个节点的“前驱”指针指向它之前的节点,而“后继”指针指向下一个节点。为了实现这一点,需要在初始化阶段将这些指针互相连接。这样,每个节点的前后关系都被正确地管理。

当新层级添加到链表中时,还需要确保链表的头部(sentinel)指针的正确性。这个“哨兵”节点会始终指向链表的开始或结束,作为链表的边界。对每个新节点,确保其“前驱”和“后继”指针正确指向相邻的节点,避免出现空指针或断链的情况。

在代码中,链表操作需要处理好指针的初始化和链接,确保节点的指针在整个操作过程中始终有效。这包括初始化每个节点的指针,并在需要时清除旧的指针,确保没有残留的无效指针。

同时,对于每次新的层级添加到链表中的操作,需要返回正确的指针,确保其他代码能够使用这个新节点。为了避免错误,还需要确保每次操作的内存分配和指针设置是合理的,避免出现内存泄漏或访问无效内存的情况。

总之,通过这种方式,可以为调试系统提供一个灵活的结构,允许动态添加和管理多个调试层级,而不必受限于当前的单一结构或内存分配。

game_debug.cpp: 编写 Hierarchy 双向链表

在实现过程中,首先需要创建调试系统的上下文(context),并初始化调试状态。调试变量层级的创建是通过标准的双向链表实现的。链表的起始点(sentinel)指向自身,确保链表开始为空。为了避免迭代时出现问题,初始化时会将链表的组指针设为零,提醒在没有正确初始化的情况下,不要进行迭代。

在链表实现中,每个节点的前驱指针(previous)指向链表的“哨兵”节点(sentinel),后继指针(next)指向链表的下一个节点。这样可以确保链表的正确性,避免出现循环或指针错误的情况。

在绘制调试菜单时,出现了一个问题:调试菜单的绘制循环似乎没有正确结束。需要检查代码,确保在绘制时能够正确退出循环,避免重复绘制同一个菜单。特别是在调试菜单绘制的函数中,需要确保调试变量的层级在迭代时能够正确前进,而不是在错误的节点上停留。

在调试菜单的名称和函数调用上,也有一些需要改进的地方,例如draw debug menu函数的命名需要更一致,以便提高代码的可读性和可维护性。

总之,当前的目标是确保调试系统能够正确地创建、管理和绘制多个调试变量层级,并确保每个层级的链表结构和指针的操作都能正常工作,避免错误的循环或无效的菜单绘制。

有点卡

调试器: 进入 AddHierarchy

在调试系统中,首先检查了调试变量层级(hierarchy)的链表结构,确保链表的起始点(哨兵节点)正确地指向自身,并且链表中的每个节点的前驱指针和后继指针都指向正确的地方,形成了一个正确的双向链表。特别是在链表的"next"指针中,当前节点正确地指向下一个节点,而下一个节点的"previous"指针又指回当前节点,确保了双向链表的完整性。

接着,进入了调试菜单的绘制部分,确保调试菜单能够正常绘制并退出绘制循环。在draw debug menu函数中,通过检查代码,确认了调试变量组(debug variable group)能够正确显示,而且绘制完成后能够正常退出,不会卡在某个地方。

在调试过程中,调试层级的循环和菜单的绘制过程都得到了修复。退出条件和绘制的逻辑都被确认无误,确保了代码按预期工作。最终,调试系统的功能看起来正常运行,调试菜单能够正确地显示和更新,调试变量也能如预期一样进行处理和显示。

game_debug.cpp: 在正确的位置调用 AddHierarchy

在调试过程中,发现了一个潜在的问题。问题的根源在于AddHierarchy函数被每一帧都调用,这会导致每一帧都生成大量的调试层级和绘制内容,这显然会影响性能。因此,决定停止这种做法。

接着,考虑如何决定调试层级的位置,因为在不知道具体尺寸的情况下,不能直接确定位置。然而,通过进一步分析,意识到实际上是可以提前计算出这些尺寸的。这意味着虽然不直接知道尺寸,但可以通过一定的方式来预估和计算这些尺寸。

具体来说,可以在初始化时为每个调试层级预设一个起始位置,假设开始时的位置为某个默认值,比如将其高度设置为初始值的一半。这样,通过预先计算和布局,可以更高效地管理调试菜单和层级的绘制,而不会因为每一帧都重新计算和绘制而带来性能上的问题。

运行游戏,发现界面有所改善

现在,调试系统的状态看起来已经变得更好了,一切都在正常运行,所有功能都按预期工作。接下来,计划实现一个功能,使得可以从当前的调试界面中“拆卸”某些元素,这样就可以更灵活地操作调试界面。

为了实现这一点,计划引入一种交互概念,使得能够通过某些操作将调试界面中的部分元素从当前显示中分离或移除。这样就可以更方便地管理调试界面,特别是在需要动态调整显示内容时,能提供更多的灵活性和操作空间。

game_debug.cpp: 实现从菜单中拆分项目的功能

为了实现从调试界面中“拆卸”元素的功能,计划增加一个新的交互概念。这个交互概念将允许用户将调试界面中的一些元素从当前的位置“拆卸”并重新放置到其他地方。这一功能的实现将通过对调试界面交互机制的调整来完成。

首先,计划在交互过程中添加一个“拆卸”操作(tear),并确保在某些特定条件下(例如按下特定的快捷键或鼠标按钮)触发这个拆卸操作。为了实现这一点,选择了一个简化的方式,即通过添加一个小组件来表示拆卸的交互功能。这种拆卸功能将允许用户将元素从原始位置拆卸并放置到新的位置。

具体的实现步骤包括:

  1. 在调试值切换功能中,引入“拆卸”功能。首先,会通过修改交互处理逻辑来实现该功能,确保在用户点击时可以触发拆卸操作。
  2. 为了简化实现,采用了一种基本的方法来定义拆卸功能,并设置特定的输入条件来触发该功能。例如,可以通过鼠标右键按下或其他特定的输入键来执行拆卸操作。
  3. 在交互处理中,将判断是否处于拆卸模式。如果用户在按下特定的修改键(如“Alt”键)时触发该模式,则启动拆卸操作;否则,执行默认的交互操作。
  4. 增加了条件判断,判断是否在交互过程中点击了右键或特定的鼠标按钮,并根据这些操作决定是否执行拆卸。如果触发了拆卸,调试界面将允许用户将选定的调试元素从当前位置拆卸并移至其他位置。

总体而言,这种方式使得调试界面变得更加灵活,用户可以根据需要自由地调整和重新排列调试元素,提升了调试系统的交互性和可操作性。

game_debug.cpp: 实现 DebugInteraction_TearValue

为了实现“拆卸值”(tear value)的功能,需要在现有的代码基础上添加一些新的实现细节。具体的步骤如下:

  1. 定义拆卸值功能:首先,拆卸值功能需要与“拖拽”功能相结合。具体来说,当用户执行拆卸操作时,需要创建一个新的调试变量层级(debug variable hierarchy),类似于现有的拖拽层级(dragging hierarchy)。这个新的层级将用于存储拆卸的值,并且可以在拖拽操作时与当前交互对象进行关联。

  2. 创建新的调试变量层级:为了实现拆卸操作,首先要检查是否已经存在调试状态的层级。如果还没有创建,应该先初始化一个新的层级。这一层级会在用户拖拽或拆卸操作时使用,并且会在操作结束后清理掉,恢复到初始状态。

  3. 更新交互状态:在处理拆卸操作时,需要将当前的鼠标位置与新的调试变量层级关联。具体来说,鼠标所在的位置将成为新的层级状态的位置,并且在拆卸过程中,该层级会随着鼠标的位置变化而移动。

  4. 清理交互状态:当拆卸操作结束时,需要清除调试状态中的相关层级,以确保下一次操作时没有遗留数据或状态影响新的交互。

  5. 考虑新组的引入:为了更加有效地管理拆卸操作,可能需要引入新的分组来保存这些拆卸后的元素。这样,在后续的操作中,可以根据需要重新组织这些拆卸的元素。这个步骤可以暂时推迟,以避免引入过多的复杂性。

通过这些步骤,拆卸值的功能得以实现,用户可以在交互过程中自由地“拆卸”调试元素并重新组织它们的位置。

game_debug.variables.h: 介绍 DEBUGAddRootGroup

当前的目标是实现添加调试变量组(debug variable group)的功能。具体来说,目标是在不依赖上下文的情况下,能够将调试变量组直接添加到程序中,并使其能够与调试状态有效地交互。

  1. 添加调试变量组的需求:当前的系统中,调试变量参考(DEBUGAddVariable)需要一个实际的组引用。而目前的实现并没有提供这种引用。为了支持这一需求,需要能够创建并添加一个调试变量组,并且在不依赖上下文的情况下直接操作。

  2. 添加根组(RootGroup):通过定义一个函数(如 DEBUGAddRootGroup),可以在没有上下文的情况下创建根组。这一根组需要关联到当前的调试客户端状态,并初始化一些属性。例如,根组的“扩展”状态需要设置为 true,并且其子元素的内容应初始化为空。这确保了根组在后续的操作中能够正常工作,并且能够作为其他调试变量组的容器。

  3. 简化变量引用的设计:如果每个调试变量都已经包含一个分组,那么实际上不需要单独引用变量。此时,所有的调试变量可以直接与它们的分组关联,而不必创建额外的变量引用。因此,设计上可以简化,调试变量组直接与调试状态关联。

  4. 调试变量的引用和扩展:通过 debug add reference variable 等操作,能够将调试变量与对应的组进行关联。当创建根组时,可以立即将该根组的引用添加到调试变量中。这样就能在不扩展的情况下,确保所有调试变量和根组的关联正确无误。

  5. 默认行为:为了简化操作,根组和调试变量组可以在初始状态下设置为不扩展,避免不必要的扩展操作,直到有需要的时候再进行。

  6. 后续验证:完成添加调试变量组和引用的功能后,需要进行验证,确保这些操作按预期工作。通过检查添加的内容,确保其行为正常且符合预期。

通过这些步骤,能够更好地管理和组织调试变量组,从而提升调试功能的灵活性和可操作性。

game_debug.cpp: 调用 DEBUGAddRootGroup

为了完成拖拽操作的实现,接下来的步骤包括创建一个根组,并将调试变量添加到该组中。详细步骤如下:

  1. 创建根组:首先,需要创建一个根组,并将其与调试状态(debug state)关联。这一根组将成为后续操作的基础,并且会成为当前调试变量组的容器。

  2. 添加调试变量到根组:接着,应该将调试变量引用添加到该根组。通过这样的操作,根组和调试变量建立起直接的联系。

  3. 层次结构的管理:为了处理这些调试变量和根组之间的关系,操作需要支持两级结构,而不依赖于上下文(context)。这样可以避免在每次交互中都需要获取上下文,而是直接通过调试状态和根组进行交互。

  4. 确保层次结构正常工作:通过添加 DEBUGAddRootGroup,可以获得一个根组,该根组随后会成为调试层次结构的一部分。根组本身并不会显示名称,而是作为一个“用户组”存在,用于组织和管理调试变量。

  5. 调整层次结构的引用:在完成根组和变量的关联后,需要确保所有的层次结构(如 at hierarchy)都能正确地接受调试变量组。每个层次结构项应该引用调试变量,而不是单独的上下文信息。

  6. 调试变量的引用方式:由于调试变量已经与根组关联,层次结构中的每个元素将直接引用调试变量,而不需要额外的引用操作。这简化了整个过程。

  7. 最终效果验证:完成这些操作后,调试系统应能正确地处理拖拽操作,并确保层次结构中的每个元素都能正确显示和管理。

通过这些步骤,拖拽操作的实现不仅能够正常运行,还能确保调试状态和变量组的管理更加高效和灵活。

game_debug_variables.h: 使 DEBUGAddVariableReference 接受 debug_variable *Group

现在需要实现变量的拆分功能,虽然相关代码已经基本完成,但目前仍然缺少一个关键部分,即在交互过程中真正地将变量添加到新的组中。具体的实现步骤如下:

  1. 调整交互逻辑

    • 目前 tear value 操作本身不需要在 end interaction 时执行任何特定的操作,实际的拆分逻辑应发生在交互过程中。
    • 需要一个方法,将当前正在交互的变量添加到新的组中,而不是仅仅创建空的组。
  2. 实现变量添加

    • 需要引入 debug add reference 函数,使其能够将变量添加到目标组中。
    • 现有的 DEBUGAddVariableReference 方法需要修改,使其不依赖于上下文(context)。
    • 由于 debug state 负责内存分配,因此可以直接在 debug state 中分配变量,而不需要依赖 context 来获取信息。
  3. 调整变量引用逻辑

    • 目前变量引用依赖 context 获取组信息,这部分需要改为直接从参数传递。
    • add reference 需要同时接受目标 groupvariable,然后将变量添加到 group 中。
    • 这意味着 context 不再是必要的,它可以被视为一个辅助工具,而不是强制依赖项。
  4. 优化父级引用

    • 变量引用通常会包含其父级信息,但在 tear value 操作中,某些情况下可能不需要父级信息。
    • 需要判断是否仍然需要维护父级关系,如果不需要,则可以省略相关字段。
  5. 调整 context 逻辑

    • 由于不再依赖 context 来获取 group,在 context 内部仍然可以提供一个封装层,以简化对 add reference 的调用。
    • context 仅仅作为辅助工具,确保调用时可以方便地获取 group 信息,但底层逻辑不再依赖于 context,而是直接操作 debug state
  6. 最终实现

    • 交互过程中,拆分变量时会创建一个新的组,并将当前变量添加到该组中。
    • 变量引用不再从 context 获取 group,而是通过传递参数直接指定 group
    • context 仅作为封装工具,以便在某些情况下提供便利,而不会影响底层逻辑的独立性。

这样,tear value 的功能就可以正常工作,并确保变量能够正确地拆分到新的组中,同时保持整体逻辑的清晰性和可维护性。

game_debug.cpp: 调用 DEBUGAddVariableReference

现在,我们需要确保 DEBUGAddVariable 可以被直接调用,并且支持将交互中的变量拆分到新的层级结构中。然而,在实现过程中,我们遇到了一些挑战,最终决定采用最初的实现方式,尽管这并不是最理想的方案,但由于层级树的父指针结构的限制,这成为了唯一可行的方法。

具体实现步骤:

  1. 允许变量拆分(tear-off)

    • 交互过程中,检测当前操作的变量,并允许其被拆分。
    • 创建一个新的层级结构,使得变量能够被正确地放入其中。
  2. 修正 DEBUGAddVariable 逻辑

    • 由于 DEBUGAddVariable 需要支持直接调用,我们需要确保它可以正确处理新的交互模式。
    • 这意味着在调用 DEBUGAddVariable 时,必须提供正确的上下文,并确保 statecontext 能够被正确传递。
  3. 调整 parent 指针逻辑

    • 由于层级树的组织方式,我们无法绕过 parent 逻辑,因此仍然需要维护 parent 指针。
    • 这样可以确保在交互过程中,变量仍然能够正确地插入到新的层级中。
  4. 修复 DEBUGAddVariableReference 参数问题

    • 之前调用 DEBUGAddVariableReference 时,遇到了参数类型不匹配的问题。
    • 需要调整 contextstate 的传递方式,确保能够正确调用 DEBUGAddVariableReference 方法。
  5. 最终优化

    • 通过修正 parent 逻辑,使变量拆分功能正确工作。
    • 调整 DEBUGAddVariableReference 以匹配正确的参数类型,确保 contextstate 传递无误。
    • tear-off 逻辑变得更稳定,确保变量能够被正确拆分到新的层级中,并正确显示在 UI 结构中。

最终,虽然不得不采用最初的 parent 逻辑,但现在变量拆分功能已经能够正确工作,交互逻辑得到了优化,并且 DEBUGAddVariable 也可以被直接调用,实现了所需的功能。

game_debug_variables.h: 使 DEBUGAddRootGroup 添加 debug_variable_reference

现在,我们需要确保 DEBUGAddRootGroup 能够正确工作。之前我们认为 RootGroup 不需要额外的变量引用,但事实证明它确实需要,因此我们必须首先创建一个 DEBUGAddVariable 才能继续操作。

具体实现步骤:

  1. 创建 DEBUGAddVariable

    • RootGroup 被添加时,必须首先创建一个 DEBUGAddVariable
    • 这意味着 DEBUGAddVariable 需要在 DEBUGAddRootGroup 之前被调用。
  2. 调整 DEBUGAddRootGroup 的逻辑

    • 之前 DEBUGAddRootGroup 只是简单地创建了一个组,但现在它必须在创建 RootGroup 之后,立即创建一个变量引用。
    • 这个变量引用会被关联到 RootGroup,确保调试系统可以正确地追踪变量关系。
  3. 修改参数传递

    • RootGroup 的变量引用需要接受 statevar 参数。
    • RootGroup 的 ID 需要传递 0,因为它是层级结构的顶层。
  4. 调用方式

    • DEBUGAddRootGroup 现在会调用 DEBUGAddVariable,并将 statevar 作为参数传递进去。
    • 之后,继续进行正常的层级操作,确保 RootGroup 被正确地添加到调试系统中。
  5. 最终优化

    • 由于 DEBUGAddRootGroupDEBUGAddVariableReference 的逻辑基本相同,我们可以优化代码,减少重复部分。
    • 通过抽取公共逻辑,提高代码的可读性和可维护性。

最终,通过这些修改,我们可以确保 DEBUGAddRootGroup 能够正确地创建并管理 RootGroup,同时支持变量引用的正确传递和关联,从而保持整个调试系统的完整性和稳定性。

game_debug_variables.h: 介绍新的 DEBUGAddRootGroup,并将原始方法重命名为 DEBUGAddRootGroupInternal

现在,我们可以调用 DEBUGAddRootGroup 并确保它能正确运行。主要的调整如下:

1. 封装 DEBUGAddRootGroup internal

  • 这是一个仅供内部使用的工具函数,外部不会直接调用它。
  • 它封装了创建 RootGroup 以及相关的 DEBUGAddVariable 的逻辑,确保代码整洁。

2. 不同调用方式

  • 第一种调用方式:使用 context 来添加 RootGroup
  • 第二种调用方式:直接使用 DEBUGAddVariableReference,不依赖 context,而是直接传递 stategroup

3. 具体实现

  • DEBUGAddRootGroup internal 现在能从多个地方被调用。
  • context 方式下,它通过 context 进行层级管理。
  • 在非 context 方式下,直接使用 DEBUGAddVariableReference,手动管理 group 层级。

4. 代码优化

  • 由于 DEBUGAddRootGroup 发生了变化,我们需要调整 AddHierarchy,使其恢复到之前的逻辑。
  • 通过修正编译器错误,我们确保 DEBUGAddRootGroup 现在的实现与最初设想的一致,不会影响其他部分的功能。

5. 测试 tear-off 交互

  • 现在,我们可以测试 tear-off(分离变量)。
  • tear-off 逻辑中,我们监听鼠标右键按下的事件来执行 tear-off 操作。
  • 我们通过 DEBUGAddVariableReference 让变量能够正确加入到 RootGroup

6. 最终检查

  • 确保 tear-off 功能能正确地创建并管理变量的层级关系。
  • 观察 tear-off 交互是否符合预期,比如按下鼠标右键时是否正确地将变量分离并移动到新的层级。

通过这些调整,我们优化了 DEBUGAddRootGroup 的实现,并确保 tear-off 交互能够正常运行,从而增强了整个调试系统的稳定性和可用性。

运行游戏并测试新的拆分功能

现在,我们可以拖拽并创建新的分组,已经可以正确地在界面上生成多个独立的调试变量组。这一调整基本实现了 tear-off(分离变量)功能,使得多个变量组可以独立存在。然而,目前仍然存在一个问题:不同变量组的展开/折叠状态是同步的,因为它们共享相同的状态管理方式。

当前进展

  • 现在可以创建多个独立的变量组,并且它们能够正常交互。
  • 拖拽变量可以生成新的变量组,并且变量能够正确地被分配到新的组中。
  • 问题点:变量组的展开/折叠状态是共享的,导致多个变量组的状态无法独立维护。

如何解决展开/折叠状态共享的问题

针对这个问题,有两种解决方案:

方案 1:在变量组内部存储自己的展开/折叠状态
  • 目前,所有变量组可能都在使用相同的 expansion state 变量,而不是各自维护独立的状态。
  • 可以在 group 结构体中添加一个 expanded 标志,每个 group 实例单独存储自己的展开/折叠状态。
  • 这样,每个 group 的展开/折叠不会影响其他 group,从而解决状态同步问题。
方案 2:使用唯一 ID 作为状态键
  • 另一种方法是,将展开/折叠状态存储在一个全局映射(如 dictionary)中,并使用 group 的唯一 ID 作为键来访问它。
  • 这样,每个 group 通过自己的 ID 获取和存储展开/折叠状态,从而确保它们不会互相影响。
  • 这种方式适用于更复杂的状态管理需求,比如需要持久化状态或在不同会话之间保持一致。

下一步优化

  • 确认当前 group 结构体的状态管理方式,检查是否所有 group 共享同一个 expansion state 变量。
  • 选择合适的方案,决定是让每个 group 独立存储状态(方案 1),还是用映射表来管理状态(方案 2)。
  • 实现独立的展开/折叠逻辑,确保每个 group 可以独立控制自己的 UI 展示状态,而不会影响其他 group

通过这些调整,我们可以进一步优化 tear-off 逻辑,使得多个变量组不仅可以独立拖拽,而且可以独立控制展开/折叠状态,从而提供更灵活的调试体验。

game_debug.cppgame_debug.h: 介绍 DebugInteraction_MoveHierarchy

目前,我们暂时不专注于变量组的展开/折叠状态管理,而是先实现另一个重要的功能:允许用户在放置变量组后,对其进行拖动和重新定位。目前的交互方式仅支持从原始位置拖拽出新的变量组,但一旦变量组被放置,就无法再移动。因此,我们的目标是为现有的调试 UI 添加一个移动功能,使得变量组可以在屏幕上自由调整位置


实现思路

  1. 引入“移动层级”功能

    • 我们定义一个新的 UI 交互方式,比如 MoveHierarchy,它的作用是让变量组能够被拖拽移动,而不是仅仅分离。
    • 这类似于 Tear-off 功能,但区别在于 Tear-off 负责从原始变量列表中分离,而 MoveHierarchy 允许调整已放置变量组的位置。
  2. 处理鼠标拖动事件

    • 当用户开始拖动某个变量组时,系统需要记录当前拖动的是哪个 Hierarchy ID,并跟踪鼠标位置。
    • 逻辑类似于 Tear-off 处理鼠标交互的方式,但这次不创建新的变量组,而是直接调整现有变量组的位置。
  3. 存储变量组的位置

    • 目前系统没有任何机制来存储变量组的绝对位置,而所有组的显示位置可能是基于 UI 布局计算的。
    • 需要在 Hierarchy 结构体中新增一个 Position 属性,记录当前变量组的屏幕坐标。
    • 当用户拖动时,更新该 Position 值,并重新渲染 UI。
  4. 检测拖拽完成

    • 监听鼠标释放事件,当拖动结束时,更新变量组的最终位置。
    • 确保拖拽过程中不会影响变量组的层级结构(Hierarchy),仅调整其视觉上的位置。

具体实现步骤

  1. 在 UI 逻辑中添加 MoveHierarchy 入口

    • 在适当的位置(如鼠标点击事件或拖拽事件)增加 MoveHierarchy 逻辑,以便能够检测到用户尝试移动变量组。
  2. 修改变量组结构体,添加 Position 字段

    • 允许变量组记录自己的位置,使其可以随用户交互而变化。
  3. 监听拖拽事件

    • 记录当前正在拖动的 Hierarchy ID,并跟踪鼠标位置的变化,以更新变量组的 Position
  4. 在 UI 渲染时使用 Position

    • 确保 Hierarchy 的 UI 位置是基于 Position 渲染,而不是固定的布局规则。

潜在问题与解决方案

  1. 如何区分“拆分变量组”(Tear-off)和“移动变量组”(Move)?

    • 可以使用不同的鼠标按键(如 Tear-off 使用 右键,而 Move 使用 左键)。
    • 也可以添加一个模式切换,比如“编辑模式”下可以拖动,而普通模式下只能拆分。
  2. 如何防止变量组移动到不可见区域?

    • 在拖动过程中添加边界检测,确保 Position 始终在屏幕范围内。
  3. 拖拽时是否需要吸附功能?

    • 可以实现吸附到网格或其他 UI 组件的对齐功能,使得变量组更易整理。

下一步

  • 实现 MoveHierarchy 逻辑,让变量组支持拖拽。
  • 修改渲染方式,使变量组位置受 Position 控制
  • 优化交互逻辑,区分 MoveTear-off

通过这些改进,用户可以更自由地调整变量组的位置,使得调试界面的交互体验更加流畅。

game_debug.cpp: 为每个 Hierarchy 绘制 MoveBox

目前,我们正在尝试实现变量组的拖动功能,并探索最简单的实现方式。一个可能的方法是,在渲染层级(Hierarchy)时,为每个变量组创建一个“移动控制区域”,用于检测用户的拖动操作。该区域可以是变量组的一部分,例如一个小方块,作为交互热区(Hotspot)。


实现思路

  1. 在渲染层级时添加“移动框”

    • 在绘制变量组时,同时渲染一个小方块,作为拖动热区。
    • 该方块的 UI_ID 需要与对应的变量组关联,以便识别拖动操作。
  2. 放置热区位置

    • 该方块可以位于变量组的右上角、左上角,或者稍微偏移,以便用户可以清楚地区分拖动区域和其他交互区域(如展开/折叠按钮)。
    • 通过 push_rect 之类的方法,创建一个 UI 组件,代表这个热区。
  3. 检测用户拖动操作

    • 当用户点击热区并开始拖动时,记录当前选中的 Hierarchy ID
    • 追踪鼠标位置,并更新变量组的 Position 值,使其跟随鼠标移动。
  4. 渲染时更新变量组位置

    • Position 发生变化时,重新计算变量组的 UI 坐标,确保其显示在正确的位置。

具体实现步骤

  1. 定义热区并渲染

    • Hierarchy 渲染逻辑中,添加 MoveBox(拖动热区)。
    • 位置稍微偏离 Hierarchy,避免干扰其他 UI 交互。
  2. 处理拖动事件

    • 监听 MoveBox 的鼠标事件:
      • 鼠标按下:记录当前拖动的 Hierarchy ID
      • 鼠标移动:更新 HierarchyPosition 值,使其跟随鼠标。
      • 鼠标释放:停止拖动,并存储最终位置。
  3. 优化交互

    • 调整热区大小和位置,使得拖动操作易于使用,不影响其他 UI 交互。
    • 边界检测,防止变量组拖出可视区域。

下一步

  • 实现热区检测逻辑,确保拖动操作能正确识别用户的交互意图。
  • 调整 UI 细节,优化热区位置,使其既不影响用户操作,又能直观地表示拖动功能。
  • 存储和恢复位置,确保变量组的位置在刷新后不会重置。

这样,用户就可以通过拖动热区,自由移动变量组的位置,进一步提高交互体验。

game_debug.cpp: 实现移动 Hierarchy 的功能

我们在交互逻辑中引入了 拖动检测区域(MoveBox),用于判断用户是否正在拖动层级(Hierarchy)。当前的实现思路是:当鼠标进入该区域时,标记当前的交互状态,使系统知道用户想要移动某个层级对象。


具体实现逻辑

  1. 检测鼠标是否进入拖动区域

    • 在 UI 交互更新逻辑中,检查鼠标是否位于 MoveBox 内部。
    • 如果鼠标位于该区域内,就将当前的交互状态更新为“即将移动层级”(Move Hierarchy)。
  2. 标记交互状态

    • 定义 NextHotInteraction 变量,用于存储当前用户的交互目标。
    • 在检测到鼠标进入 MoveBox 后,设置 NextHotInteraction 为移动层级操作。
  3. 调整交互标记逻辑

    • 使用 NextHotHierarchy 变量来存储即将被拖动的层级 ID。
    • 这意味着:
      • 在下一帧,系统可以根据 NextHotHierarchy 确定是否需要移动某个层级。
      • 交互逻辑可以继续扩展,使得 层级拖动、交互切换等功能更加统一
  4. 未来改进方向

    • 目前,我们在不同地方使用了多个类似 NextHotHierarchy 这样的标记变量,它们的职责有些重叠,可能会导致逻辑变得复杂。
    • 计划在后续重构时,优化这些变量的管理方式,减少冗余,提高代码清晰度。

后续计划

  • 优化 NextHotHierarchy 变量的管理方式,让层级交互更清晰。
  • 在交互逻辑中更好地整合拖动功能,确保拖动、选择、展开/折叠等功能互不干扰。
  • 优化 UI 反馈机制,让用户更清晰地感知当前的交互状态。

这样,我们的层级拖动交互就会更加自然、直观。

game_debug.h: 在 debug_state 中添加 debug_hierarchy *NextHotHierarchy

我们在实现层级拖动交互的过程中,调整了 NextHotHierarchy 变量的使用方式,并尝试将其与 DraggingHierarchy 关联,以便在检测到鼠标交互后,可以正确地执行拖动操作。


具体实现步骤

  1. 设定 NextHotHierarchy

    • 在 UI 交互逻辑中,检测鼠标是否进入 MoveBox(拖动触发区域)。
    • 如果鼠标进入该区域,则将 NextHotHierarchy 设置为当前的层级对象。
  2. 更新 DraggingHierarchy

    • debug_state HotHierarchy 执行时,检查 NextHotHierarchy 的值。
    • 如果检测到 NextHotHierarchy,则将 DraggingHierarchy 赋值为 NextHotHierarchy,从而让系统知道哪个层级正在被拖动。
  3. 拖动交互逻辑

    • debug_get_interact_HotInteraction 中,确保 DraggingHierarchyinteraction 结束时被正确清除,以防止错误状态残留。
    • MoveBox 交互过程中,更新 NextHotInteraction,确保 UI 层可以正确感知拖动状态。

遇到的问题

  • 拖动状态未正确更新

    • 代码逻辑应该正确,但 NextHotHierarchy 似乎没有按预期生效,导致 DraggingHierarchy 仍然是 0,而未能正确切换到新的层级对象。
  • 可能的原因

    1. NextHotHierarchy 的赋值未能正确触发,可能是 MoveBox 计算区域有误,导致鼠标进入时未能正确触发交互更新。
    2. DraggingHierarchy 的更新逻辑可能在 interaction 结束时被错误地重置回 0,导致拖动状态丢失。

下一步改进

  1. 调试 MoveBox 碰撞检测

    • 确保 MoveBox 计算正确,并且 NextHotHierarchy 能够在鼠标进入时成功更新。
  2. 优化 DraggingHierarchy 赋值逻辑

    • 确保 DraggingHierarchy 只有在 interaction 结束后才被清除,而不会在鼠标仍然处于拖动状态时提前归零。
  3. 进一步简化 NextHotHierarchy 的管理

    • 可能需要优化变量的使用方式,以减少不必要的重复赋值,使交互逻辑更清晰。

通过这些调整,我们可以确保拖动交互能够按预期运行,让层级对象能够顺畅地拖拽和移动。

调试器: 进入 DraggingHierarchy

在调试 NextHotInteraction 赋值逻辑的过程中,发现它从未被正确设置,导致 DraggingHierarchy 无法更新,最终无法实现拖动层级的功能。


具体分析

  1. 检测 Move Box 逻辑

    • 发现 NextHotInteraction 变量未被正确赋值,意味着鼠标交互逻辑可能存在问题。
    • 需要确认 Move Box 的矩形区域是否正确计算,并检查鼠标是否真的进入了该区域。
  2. NextHotInteraction 赋值问题

    • 代码逻辑预期:如果鼠标进入 Move Box 区域,则 NextHotInteraction 需要被赋值当前的层级对象。
    • 实际情况:NextHotInteraction 似乎始终为空,说明 if 判断条件从未成立。
  3. 交互状态管理

    • 代码确保 DraggingHierarchyinteraction 结束时会被清除,但 NextHotInteraction 未能正确赋值,导致 DraggingHierarchy 无法更新。
    • 可能 NextHotInteraction 赋值代码从未被执行,或者 Move Box 检测机制未正确触发。

可能的原因

  1. 鼠标位置检测失败

    • 需要确认 Move Box 的边界是否正确计算,可能当前 Move Box 坐标与鼠标位置计算不匹配,导致 if (is_inside_rect(...)) 条件一直为 false
  2. NextHotInteraction 赋值逻辑未触发

    • 可能是在 UI 逻辑更新的顺序中,NextHotInteraction 赋值过程被某些条件限制,导致其始终为空。
  3. 事件优先级导致的覆盖

    • 可能 NextHotInteraction 被设置后,又在某些逻辑路径上被覆盖或清空,从而无法传递到 DraggingHierarchy

改进方案

  1. 调试 Move Box 检测

    • 直接打印 Move Box 的计算结果,确保它的坐标范围正确。
    • if (is_inside_rect(...)) 语句中加 printflog 语句,确认鼠标是否真的进入了 Move Box 区域。
  2. 强制设置 NextHotInteraction

    • 临时手动设置 NextHotInteraction 为某个有效值,观察是否能够正确触发 DraggingHierarchy 更新。
  3. 检查 NextHotInteraction 是否被清除

    • 在整个交互过程中打印 NextHotInteraction 的值,确认它不会被错误地提前清空。

通过这些步骤,我们可以确保 NextHotInteraction 赋值正确,使 DraggingHierarchy 能够更新,从而成功实现层级拖动交互功能。

game_debug.cpp: 清除 NextHotHierarchy

在当前的交互逻辑中,NextHotHierarchy 的清除方式实际上并不影响核心功能,因为唯一真正需要被清除的变量是 debug_interaction_none。但为了便于观察 NextHotHierarchy 的变化,仍然保留了清除逻辑。


具体分析

  1. NextHotHierarchy 清除逻辑

    • 代码当前的交互管理方式会在特定情况下清除 NextHotHierarchy,但从技术角度来看,这并不真正影响交互结果。
    • 事实上,唯一必须被清除的变量是 debug_interaction_none,因为它的状态会直接影响交互逻辑的下一步处理。
  2. 调试目的

    • 尽管 NextHotHierarchy 的清除不是必要的,但仍然保留它,以便可以通过观察其值的变化,确认交互流程是否按预期执行。
    • 这样在调试时,可以更容易地排查 NextHotHierarchy 是否在错误的时间点被清除,或是否未能正确设置。

优化方案

  1. 保留 NextHotHierarchy 的调试输出

    • 可以在交互逻辑执行过程中,打印 NextHotHierarchy 的值,以观察其变化情况。
    • 例如,在 NextHotHierarchy 赋值和清除的位置加上日志输出,以便确认它在正确的时间点发生变更。
  2. 检查 debug_interaction_none 的状态

    • 确保 debug_interaction_none 仅在必要的情况下被清除,以免意外影响 NextHotHierarchy 或其他交互状态。
  3. 优化清除逻辑

    • 既然 NextHotHierarchy 的清除并非必要,可以考虑在调试完成后移除这部分代码,以减少不必要的状态变更,提高交互逻辑的清晰度。

通过这些改进,可以确保 NextHotHierarchy 仅在必要时被清除,同时保持调试时的可观测性,以便更好地理解交互逻辑的运行情况。

game_debug.cpp: 介绍 DEBUGTextLine 以显示交互状态

在当前的交互逻辑调试过程中,我们尝试通过 DEBUGTextLine 输出调试信息,以确保 debug_state.NextHotHierarchy 在交互时是否被正确设置。


具体分析

  1. 调试 NextHotHierarchy
    • debug_interact 执行时,增加 DEBUGTextLine 以检查 NextHotHierarchy 的状态。
    • 目标是确定在交互过程中,NextHotHierarchy 是否被正确赋值,或者是否存在某些条件导致它始终为零。

  1. 检查 DEBUGBeginInteract 的执行情况

    • 由于 NextHotHierarchy 似乎已经正确检测到交互对象,但交互仍未触发,因此在 DEBUGBeginInteract 处设置断点,以确认函数是否被正确调用。
    • 这有助于排查 DEBUGBeginInteract 是否由于某些条件未被触发,例如鼠标按键未被检测到或其他条件限制。
      断点没进来
  2. 发现的问题

    • 通过调试信息发现,NextHotHierarchy 确实被正确识别,但 DEBUGBeginInteract 并未触发交互。
    • 可能的原因:
      • PlatformMouseButton_Left 事件未被检测到(例如输入状态未正确更新)。
      • DEBUGBeginInteract 逻辑存在其他前置条件,导致它未能正常执行。

优化方案

  1. 增加更多调试信息

    • 继续在 DEBUGBeginInteract 附近增加 DEBUGTextLine,以跟踪代码执行流,确保能够正确进入 DEBUGBeginInteract
  2. 检查鼠标输入处理

    • 确保 PlatformMouseButton_Left 事件能够被正确触发,检查输入管理逻辑是否存在问题,例如:
      • 鼠标点击未注册(可能由于输入系统未激活)。
      • 事件处理顺序导致 PlatformMouseButton_Left 被提前清除或覆盖。
  3. 确认 NextHotHierarchy 赋值逻辑

    • 观察 NextHotHierarchy 是否可能在某些情况下被错误清除,例如:
      • 交互状态在执行 DEBUGBeginInteract 之前被重置。
      • NextHotHierarchy 被其他逻辑覆盖。

通过这些改进,我们可以更准确地定位问题,使 DEBUGBeginInteract 正确触发,确保 NextHotHierarchy 在交互时能够正常工作。

game_debug.cpp: 让检查发生在 HotInteraction

在当前交互逻辑的调整中,我们发现 HotInteraction 的逻辑存在问题,导致 DEBUGBeginInteract 不能正确触发。


具体分析

  1. 问题原因

    • HotInteraction 应该是检测交互的主要判断条件,而之前的代码错误地使用了 next_hot_hierarchy
    • HotInteraction 本应始终被检测,并且如果存在有效交互,就应该直接执行,而不需要额外的条件判断。
    • 之前的逻辑错误导致 HotInteraction 没有正确生效,因此交互未能触发。
  2. 调整方案

    • 修正 HotInteraction 的逻辑
      • 交互逻辑调整为:如果存在 HotInteraction,那么直接设置 HotInteraction,不进行额外的条件判断。
      • 如果 HotInteraction 为空,则进入默认交互处理流程。
    • 移动 else 分支
      • else 分支逻辑应该在 HotInteraction 为空时才执行,以确保没有交互时仍然有合理的默认行为。
  3. 最终逻辑

    • 如果 HotInteraction 存在,则直接执行交互逻辑,无需额外判断。
    • 如果 HotInteraction 为空,则执行默认交互处理逻辑,以确保界面交互的完整性。
    • HotInteraction 应该在整个流程的核心位置,避免错误触发或遗漏交互检测。

优化后的代码逻辑

  1. 修正 HotInteraction 检测

    if (HotInteraction) {
        // 直接执行交互逻辑
        current_interaction = HotInteraction;
    } else {
        // 如果没有 HotInteraction,则进入默认处理逻辑
        handle_default_interaction();
    }
    
  2. 优化默认交互逻辑

    void handle_default_interaction() {
        if (user_clicked_on_nothing) {
            reset_interaction_state();
        }
    }
    

改进后的交互逻辑

  • 修正了 HotInteraction 作为主要交互检测变量的错误使用。
  • 确保交互逻辑在 HotInteraction 存在时始终执行,不受额外条件影响。
  • 增加 else 分支,确保无交互时的默认处理逻辑仍然有效。
  • 让代码结构更清晰,更容易理解 HotInteraction 何时生效。

运行游戏并再次测试

在修正了代码逻辑后,问题得到了有效解决。最初的错误源于代码的设计步骤中出现了一个疏忽,导致 HotInteraction 的处理方式不符合预期。通过回顾并修正了这一点,交互的逻辑终于变得如预期般顺畅。


当前状态

  1. 代码修复

    • 修正了 HotInteraction 的判断和执行逻辑,确保了交互过程中的有效性。
    • 通过调整交互逻辑,现在能够正确地处理交互状态。
  2. 功能恢复

    • 所有其他功能都恢复正常,交互和拖拽操作都可以顺利执行。
    • 代码中实现了“拖拽”操作,确保了界面元素的流畅移动。
  3. 修正后的行为

    • 之前的问题已解决,现在的代码能够支持拖拽操作,用户可以像预期的那样对元素进行交互。
    • 系统可以处理拖拽及拖拽后的状态变化,确保所有的交互和操作都能无误地完成。

总结

在经历了修复后的调整后,系统恢复了预期的交互功能,并且可以进行拖拽操作,界面响应也非常流畅。之前的设计疏忽已经被修正,现在系统的交互逻辑更加稳定和可靠。

game_debug.cpp: 移动 Assert(Var)

代码调整与优化

在调试过程中发现 DEBUGEndInteract 似乎默认假设交互状态始终是“正在交互中”,但这并不是我们真正想要的逻辑。因此,需要调整代码逻辑,使其不再强制要求这一点。


修正内容

  1. 移除不必要的断言

    • 发现 DEBUGEndInteract 仍然包含一个不必要的断言(assert),原本的逻辑假设交互状态在调用该函数时始终有效,但实际上并非如此。
    • 由于这并不是我们想要的行为,因此需要将其移除,避免程序因无意义的断言而崩溃。
  2. 调整交互逻辑

    • 由于 ToggleValue 在所有情况下都应该有明确的状态,因此可以考虑在更合适的位置执行该操作,避免在无效的交互状态下进行无意义的处理。

调整后的预期行为

  • DEBUGEndInteract 不再假设交互始终存在,而是更加灵活地处理交互状态。
  • 确保 ToggleValue 在适当的地方执行,避免因状态不一致导致的错误。
  • 代码更加健壮,不会因多余的断言或错误假设导致程序异常。

总结

这次调整主要是针对 DEBUGEndInteract 逻辑进行了优化,使其不再依赖于始终存在的交互状态。同时,合理地调整 ToggleValue 的执行位置,确保其行为符合预期,避免引发额外的问题。

运行游戏并检查拆分和移动功能

目前,整个 UI 系统的构建已经逐步完善,虽然仍然需要一些时间来打磨和优化,但大部分核心功能已经基本就绪。从整体来看,搭建一个合理的 UI 系统只需要几个小时,这个时间并不算长。

当前 UI 系统已经具备大部分基础功能,后续的主要任务是进行优化和美化,使其更加精致、易用。目前,系统的整体结构已经趋于完善,可以支持各种复杂的交互操作,并且在运行时能够正常工作,这一点非常重要。尽管当前的界面可能在视觉上仍然显得粗糙或简陋,但已经能够实现预期的功能,后续只需要进一步调整和优化,使其更加美观和流畅。

没有问题

目前没有任何问题需要解决,因此没有额外的内容需要讨论,一切都已完成,没有需要关注的地方。

你提到封装很重要,但不是以 OOP 的方式。你能详细说明一下你的意思吗?

封装的作用在于划分项目的不同部分,使其不被外部直接访问。当确定某些部分已经完全定型,并且不希望外部代码直接依赖它们时,就可以将这些内容从公共接口中移除。例如,可以将对外开放的函数保留在头文件(.h),而将实现细节放入源文件(.cpp),这样可以确保外部代码只调用预期的接口,而不会依赖具体的内部实现,从而提高代码的清晰度和模块化程度。

菜单项的垂直间距是均匀的吗?看起来有点奇怪

当前的文本对齐问题是由于未使用字体的实际间距,而是依赖矩形的间距进行排布。这样一来,如果某些文本没有下降部(descenders,例如字母g、j、p等的下部),它们所占的空间会相对较小,导致整体排列在视觉上显得不均匀。换句话说,不同字符的高度差异使得它们在垂直方向上的间距看起来不一致。要解决这个问题,需要基于字体的实际行高(line height)或基线对齐,而不是简单依赖矩形尺寸来计算间距。

game_debug.cpp: 使用 LineAdvance 调整行间距

当前的排版方式主要依赖于文本的实际边界(bounds)来决定布局,但由于某些字符没有下降部(descenders)或上升部(ascenders),导致文本在垂直方向上的对齐可能会出现不均匀的情况。为了解决这个问题,可以采用统一的行高(line advance)来确保所有文本元素的间距一致。

首先,调整 DEBUGGetTextSize 计算文本边界时,强制其符合统一的行高,而不是使用文本自身的边界。具体操作是,在计算文本大小时,将 bounds.min.y 设为 bounds.max.y - LineAdvance,确保每行文本的高度一致。

接着,在排版时,对于非文本元素(例如按钮或其他 UI 组件),由于它们没有行高的概念,因此需要额外添加一个 spacing_y 参数,使它们能够与文本对齐,同时保留一定的间距。这样一来,所有元素的间距都能够遵循相同的逻辑,而不会因文本字符的特性不同而出现视觉上的错位。

然后,在最终的布局计算中,确保 LeftPXTopPy 计算正确,使其能够正确地匹配 text boundsMin.xMax.x,以及 TopPy - LineAdvance 来定义统一的基准线。这样,无论文本包含何种字符,其排布都会保持一致。

最后,通过变量优化和代码重构,消除可能的变量遮蔽(shadowing)问题,确保代码逻辑清晰,同时避免因不同字符高度不一致导致的 UI 变形问题。经过这样的调整,文本对齐方式将更加稳定,使得所有 UI 元素的间距更加整齐统一。

拖动 hierarchies 时为什么会有这么大的延迟?还是只是 Twitch 的流媒体问题?

在拖动 UI 元素(例如心形图标)或进行某些交互时,存在明显的延迟和卡顿现象。经过分析,发现这种延迟主要来源于调试系统的重置(debug system reset),而不是游戏本身的性能问题。

目前的调试系统在执行调试数据整理(debug collation)时开销较大,这部分逻辑尚未进行优化。当调试数据整理触发时,会导致短暂的卡顿,因为当前的实现方式会一次性清理并重新整理所有调试数据,而不是采用增量更新的方式。

如果禁用调试数据整理(debug collation),可以明显看到拖动交互是流畅的,没有任何延迟。这表明问题并不出在 UI 渲染或游戏逻辑上,而完全是由于调试系统的重置过程导致的性能损耗。

目前的调试系统每次进行数据整理时,都会清空整个调试状态,这种做法导致短暂的帧率下降。一个更优的方案是采用增量式滚动缓冲区(incremental rolling buffer),使调试数据能够逐步更新,而不需要每次都完全重置整个状态。如果能够实现这一点,不仅能消除调试系统引起的卡顿,还能改善整体调试体验,使得 UI 交互更加顺畅。

拆分出的界面实例是应该具有相同的层级结构,还是它们应该允许独立钻取不同的内容?

当前的目标是改进 UI 交互,使得不同的调试面板(或层级结构)在拆分和调整时可以独立展开,而不会相互影响。同时,希望能够支持更自由的拖放操作,使用户可以更灵活地管理调试面板和数据分组。

目前的设计思路包括:

  1. 独立展开不同层级:允许用户单独展开某个层级,而不影响其他同类型的面板。这样可以更直观地查看不同类别的数据,而不导致所有相同类型的面板都同时发生变化。

  2. 可扩展的拖放交互

    • 允许用户拖拽某个调试项,并将其附加到现有面板中,而不是只能进行单独的拆分操作。
    • 例如,用户当前在一个面板中查看某项调试数据(如 UI 状态),如果想要将 “Debug Camera” 添加到当前面板中,应该能够轻松拖拽并合并,而不需要额外的步骤。
  3. 创建自定义分组

    • 允许用户通过拖拽方式创建新的调试数据分组,而不是只能使用固定的预设分组。
    • 例如,用户可以选择一部分调试项,并将它们拖动到一个新创建的容器中,以便组织数据。

实现这一功能的技术要点:

  • 在拖放时增加逻辑,检测目标区域是否允许合并,如果允许,则将拖拽的元素插入到目标面板或分组中。
  • 在界面渲染时,确保不同的面板状态是独立存储的,而不会互相干扰。
  • 提供合适的 UI 反馈,比如在拖拽过程中高亮目标区域,以提示用户可以放置数据的位置。

这项改进能够使调试 UI 更加灵活,允许用户根据自己的需求定制界面布局,提高操作效率和可视化效果。

我注意到你使用 internal 关键字,我之前没见过,它的作用是什么?

internal 只是一个宏定义,它的作用是被 #define 预处理器指令定义为 static。换句话说,在代码中看到的 internal 关键字,实际上在编译时都会被替换成 static

作用

在 C 或 C++ 代码中,static 关键字用于控制变量或函数的作用域:

  1. 对于函数:声明为 static 的函数仅在定义它的 编译单元(即源文件 .c.cpp)内部可见,不能被其他文件访问。
  2. 对于变量
    • 全局 static 变量:作用域限制在当前编译单元,不会被其他文件访问。
    • 局部 static 变量:在函数内部声明的 static 变量,其值在整个程序运行过程中保持不变,不会在每次函数调用时重新初始化。

为什么使用 internal

通常,internal 只是用作 static 的别名,这是代码风格上的选择:

  • 提高可读性internal 让代码更具语义化,明确表示这个函数或变量是“内部使用的”,不会暴露给其他编译单元。
  • 减少命名冲突:由于 static 变量和函数的作用域仅限于当前文件,避免了多个文件中同名函数或变量引起的冲突。
  • 符合特定代码规范:一些代码库或项目使用 internal 代替 static,统一风格。

示例

#define internal static

internal int InternalFunction() {
    return 42;
}

int PublicFunction() {
    return InternalFunction();
}

在这里,internal 只是 static 的替代写法,使 InternalFunction 仅在当前文件可见,外部文件无法访问它。

总结

  • internal 只是 #define internal static 的宏定义,本质上就是 static
  • 主要用于标记仅限当前编译单元使用的函数或变量
  • 这样做的目的是增强可读性,减少命名冲突,同时符合某些项目的代码风格规范。

抱歉,我加入得比较晚,出于好奇,你在拖动子部分时使用的容差(像素)是多少?

当前的实现方式并没有使用特定的像素阈值来判断拖拽子区域的操作,而是直接通过 右键点击 触发该功能。

在交互过程中,用户可以通过 按住右键 并拖拽来执行子区域的拆分或拖动,而不依赖于特定的像素距离来判定是否进行拖拽。这种方式相对简单,避免了设定拖拽敏感度的问题,也确保了交互的直接性和即时反馈。

从逻辑上来看,这种方法省去了对鼠标位移距离的检测,不需要设定一个固定的拖拽判定阈值,例如 “拖拽超过 X 像素才会生效” 之类的规则。这样,只要用户按住右键并移动鼠标,就会直接进入拖拽模式,从而实现对界面子部分的拆分或移动。

这种实现方式的优点是:

  • 减少误触:相比于基于像素阈值的拖拽判定,右键拖拽的方式更明确,不容易因为鼠标的微小移动而触发拖拽。
  • 交互直观:用户只需记住使用右键即可拆分和拖动,而不需要关心鼠标移动的距离是否超过某个限制。
  • 代码逻辑简洁:不需要额外检测鼠标位移的阈值,使得实现方式更加直接和高效。

如果未来需要改进,可以考虑引入 拖拽判定阈值,比如设定一个最小拖拽距离(如 5-10 像素),以避免误操作。

你提到在工作中使用元编程来处理链表,你是指什么?

在当前的实现中,已经有一个 用于生成结构化内容的系统,它能够自动创建一些结构化的元素,使得开发过程中不需要手动重复编写类似的内容,而是由系统 自动生成 这些部分。

这个系统的作用主要是处理 超结构化(super structural) 的内容,也就是一些 通用模板或固定模式的结构,可以在不同的情况下重复使用。例如,某些 UI 组件、调试信息面板、数据可视化布局等,都可以通过这个系统 自动构建,而不是手动编写每一个部分。

具体来说,这个系统的特点包括:

  • 自动生成基础结构:不需要手动定义某些 UI 元素或调试窗口,系统会根据已有的逻辑自动创建它们,并填充对应的数据或信息。
  • 减少重复代码:开发人员不需要手动编写相同的代码片段,而是可以依赖系统提供的生成机制,让代码更加简洁和模块化。
  • 动态适应需求:如果数据或逻辑发生变化,这个系统能够动态地调整结构,而不需要手动修改代码,使得界面和功能更加灵活。
  • 提高开发效率:对于某些需要频繁调整的内容,例如调试界面、工具面板、数据展示等,使用这个系统可以快速调整布局,而不需要手动更新每一个元素。

简单来说,这个系统相当于一个 自动化的结构生成工具,它能够在运行时或开发时帮助创建一些固定模式的内容,从而简化工作流程,提高开发效率。

我错过了 90% 的直播,想请教一下游戏设计的入门建议?有哪些值得做的事情和需要避免的坑?

如果有兴趣进入游戏设计领域,以下是一些 值得注意的做法和避免的错误,以及一些简单而有效的建议:

做法(Do’s):

  1. 从基础做起

    • 了解并掌握游戏设计的基本原则,如玩家体验、游戏机制、平衡性等。
    • 学习并熟练使用一些游戏设计工具和引擎,比如Unity、Unreal Engine或Godot等。
  2. 注重玩家体验

    • 游戏设计的核心是 玩家体验,确保游戏设计考虑到玩家的互动、反馈以及可玩性。
    • 在设计游戏时,可以多进行 用户测试,通过玩家的反馈来调整和优化设计。
  3. 从简单的项目开始

    • 不要一开始就尝试做复杂的游戏,应该先从小型项目或原型开始,逐步积累经验。
    • 制作简单的小游戏或工具,帮助理解基本的游戏机制和设计流程。
  4. 学习并借鉴成功的游戏

    • 研究和分析市场上已有的成功游戏,学习它们的设计理念、玩法和用户交互方式。
    • 了解不同类型的游戏及其玩家群体,掌握各种游戏类型的设计要素。
  5. 多与其他设计师交流

    • 加入游戏开发社区,参与讨论、分享和学习他人的经验。与其他开发者、设计师进行 合作反馈,有助于提升自己的设计水平。

不做的事情(Don’ts):

  1. 避免忽视游戏平衡性

    • 游戏的 平衡性 是非常重要的。设计时不要过于偏向某种玩法或角色,而忽略其他部分的体验。
    • 避免让某一玩法过强,或者让游戏机制过于复杂,让玩家感到困惑。
  2. 不要陷入完美主义

    • 游戏设计过程中,过分追求完美可能会导致项目拖延,甚至无法完成。快速迭代快速验证设计思路才是关键。
    • 要学会在有限时间内做出 妥协,然后通过反馈继续优化。
  3. 避免忽视可玩性和互动性

    • 游戏不只是视觉和声音效果好看,互动性和趣味性才是留住玩家的关键。
    • 不要仅仅依赖于华丽的图像或复杂的机制,最终还是要确保玩家有趣、刺激的体验。
  4. 避免忽略优化和性能

    • 在设计游戏时要始终考虑 性能优化,确保游戏能够流畅运行,尤其是当目标设备是性能有限的设备时。
  5. 不要过度设计

    • 游戏设计应该有节制,不要过度添加复杂的功能或玩法,保持简洁,让玩家能够快速上手,避免冗余设计。

简单而有效的建议:

  • 保持好奇心和学习的态度:游戏设计领域不断变化,新技术和新理念不断涌现,要始终保持学习的心态。
  • 了解玩家:无论是从玩家的角度设计,还是通过测试收集反馈,都要关注玩家的需求和反应。
  • 制作原型:通过制作原型和简单的游戏测试,可以帮助发现潜在的问题并及时调整。
  • 团队合作:游戏设计是一个多学科的合作过程,学会和程序员、艺术家等其他成员有效沟通并协作。

总的来说,游戏设计是一项充满创造力和挑战的工作,通过不断学习、实践和反思,可以不断提升自己。

未来有计划支持其他平台吗?

关于这个项目,未来计划支持多个平台。虽然目前关注的是编程部分,但确实有意在未来扩展到不同的平台,这意味着这个项目将会在多个平台上得到支持和运行。

你有没有为 PS1 编写过任何代码?(我记得 Jeff 在 J&C 的某一集里提到过)

关于PS One的相关内容,并没有涉及。

你玩过 Space Quest 系列游戏吗?网站上的音乐让我想起了它的配乐

提到了对太空探索类游戏的了解,特别是提到了与《Space Quest》相关的音乐。对这款游戏的音乐记忆不深,计划去重新听一下以唤起记忆。

你打算对文本渲染中的字符间距做一些调整吗?

讨论了是否有计划在文本渲染中处理字符间距的问题。提到在某个项目中已经有相关实现,并询问对方具体指的是哪种类型的字符间距处理。

“sentinel” 是一种设计模式,可以帮助拆分的 UI 实例独立运作,还是这是你在工具开发过程中积累的术语?现在我理解了你所谓的“拆分”界面,感觉确实对独立管理层级很有用

讨论了设计模式的概念,特别是如何利用双向链表来处理接口的拆分。提到当创建双向链表时,常常使用链表中的一个元素作为头尾指针,从而帮助管理不同的层次结构或数据。还提到曾经有过一集讨论如何实现和理解这种链表结构。

这不是什么大问题,但现在标签不再显示点击后会展开还是折叠。此外,目前也不太清楚哪些是类别,哪些是变量

讨论了关于标签的问题,提到目前点击标签后它们会展开或最小化,但从外观上看,标签没有显示出来。这种情况还没有在界面渲染上做任何处理,意味着这些只是初步的概念,还没有实现完整的渲染功能。

哪款游戏主机的 SDK 体验最糟糕?

讨论了不同游戏控制台的SDK(软件开发工具包),并指出任天堂的SDK通常是最差的。根据记忆,任天堂每次发布的SDK都是最差的,并且至今没有被超越,尽管也有可能记错。这只是个人的回忆。

本文地址:https://www.vps345.com/6934.html

搜索文章

Tags

docker 容器 运维 java-rabbitmq java 智能驾驶 BEVFusion Ubuntu 服务器带宽 上行带宽 上行速率 什么是上行带宽? PV计算 带宽计算 流量带宽 macos windows linux 服务器 嵌入式硬件 #docker #centos #容器 网络 远程连接 vscode pytorch tensorflow #windows #自动化 #运维 ubuntu 无人机 机器人 github 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP ide AI Dify 大模型应用 CC攻击 攻击怎么办 安全 ubuntu24.04 todesk 云原生 c# 开发语言 网络协议 网络安全 ssh漏洞 ssh9.9p2 CVE-2025-23419 ai nlp ssh remote-ssh python c++ php centos 人工智能 #git #ssh #windows 边缘计算 具身智能 强化学习 华为 conda ROS 自动驾驶 经验分享 wireshark #linux #命令 #网络 IPMI ollama llm #macos #EasyConnect 远程工作 harmonyos react native 部署 tomcat #harmonyos #android #ios debian wps 安卓 语言模型 AI大模型 DeepSeek agi micropython esp32 单片机 mqtt 物联网 #ubuntu #linux 深度学习 #java #华为 数据库 mysql adb 自动化 n8n LLM 大模型面经 大模型 职场和发展 Deepseek 大模型学习 中间件 web安全 可信计算技术 安全架构 网络攻击模型 存储维护 NetApp存储 EMC存储 AIGC comfyui comfyui教程 虚拟机 网络药理学 生信 分子对接 autodock mgltools PDB PubChem #javascript #开发语言 #ecmascript kylin r语言 数据挖掘 数据可视化 数据分析 机器学习 快捷键 旋转屏幕 自动操作 #jenkins #人工智能 #云原生 flutter Google pay Apple pay ddos CosyVoice 持续部署 jenkins Playwright pythonai PlaywrightMCP prometheus grafana 3d svn zabbix golang 算法 开源 dity make intellij-idea Linux 维护模式 #区块链 #智能合约 服务器安全 网络安全策略 防御服务器攻击 安全威胁和解决方案 程序员博客保护 数据保护 安全最佳实践 bash 编辑器 pip Agent llama CrewAI 小程序 html http json css django fastapi 后端 智能路由器 自然语言处理 ssl git 华为云 华为od web3 区块链 区块链项目 YOLO gpu算力 Java进程管理 DevOps自动化 脚本执行 跨平台开发 远程运维 Apache Exec JSch rag ragflow 大模型部署 MVS 海康威视相机 springsecurity6 oauth2 授权服务器 前后端分离 MCP DevEco Studio HarmonyOS OpenHarmony 真机调试 游戏引擎 学习 unity GameFramework HybridCLR Unity编辑器扩展 自动化工具 性能优化 阿里云 云计算 spring boot spring YOLOv8 NPU Atlas800 A300I pro onlyoffice 在线office c语言 计算机网络 bug 运维开发 智能合约 压力测试 哈希算法 MacMini Mac 迷你主机 mini Apple 鸿蒙 混合开发 环境安装 JDK linux环境变量 gnu unix iot 计算机视觉 opencv 目标检测 rk3588 npu rknn-toolkit2 群晖 低代码 1024程序员节 单例模式 chatgpt 飞牛NAS 飞牛OS MacBook Pro AI编程 visual studio code kvm qemu libvirt 课程设计 负载均衡 Cline ESXi Dell HPE 联想 浪潮 GCC crosstool-ng typescript 微信 设计模式 电路仿真 multisim 硬件工程师 硬件工程师学习 电路图 电路分析 仪器仪表 nvcc cuda A100 nginx prompt AI提示词优化 搜索引擎 程序员 SSH Linux Xterminal open webui rtsp h.265 vite Svelte 实时音视频 实时互动 技能大赛 qt linuxdeployqt 打包部署程序 appimagetool 爬虫 dash 正则表达式 网络工程师 华为认证 stm32 tcp/ip android studio 交互 websocket android 硬件工程 Qwen3 qwen3 32b vllm 本地部署 milvus 向量数据库 word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 Kylin-Server 国产操作系统 服务器安装 CUDA PyTorch aarch64 编译安装 HPC 银河麒麟 信创国产化 达梦数据库 mybatis appium 软件测试 自动化测试 功能测试 程序人生 yolov5 apache pdf xml uniapp vue ansible playbook 自动化运维 vmamba mamba postgresql ffmpeg 音视频 视频编解码 redis uni-app m3u8 HLS 移动端H5网页 APP安卓苹果ios 监控画面 直播视频流 #激光雷达 #览沃 #ubuntu22.04 #ros2 #大疆 kubernetes k8s 程序 编程 内存 性能分析 动态库 GCC编译器 -fPIC -shared elasticsearch dify dify部署 gpt transformer rust 前端 okhttp springboot容器部署 springboot容器化部署 微服务容器化负载均衡配置 微服务容器多节点部署 微服务多节点部署配置负载均衡 ruoyi 交换机 硬件 设备 GPU PCI-Express iventoy VmWare OpenEuler pgpool chrome chrome devtools selenium chromedriver mac fpga开发 笔记 DevOps 大数据 软件交付 数据驱动 应用场景 数据安全 Docker Docker Compose Kubernetes rpc 远程过程调用 Windows环境 vue.js javascript 服务器配置 图像处理 其他 deepseek 截图 录屏 gif 工具 searxng SenseVoice 远程桌面 嵌入式 linux驱动开发 arm开发 鸿蒙系统 hdc 鸿蒙NEXT 进程信号 智能体开发 三维重建 oceanbase 传统数据库升级 银行 MS Materials rc.local 开机自启 systemd 麒麟 FunASR ASR LVS 蓝桥杯 openjdk Claude Desktop Claude MCP Windows Cli MCP 计算机学习路线 编程语言选择 王者荣耀 HTTP 服务器控制 ESP32 DeepSeek WSL2 上安装 Ubuntu openssl 计算机外设 数据集 MobaXterm 文件传输 node.js 大模型压力测试 EvalScope 华为机试 C++ Java Python LLM Web APP Streamlit HTTP状态码 客户端错误 服务器端错误 API设计 进程间通信 智能手机 安全威胁分析 安全性测试 多线程服务器 Linux网络编程 硬件架构 系统架构 EasyConnect glibc UOS 开机自启动 桌面快捷方式 vue3 语音识别 AutoDL Qwen2.5-VL 企业微信 servlet Docker Hub docker pull 镜像源 daemon.json rabbitmq 知识图谱 大模型教程 科技 Windows ai工具 视频平台 录像 RTSP 视频转发 性能测试 视频流 存储 oracle 关系型 分布式 监控 安卓模拟器 GPU训练 wsl 多线程 进程 pthread 系统 webpack 策略模式 mac安装软件 mac卸载软件 mac book LLMs GenAI LLM 推理优化 LLM serving 鲲鹏 昇腾 金融 openEuler 欧拉系统 嵌入式Linux IPC FTP 服务器 llama3 Chatglm 开源大模型 chatbox 麒麟OS 软件工程 软件构建 burpsuite 安全工具 mac安全工具 burp安装教程 渗透工具 开发工具 基础指令 指令 langchain deep learning 政务 分布式系统 监控运维 Prometheus Grafana pygame 相机 主从复制 cron crontab日志 word microsoft coze SSE mcu 飞腾处理器 国产化 EVE-NG 操作系统 openwrt USB网络共享 Portainer搭建 Portainer使用 Portainer使用详解 Portainer详解 Portainer portainer 换源 国内源 Debian Kali 渗透 #embedding #网络 #dify MCP server agent C/S 驱动开发 嵌入式实习 DNS dubbo 三级等保 服务器审计日志备份 大大通 第三代半导体 碳化硅 elk 架构 安全漏洞 信息安全 信息与通信 yum apt ui HarmonyOS Next YOLOv12 神经网络 docker desktop image MLLMs VLM gpt-4v 工作流自动化工具 bushujiaocheng 部署教程 算家云 AI算力 租算力 到算家云 毕设 pycharm maven 学习方法 GIS 遥感 WebGIS 个人开发 程序化交易 量化交易 高频交易 jvm muduo 网络库 云计算面试题 arkUI arkTs SecureCRT 流程图 mermaid 环境部署 工作流 workflow 信号处理 flash-attention 报错 计算生物学 生物信息学 生物信息 基因组 ShapeFile GeoJSON Nginx fiddler Apache Flume 数据采集 安装部署 配置优化 高级功能 大数据工具集成 kind xrdp 环境迁移 微信开放平台 flask 微信公众平台 微信公众号配置 matlab hadoop big data wsl2 CH340 串口驱动 CH341 uart 485 harmonyOS面试题 iNode Macos rpa 缓存 eureka spring cloud 知识库 本地化部署 网页服务器 web服务器 visualstudio Autoware 辅助驾驶 FTP服务器 stm32项目 系统安全 统信 虚拟机安装 Deepseek-R1 私有化部署 推理模型 前端框架 Cursor Bug解决 Qt platform OpenCV ros 树莓派项目 ragflow 源码启动 电脑 devops 防火墙 ufw iBMC UltraISO 集成学习 集成测试 大模型入门 jupyter 云服务器 https 反向代理 web3.py Windsurf tcpdump element-ui 上传视频并预览视频 vue上传本地视频及进度条功能 vue2选择视频上传到服务器 upload上传视频组件插件 批量上传视频 限制单个上传视频 gitee gitee go cursor latex RTX5090 torch2.7.0 Ollama RAGFlow 本地知识库部署 DeepSeek R1 模型 网络结构图 yaml Ultralytics 可视化 环境配置 Vmamba 线程 卷积神经网络 镜像 nohup 异步执行 ACL 流量控制 基本ACL 网络管理 规则配置 游戏 H3C 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 外网访问 内网穿透 端口映射 jar 话题通信 服务通信 Chatbox glm4 mariadb Claude 计算机系统 网络编程 cmake react.js vim QQ bot 测试工具 程序员创富 gcc centos 7 安装MySQL 物理地址 页表 虚拟地址 RAG Multi-Agent 开源软件 百度 paddlepaddle 雨云 NPS IMM 统信操作系统 游戏服务器 Minecraft 宝塔面板 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 代码调试 ipdb tidb GLIBC windows 服务器安装 umeditor粘贴word ueditor粘贴word ueditor复制word ueditor上传word图片 抽象工厂模式 电子信息 通信工程 毕业 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 nvm node 微服务 数据结构 eclipse Linux Vim IPv4/IPv6双栈 双栈技术 网路规划设计 ensp综合实验 IPv4过渡IPv6 IPv4与IPv6 烟雾检测 yolo检测 消防检测 记账软件 springboot 容器部署 NAS Termux Samba Dell R750XS triton 模型分析 UOS1070e webrtc NVML nvidia-smi mcp mcp协议 go-zero mcp服务器 vmware tools VMware 生成对抗网络 Spring AI 大模型应用开发 AI 应用商业化 sequoiaDB 华为鸿蒙系统 ArkTS语言 Component 生命周期 条件渲染 Image图片组件 RockyLinux 迁移 openeuler list 远程 命令 执行 sshpass 操作 perl arm Alist rclone mount 挂载 网盘 论文笔记 udp HCIE 数通 RAID RAID技术 磁盘 open Euler dde deepin 统信UOS 智能硬件 sql 游戏程序 Java Applet URL操作 服务器建立 Socket编程 网络文件读取 grub 版本升级 扩容 Pyppeteer ipython trae cudnn nvidia sdkman nftables vmware chromium dpi 文档 zephyr #服务器 #c语言 #git #vim 抓包工具 PX4 k8s部署 MySQL8.0 高可用集群(1主2从) GPUGEEK 考研 代理模式 线程互斥与同步 框架搭建 RustDesk自建服务器 rustdesk服务器 docker rustdesk 自定义客户端 SAS 常用命令 文本命令 目录命令 opensearch helm 弹性计算 裸金属服务器 弹性裸金属服务器 虚拟化 服务器扩容没有扩容成功 ftp服务 文件上传 PyQt PySide6 矩阵乘法 3D深度学习 gemini gemini国内访问 gemini api gemini中转搭建 Cloudflare 软件需求 embedding UEFI Legacy MBR GPT U盘安装操作系统 archlinux kde plasma 实时内核 Obsidian Dataview 5G seatunnel #centos #vscode #ubuntu MQTT mosquitto 消息队列 HP Anyware 树莓派 Navidrome AI-native 7-zip gitlab 源代码管理 微信小程序 notepad++ NFS 重启 排查 系统重启 日志 原因 virtualenv g++ g++13 paddle shell libreoffice word转pdf 安装 代码复审 codereview code-review 腾讯云大模型知识引擎 yolov8 rnn docker compose 终端工具 远程工具 deepseek-v3 ktransformers RagFlow 密码学 ESP32 我的世界 我的世界联机 数码 ISO镜像作为本地源 性能监控 ip 虚拟显示器 远程控制 我的世界服务器搭建 minecraft ArkTs ArkUI ROS2 iTerm2 IP地址 IPv4 IPv6 端口号 计算机基础 Kali Linux ecmascript KVM 网络建设与运维 网络搭建 神州数码 神州数码云平台 云平台 性能调优 安全代理 jellyfin nas rocketmq C语言 升级 CVE-2024-7347 漏洞 僵尸世界大战 游戏服务器搭建 html5 less jmeter 分布式账本 信任链 共识算法 python2 maxkb ARG ollama api ollama外网访问 lvgl8.3 lvgl9.2 lvgl lvgl安装 拓扑图 ai小智 语音助手 ai小智配网 ai小智教程 esp32语音助手 diy语音助手 etcd cfssl go 计算机八股 物联网开发 adobe rust腐蚀 分布式训练 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 hive ranger MySQL8.0 p2p bigdata OpenGL 图形渲染 CPU架构 服务器cpu 若依 内存不足 outofmemory Key exchange 主包过大 ECS API Uvicorn xcode 命名管道 客户端与服务端通信 cocoapods notepad 隐藏文件 zookeeper 火绒安全 mybase easyTier 组网 渗透测试 系统内核 Linux版本 nac 802.1 portal eNSP 企业网络规划 华为eNSP 网络规划 ip命令 新增网卡 新增IP 启动网卡 前端面试题 jdk 创业创新 LSTM 仙盟大衍灵机 东方仙盟 仙盟创梦IDE odoo 服务器动作 Server action ukui 麒麟kylinos thingsboard 云服务 midjourney AI写作 KylinV10 麒麟操作系统 Vmware Netty ios AI员工 状态模式 数学建模 MacOS 向日葵 CPU 使用率 系统监控工具 linux 命令 stable diffusion AI作画 burp suite 抓包 打不开xxx软件 无法检查其是否包含恶意软件 arcgis 产品经理 vnc FS 文件系统 bootfs rootfs linux目录 鸿蒙项目 ShenTong 人工智能生成内容 docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos 文心一言 Mermaid 可视化图表 自动化生成 postgres Docker Desktop Dify重启后重新初始化 小智 面试 dns是什么 如何设置电脑dns dns应该如何设置 VSCode 豆瓣 追剧助手 迅雷 express CORS 跨域 音乐服务器 音流 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap tailscale derp derper 中转 CDN .netcore .net core .net NFC 近场通讯 智能门锁 rsync 客户端-服务器架构 点对点网络 服务协议 网络虚拟化 网络安全防御 LangGraph CLI JavaScript langgraph.json 毕业设计 struts 物联网嵌入式开发实训室 物联网实训室 嵌入式开发实训室 物联网应用技术专业实训室 桌面环境 sqlserver yum换源 kernel function address 函数 地址 内核 开发环境 微软 gstreamer 流媒体 can 线程池 OpenSSH DocFlow 虚拟局域网 ros2 moveit 机器人运动 kali 共享文件夹 网卡 显卡驱动持久化 GPU持久化 网络爬虫 卸载 软件 列表 Crawlee perf 健康医疗 #人工智能 #深度学习 #机器学习 #考研 #计算机视觉 Trae IDE AI 原生集成开发环境 Trae AI 单一职责原则 虚幻 python3.11 pyside6 界面 Python 视频爬取教程 Python 视频爬取 Python教程 Python 视频教程 开发效率 Windmill 源码 anaconda fstab Charles vsxsrv 环境变量 Android ANDROID_HOME zshrc Logstash 日志采集 minicom 串口调试工具 网络用户购物行为分析可视化平台 大数据毕业设计 yum源切换 更换国内yum源 监控k8s集群 集群内prometheus miniapp 调试 debug 断点 网络API请求调试方法 云原生开发 接口优化 k8s二次开发 zip unzip edge 软考设计师 中级设计师 SQL 软件设计师 gru nohup后台启动 超级终端 多任务操作 提高工作效率 unionFS OverlayFS OCI docker架构 写时复制 issue Docker 部署es9 Docker部署es Docker搭建es9 Elasticsearch9 Docker搭建es dell服务器 minio kafka 黑客 计算机 游戏开发 网站搭建 serv00 博客 saltstack 机柜 1U 2U postman aws centos-root /dev/mapper yum clean all df -h / du -sh 京东云 protobuf 序列化和反序列化 ubuntu20.04 开机黑屏 linux内核 gpt-3 miniconda HP打印机 增强现实 沉浸式体验 技术实现 案例分析 AR 宝塔面板无法访问 tar kubeless lvs Agentic Web NLWeb 自然语言网络 微软build大会 rdp 实验 大模型微调 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 云电竞 云电脑 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 大模型推理 服务器繁忙 PVE 网工 聊天室 bonding 链路聚合 状态管理的 UDP 服务器 Arduino RTOS 剧本 图形化界面 React Next.js 开源框架 aac 媒体 进程控制 鸿蒙开发 移动开发 Echarts图表 折线图 柱状图 异步动态数据 可视化效果 ArkTS css3 js homebrew windows转mac ssh密匙 Mac配brew环境变量 TRAE AI代码编辑器 车载系统 3GPP 卫星通信 DBeaver 数据仓库 kerberos 大语言模型 seleium WSL ip协议 opengl 脚本 android-studio 冯诺依曼体系 STP 生成树协议 PVST RSTP MSTP 防环路 网络基础 局域网 armbian u-boot 技术 react next.js 部署next.js nuxt3 文件分享 WebDAV outlook dba IM即时通讯 剪切板对通 HTML FORMAT AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 massa sui aptos sei Featurize Mobilenet 分割 ArcTS 登录 ArcUI GridItem 灵办AI 稳定性 看门狗 docker-compose Ubuntu 22.04 MySql 算力租赁 安装教程 Ubuntu20.04 2.35 软件商店 信创 livecd systemtools SystemV 更换镜像源 charles #IntelliJ IDEA #Java #Kotlin SSH 服务 SSH Server OpenSSH Server Open WebUI mcp-proxy mcp-inspector fastapi-mcp sse WSL2 ubuntu安装 linux入门小白 计算机科学与技术 远程服务 java-ee ajax 二级页表 数据链路层 AD域 计算虚拟化 弹性裸金属 致远OA OA服务器 服务器磁盘扩容 asp.net大文件上传 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 .net mvc断点续传 wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 显示器 localhost janus linq flink DICOM cn2 带宽 #服务器 neo4j 数据库开发 database initramfs Linux内核 Grub 星河版 mac设置host 磁盘挂载 新盘添加 partedUtil orbslam2 ubuntu22.04 鸿蒙面试 面试题 tftp nfs 模块测试 药品管理 团队开发 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 excel x64 SIGSEGV xmm0 numpy OpenManus Typore 7z autoware Masshunter 质谱采集分析软件 使用教程 科研软件 lstm LSTM-SVM 时间序列预测 v10 mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 SSL证书 unity3d 无桌面 命令行 模拟退火算法 gaussdb 腾讯云 llama.cpp 客户端 大模型训练/推理 推理问题 mindie 商用密码产品体系 sqlite linux cpu负载异常 Cache Aside Read/Write Write Behind SRS chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 prometheus数据采集 prometheus数据模型 prometheus特点 Qwen2.5-coder 离线部署 ArtTS 系统开发 binder framework 源码环境 openvpn server openvpn配置教程 centos安装openvpn 华为证书 HarmonyOS认证 华为证书考试 GPU环境配置 Ubuntu22 Anaconda安装 Ardupilot 代码 对比 meld Beyond Compare DiffMerge npm RAGflow 热榜 单元测试 测试用例 ue4 着色器 ue5 gromacs 分子动力学模拟 MD 动力学模拟 监控k8s 监控kubernetes powerpoint mongodb Xshell 文件共享 切换root nacos Typescript authorized_keys 密钥 rustdesk 信息收集 银河麒麟高级服务器 外接硬盘 Kylin C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 SWAT 配置文件 服务管理 网络共享 毕昇JDK Jellyfin 硅基流动 ChatBox 日志分析 系统取证 5090 显卡 AI性能 flinkcdc make命令 makefile文件 版本 c/c++ 串口 resolv.conf NVM Node Yarn PM2 brew swift VLAN 企业网络 PPI String Cytoscape CytoHubba 自动化任务管理 easyui 私有化 cnn VGG网络 卷积层 池化层 开放端口 访问列表 去中心化 Spring Boot 全文检索 es pppoe radius spark HistoryServer Spark YARN jobhistory pillow tcp gitea frp 内网服务器 内网代理 内网通信 数据库系统 Headless Linux 即时通信 NIO Anolis nginx安装 linux插件下载 firefox LDAP AD 域管理 录音麦克风权限判断检测 录音功能 录音文件mp3播放 小程序实现录音及播放功能 RecorderManager 解决录音报错播放没声音问题 gunicorn 锁屏不生效 fpga 概率论 过期连接 材料工程 服务发现 edge浏览器 智慧农业 开源鸿蒙 IP 地址 管道 pipe函数 匿名管道 管道的大小 匿名管道的四种情况 NVIDIA显卡安装 Ubuntu开机黑屏 #chrome #mac #拓展程序 #禁用 深度求索 私域 ubuntu24.04.1 Linux24.04 firewalld 路径解析 rime top Linux top top命令详解 top命令重点 top常用参数 Apache Beam 批流统一 案例展示 数据分区 容错机制 大屏端 裸机装机 linux磁盘分区 裸机安装linux 裸机安装ubuntu 裸机安装kali 裸机 MAVROS 四旋翼无人机 企业风控系统 互联网反欺诈 DDoS攻击 SQL注入攻击 恶意软件和病毒攻击 risc-v Quixel Fab Unity UE5 游戏商城 虚幻引擎 进程状态 僵尸进程 MySQL lsof linux命令 autodl cpu 实时 使用 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 模型联网 CherryStudio api 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP X11 Xming vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 samba 宝塔 笔灵AI AI工具 es6 qt6.3 g726 华为昇腾910b3 finebi 网络接口 时间间隔 所有接口 多网口 实时传输 lua 高考 省份 年份 分数线 数据 log4j mcp client mcp server 模型上下文协议 C 进程地址空间 沙盒 pyicu 推荐算法 pycharm安装 harmonyosnext illustrator 互联网医院 openstack Xen Hyper-V Reactor Node-Red 编程工具 流编程 deekseek intellij idea 设置代理 实用教程 LVM 磁盘分区 lvresize 磁盘扩容 pvcreate 图搜索算法 client-go OS NVIDIA 转换 深度强化学习 深度Q网络 Q_Learning 经验回收 CAN 多总线 模拟器 pnet pnetlab 网络配置 路由配置 磁盘监控 dns 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 云桌面 AD域控 证书服务器 Web服务器 多线程下载工具 PYTHON solidworks安装 web 串口服务器 万物互联 工业自动化 工厂改造 teamspeak 显卡驱动 nvidia驱动 Tesla显卡 排序算法 cs144 零售 AudioLM scrapy iftop 网络流量监控 Hive环境搭建 hive3环境 Hive远程模式 进程优先级 调度队列 进程切换 kotlin iphone 动静态库 milvus安装 Metastore Catalog 软硬链接 文件 RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 卡死 Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 RBAC 显示过滤器 ICMP Wireshark安装 DeepSeek r1 蓝牙 汇编 csapp 缓冲区 #redis 流式接口 rsyslog pyqt XCC Lenovo db 浪潮信息 AI服务器 YashanDB 崖山数据库 yashandb logstash gitlab服务器 深度优先 客户端/服务器架构 分布式应用 三层架构 Web应用 跨平台兼容性 邮件APP 免费软件 Xinference CUPS 打印机 Qt5 csrf 苹果电脑装windows系统 mac安装windows系统 mac装双系统 macbook安装win10双 mac安装win10双系统 苹果电脑上安装双系统 mac air安装win 北亚数据恢复 数据恢复 服务器数据恢复 数据库数据恢复 oracle数据恢复 更新apt 安装hadoop前的准备工作 离线部署dify 办公自动化 pdf教程 iperf3 带宽测试 docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 mq Helm k8s集群 ros1 Noetic 20.04 apt 安装 考试 软考 webview RDP 进程池实现 百度云 BCLinux 智能体 开发 Jenkins流水线 声明式流水线 软件安装 Linux权限 xshell 权限掩码 粘滞位 量子计算 双系统 多系统 嵌入式实时数据库 pandas matplotlib 分类 dataworks maxcompute 数字化转型 驱动器映射 批量映射 win32wnet模块 网络驱动器映射工具 shell编程 sse_starlette Starlette FastAPI Server-Sent Eve 服务器推送事件 xop RTP RTSPServer 推流 视频 直播推流 mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 项目部署到linux服务器 项目部署过程 信创终端 中科方德 Carla ECS服务器 MultiServerMCPC load_mcp_tools load_mcp_prompt SFTP SFTP服务端 uni-popup报错 连接服务器超时 点击屏幕重试 uniapp编译报错 uniapp vue3 imported module TypeError HarmonyOS5 教程 GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 Ubuntu共享文件夹 共享目录 Linux共享文件夹 Mac内存不够用怎么办 mysql安装报错 windows拒绝安装 beautifulsoup termux 环境搭建 线程同步 线程互斥 条件变量 chrome历史版本下载 chrominum下载 dnf uni-app x linux/cmake vr 空Ability示例项目 讲解 上架 实习 pyautogui Zoertier 内网组网 2024 2024年上半年 下午真题 答案 WireGuard 异地组网 GRE 漏洞报告生成 axure 轮播图 可用性测试 写时拷贝 Linux的进程调度队列 活动队列 Apache OpenNLP 句子检测 分词 词性标注 核心指代解析 冯诺依曼体系结构 Makefile Make Nginx报错413 Request Entity Too Large 的客户端请求体限制 CKA #apache #kafka #flink #运维 #openssh升级 #银河麒麟V10 SP10 ecm bpm iis 远程看看 远程协助 大数据平台 网络穿透 asm lighttpd安装 Ubuntu配置 Windows安装 服务器优化 服务器ssl异常解决 CNNs 图像分类 框架 规格说明书 设计规范 证书 签名 ueditor导入word 接口隔离原则 VMware安装mocOS macOS系统安装 本地部署AI大模型 可执行程序 OpenCore devmem JAVA 数码相机 全景相机 设备选择 实用技巧 数字空间 openssh #算法 #数据清洗 DenseNet 读写锁 Isaac Sim 虚拟仿真 Reactor反应堆 学习路线 LLaMA-Factory NLP 客户端和服务器端 弹性 pytorch3d kylin v10 麒麟 v10 oneapi audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 nextjs reactjs kamailio sip VoIP TCP服务器 qt项目 qt项目实战 qt教程 WebRTC IIS服务器 IIS性能 日志监控 BMC 带外管理 思科模拟器 思科 Cisco 服务器管理 配置教程 网站管理 pxe socket http状态码 请求协议 科勘海洋 数据采集浮标 浮标数据采集模块 ftp 滑动验证码 反爬虫 大学大模型可视化教学 全球气象可视化 大学气象可视化 观察者模式 TCP 多进程 TCP回显服务器 VMware安装Ubuntu Ubuntu安装k8s 黑苹果 sonoma 自动更新 fd 文件描述符 用户缓冲区 软链接 硬链接 网络文件系统 免密 公钥 私钥 photoshop debezium 数据变更 数据迁移 进程等待 内存泄漏 VUE Mysql 源码软件 编译器 libtorch P2P HDLC RAGFLOW System V共享内存 进程通信 Alexnet compose IO VM虚拟机 python高级编程 Ansible elk stack Linux的进程概念 Linux系统编程 MinerU 直播 #java #maven #java-ee #spring boot #jvm #tomcat IIS Hosting Bundle .NET Framework vs2022 银河麒麟桌面操作系统 Kylin OS TrinityCore 魔兽世界 token sas 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 ABAP VNC 飞牛 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 vu大文件秒传跨域报错cors RK3568 proto actor actor model Actor 模型 英语六级 前端项目部署 微前端 deepseek r1 中兴光猫 换光猫 网络桥接 自己换光猫 ci/cd Maven Linux find grep 权限 powerbi vm SPI 进程程序替换 execl函数 execv函数 execvp函数 execvpe函数 putenv函数 electron docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 bat 论文阅读 qt5 客户端开发 LInux 飞书 Invalid Host allowedHosts Flask Waitress Gunicorn uWSGI 孤岛惊魂4 echarts 信息可视化 网页设计 DeepSeek行业应用 Heroku 网站部署 freebsd 联想开天P90Z装win10 MQTT协议 消息服务器 联机 僵尸毁灭工程 游戏联机 开服 Webserver 异步 Arduino 电子信息工程 零日漏洞 CVE 全栈 raid OSB Oracle中间件 SOA 相机标定 漫展 笔记本电脑 SQI iOS Server Trust Authentication Challenge jvm调优 LRU策略 内存增长 垃圾回收 Ubuntu Server Ubuntu 22.04.5 bcompare Linux的基础指令 键盘 ruby 英语 电脑桌面出现linux图标 电脑桌面linux图标删除不了 电脑桌面Liunx图标删不掉 linux图标删不掉 大版本升 升级Ubuntu系统 设备树 STL firewall tar.gz tar.xz linux压缩 vr看房 在线看房系统 房产营销 房产经济 三维空间 sublime text podman 美食 根目录 #pytorch #字体 #安装 #微软雅黑 #office 金仓数据库 2025 征文 数据库平替用金仓 Python基础 Python技巧 自动化编程 camera 输入法 qps 高并发 GeneCards OMIM TTD autogen openai visual studio d3d12 蜂窝网络 频率复用 射频单元 无线协议接口RAN 主同步信号PSS 本地知识库 BMS 储能 WebFuture 容器化 #大数据 #python #毕业设计 #Hadoop #SPark #数据挖掘 c EMQX 通信协议 CPU 存储数据恢复 raid5数据恢复 磁盘阵列数据恢复 netty 音乐库 阿里云ECS 小番茄C盘清理 便捷易用C盘清理工具 小番茄C盘清理的优势尽显何处? 教你深度体验小番茄C盘清理 C盘变红?!不知所措? C盘瘦身后电脑会发生什么变化? client close PTrade QMT 量化股票 工厂方法模式 Scoket 套接字 加密 JavaWeb 回显服务器 Echo HiCar CarLife+ CarPlay QT RK3588 direct12 cuda驱动 Linux的进程控制 调试方法 Valgrind 内存分析工具 实战项目 入门 精通 Ubuntu22.04 composer ssh远程登录 运维监控 lio-sam SLAM ceph 隐藏目录 管理器 通配符 web环境 Serverless 内存管理 软路由 Playwright MCP 青少年编程 编程与数学 自动化测试框架 开启关闭防火墙 机器人操作系统 打包工具 TraeAgent #python3.11 #docker zotero 同步失败 ocr 做raid 装系统 黑客技术 windows日志 银河麒麟操作系统 端口测试 上传视频文件到服务器 uniApp本地上传视频并预览 uniapp移动端h5网页 uniapp微信小程序上传视频 uniapp app端视频上传 uniapp uview组件库 跨域请求 mvc HTTP3 全双工通信 多路复用 实时数据传输 mysql离线安装 mysql8.0 Linux PID Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 MAC export env 变量 视觉检测 GKI KMI PATH 命令行参数 main的三个参数 linux常用命令 机床 仿真 课件 虚拟现实 教学 课程 MAC地址 #tomcat #架构 #servlet QT 5.12.12 QT开发环境 Ubuntu18.04 免费域名 域名解析 Doris搭建 docker搭建Doris Doris搭建过程 linux搭建Doris Doris搭建详细步骤 Doris部署 rtc 命令模式 桥接模式 windows虚拟机 虚拟机联网 Arduino下载开发板 esp32开发板 esp32-s3 重构 dnn mysql 8 mysql 8 忘记密码 c盘 磁盘清理 #YOLO #目标检测 UDP的API使用 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 live555 源码剖析 rtsp实现步骤 流媒体开发 银河麒麟服务器操作系统 系统激活 swoole uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 LORA 半虚拟化 硬件虚拟化 Hypervisor 镜像下载 配置原理 机架式服务器 1U工控机 国产工控机 医疗APP开发 app开发 移动端开发 热键 泰山派 根文件系统 编译 烧录 docker run 数据卷挂载 交互模式 virtualbox VMware Tools vmware tools安装 vmwaretools安装步骤 vmwaretools安装失败 vmware tool安装步骤 vm tools安装步骤 vm tools安装后不能拖 vmware tools安装步骤 电脑操作 电子器件 二极管 三极管 SSM 项目实战 页面放行 #自动化 wsgiref Web 服务器网关接口 OD机试真题 华为OD机试真题 服务器能耗统计 智能音箱 智能家居 智能电视 免费 cocos2d 3dcoat 教育电商 pyscenic 生信教程 DELL R730XD维修 全国服务器故障维修 多媒体 Lenovo System X GNOME 决策树 医药 华为OD机考 机考真题 需要广播的服务器数量 SPP #c++ 小游戏 五子棋 检索增强生成 文档解析 大模型垂直应用 USB转串口 Redis Desktop 支付 微信支付 开放平台 IP配置 netplan grep 一切皆文件 数据库管理 react Native IMX317 MIPI H265 VCU springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 Sealos 输入系统 AzureDataStudio 服务注册与发现 AOD-PONO-Net 图像去雾技术 思科实验 高级网络互联 链表 gin #bright data #llama #kimi DeepSeek-R1 API接口 vasp安装 Ubuntu 24.04.1 轻量级服务器 laravel ldap java-zookeeper openvino 网络带宽 问题排查 blender three.js 数字孪生 信号 shell脚本免交互 expect linux免交互 mac cocoapods macos cocoapods iptables GoogLeNet AnythingLLM AnythingLLM安装 目标跟踪 OpenVINO 推理应用 rancher 大模型技术 本地部署大模型 finalsheel llamafactory 微调 Qwen DrissionPage muduo库 服务 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 gateway Clion Nova ResharperC++引擎 Centos7 远程开发 匿名FTP 邮件传输代理 SSL支持 chroot监狱技术 GPU状态 服务器租用 物理机 进度条 嵌入式系统开发 AList webdav fnOS 开发人员主页 图文教程 VMware虚拟机 macOS系统安装教程 macOS最新版 虚拟机安装macOS Sequoia 文件权限 CTE AGE 单用户模式 wget 进程创建 进程退出 端口 #华为 #harmonyos #手机 Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 聚类 WebVM 国产数据库 瀚高数据库 下载安装 4 - 分布式通信、分布式张量 本地环回 bind SoC 原子操作 AXI 迭代器模式 ping++ 温湿度数据上传到服务器 Arduino HTTP 内网渗透 靶机渗透 EtherCAT转Modbus EtherCAT转485网关 ECT转485串口服务器 ECT转Modbus485协议 ECT转Modbus串口网关 ECT转Modbus串口服务器 Putty 花生壳 web开发 网络IO 队列 数据库占用空间 #开发语言 keepalived csrutil mac恢复模式进入方法 恢复模式 win向maOS迁移数据 导航栏 PostgreSQL15数据库 容器清理 大文件清理 空间清理 uboot 部署方案 IMX6ULL 蓝耘科技 元生代平台工作流 ComfyUI curl redhat 电视剧收视率分析与可视化平台 copilot 图片增强 增强数据 su sudo sudo原理 su切换 post.io 企业邮箱 搭建邮箱 PCB fork 进程管理 vb #YOLOv13 网卡的名称修改 eth0 ens33 vscode1.86 1.86版本 ssh远程连接 ssrf 失效的访问控制 filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 file server http server web server VPS googlecloud DOIT 四博智联 rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK C# MQTTS 双向认证 emqx 动态规划 deepseek-r1 大模型本地部署 deepseak 豆包 KIMI 腾讯元宝 软件开发 文件存储服务器组件 宠物 免费学习 宠物领养 宠物平台 支持向量机 建站 快速入门 VR手套 数据手套 动捕手套 动捕数据手套 分析解读 权限命令 特殊权限 systemctl Mac部署 Ollama模型 Openwebui 配置教程 AI模型 elementui I/O 设备管理 linux安装配置 telnet 远程登录 集成 nano wpf dsp开发 xfce #python #信息可视化 磁盘满 asp.net大文件上传下载 网站 网络原理 券商 股票交易接口api 类型 特点 股票量化接口 股票API接口 vCenter服务器 ESXi主机 监控与管理 故障排除 日志记录 腾讯云服务器 轻量应用服务器 linux系统入门 asp.net 磁盘IO iostat 序列化反序列化 代理服务器 基础环境 Cookie diskgenius 高德地图 鸿蒙接入高德地图 HarmonyOS5.0 sublime text3 octomap_server 原创作者 deployment daemonset statefulset cronjob K8S k8s管理系统 proxy_pass 2025一带一路金砖国家 金砖国家技能大赛 技能发展与技术创新大赛 首届网络系统虚拟化管理与运维 比赛样题 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 ardunio BLE W5500 OLED u8g2 充电桩 欧标 OCPP 小智AI服务端 xiaozhi TTS 主板 电源 nosql Web应用服务器 三次握手 惠普服务器 惠普ML310e Gen8 惠普ML310e Gen8V2 mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 conda配置 conda镜像源 wait waitpid exit 用户管理 jdk11安装 jdk安装 openjdk11 openjdk11安装 Python学习 Python编程 苹果 vscode-server ubuntu18.04 影刀 #影刀RPA# 流水线 脚本式流水线 问题解决 import save load 迁移镜像 富文本编辑器 scapy netlink libnl3 能效分析 time时间函数 #adb #数据库开发 #mysql #sql Socket hibernate 游戏机 移动云 java-rocketmq 服务器部署 本地拉取打包 Qualcomm WoS QNN AppBuilder 鼠标 messages dmesg 材质 贴图 #提示词注入 #防护 #安全 #大模型 bpf bpfjit pcap ebpf Linux环境 ubuntu24 vivado24 efficientVIT YOLOv8替换主干网络 TOLOv8 抗锯齿 NLP模型 IPv6测试 IPv6测速 IPv6检测 IPv6查询 linux子系统 忘记密码 openGauss 个人博客 code-server EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 聊天服务器 创意 社区 VMware创建虚拟机 代码托管服务 数字证书 签署证书 banner vSphere vCenter 金仓数据库概述 金仓数据库的产品优化提案 站群服务器 多端开发 智慧分发 应用生态 鸿蒙OS cmos Maxkb RAG技术 Linux的基础开发工具 GRANT REVOKE C/C++ Unlocker 分布式总线 若依框架 leetcode 体验鸿蒙电脑操作系统 Windows电脑能装鸿蒙吗 #数据库 SSH 密钥生成 SSH 公钥 私钥 生成 实战案例 钉钉 Docker快速入门 源代码 registries ROS1/ROS2 dockerfile Wayland 图论 TiDB测试集群 阻塞队列 生产者消费者模型 服务器崩坏原因 junit 大文件秒传跨域报错cors DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 Dedicated Host Client 无头主机 算力 skynet slave RustDesk 搭建服务器 支付宝小程序 云开发 基础入门 EMUI 回退 降级 高级IO epoll MDK 嵌入式开发工具 cpolar java毕业设计 微信小程序医院预约挂号 医院预约 医院预约挂号 小程序挂号 影视app 云盘 安全组 #VMware #虚拟机 #apache CentOS TCP协议 软负载 飞牛nas fnos 工具分享 高可用 回归 coze扣子 AI口播视频 飞影数字人 coze实战 ipv6 光猫设置 路由器设置 WIFI7 无线射频 高通 射频校准 射频调试 射频匹配 #stm32 #单片机 #freeRTOS SVN Server tortoise svn UDP 同步 备份 XFS xfs文件系统损坏 I_O error Spring Security 雨云服务器 Erlang OTP gen_server 热代码交换 事务语义 备选 调用 示例 IDEA 西门子PLC 通讯 弹性服务器 行情服务器 股票交易 速度慢 切换 caddy bootstrap 访问公司内网 粘包问题 服务网格 istio Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 trea idea AppLinking 应用间跳转 杂质 pi0 lerobot aloha act jina 浏览器开发 AI浏览器 k8s集群资源管理 烟花代码 烟花 元旦 并查集 自学笔记 小米 澎湃OS openresty nacos容器环境变量 docker启动nacos参数 nacos镜像下载 搜狗输入法 中文输入法 network NetworkManager rtsp转rtmp 海康rtsp转rtmp 摄像头rtsp到rtmp rtsp转发 rtsp摄像头转rtmp rtsp2rtmp #经验分享 #笔记 #c++ rtp iDRAC R720xd 干货分享 黑客工具 密码爆破 繁忙 解决办法 替代网站 汇总推荐 AI推理 gradle 蓝桥杯C++组 华为OD 可以组成网络的服务器 ueditor导入pdf ueditor导入ppt AWS qwen2vl 事件驱动 自定义登录信息展示 motd 美化登录 大厂程序员 硅基计算 碳基计算 认知计算 生物计算 AGI 系统架构设计 软件哲学 程序员实现财富自由 算法协商 故障排查 DIFY Linux的权限 wifi驱动 线程安全 桶装水小程序 在线下单送水小程序源码 桶装水送货上门小程序 送水小程序 订水线上商城 时序数据库 iotdb #数据结构 #链表 子网掩码 公网IP 私有IP GRUB引导 Linux技巧 容器技术 lb 协议 anythingllm open-webui docker国内镜像 MinIO 手机 通用环境搭建 NAT huggingface 麒麟kos 网络检测 ping #openssh #kubernetes #数据结构 #chrome #n8n #n8n工作流 #n8n教程 #n8n本地部署 #n8n自动化工作流 #n8n使用教程 #n8n工作流实战案例 opcua opcda KEPServer安装 WinRM TrustedHosts 服务器时间 服务器主板 AI芯片 ECT转Modbus协议 EtherCAT转485协议 ECT转Modbus网关 像素流送api 像素流送UE4 像素流送卡顿 像素流送并发支持 错误代码2603 无网络连接 2603 实时云渲染 云渲染 3D推流 MCP 服务器 JADX-AI 插件 光电器件 LED MateBook bug定位 缺陷管理 js逆向 #vscode #编辑器 #ide 小艺 Pura X termius iterm2 uv Tabs组件 TabContent TabBar TabsController 导航页签栏 滚动导航栏 Bandizip Mac解压 Mac压缩 压缩菜单 互联网实用编程指南 CodeBuddy首席试玩官 系统完整性 越狱设备 程序地址空间 CAN总线 多路转接 产测工具框架 管理框架 cd 目录切换 AI Agent 字节智能运维 Web3 Telegram HBase分布式集群 HBase环境搭建 HBase安装 HBase完全分布式环境 简单工厂模式 dockercompose安装 compose.yml文件详解 dockercompose使用 pavucontrol 蓝牙耳机 人工智能作画 #debian Radius 并集查找 换根法 树上倍增 MNN 显示管理器 lightdm gdm 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 hugo VS Code zerotier 环境 非root access blocked 破解 anonymous rtmp 独立服务器 BIO Java socket Java BIO Java NIO Java 网络编程 alphafold3 pve 软件高CPU占用 ProcessExplorer Process Hacker System Informer Windbg 线程的函数调用堆栈 #合成孔径雷达 #GAMMA #InSAR #游戏 #云计算 捆绑 链接 谷歌浏览器 youtube google gmail 软件卸载 系统清理 多产物 空间 查错 子系统 ps命令 webgis cesium 应急响应 CTF EulerOS 版本对应 Linux 发行版 企业级操作系统 RHEL 开源社区 分布式锁 南向开发 北向开发 MVVM 鸿蒙5.0 备忘录应用 ai编程 k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm WebUI DeepSeek V3 fabric BitTorrent 搜索 mcp-server RTMP 应用层 软件定义数据中心 sddc AI agent windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 MI300x 能力提升 面试宝典 IT信息化 流量运营 加解密 Yakit yaklang 互信 WebServer oracle fusion oracle中间件 c/s 矩池云 数据下载 数据传输 MQTT Broker GMQT 视频直播物理服务器租用 物理服务器 物理机租用 safari CentOS Stream HarmonyOS NEXT 原生鸿蒙 查看显卡进程 fuser vpn 终端 Linux指令 时间轮 文件清理 Windows应急响应 webshell 网络攻击防御 网络攻击 HarmonyOS 5开发环境 CUDA Toolkit HDC2025 HarmonyOS 6 #技能认证 机械臂 CAD瓦片化 栅格瓦片 矢量瓦片 Web可视化 DWG解析 金字塔模型 红黑树封装map和set 影刀证书 分享 ICMPv6 docker安装mysql win下载mysql镜像 mysql基本操作 docker登陆私仓 docker容器 deepseek与mysql AI控制浏览器 Browser user Cilium 物理层 #udp #网络通信 #网络协议 #Socket webstorm 根服务器 需求分析 SEO KingBase sqlite3 Qt QModbus OpenManage 流量 aiohttp asyncio 视频服务器 雾锁王国 cordova 跨域开发 集群 科研绘图 生信服务器 tengine web负载均衡 WAF alias unalias 别名 springcloud 微信分享 Image wxopensdk 多层架构 解耦 fonts-noto-cjk lvm retry 重试机制 提示词 Bluetooth 配对 tvm安装 深度学习编译器 CKEditor5 对话框showDialog showActionMenu 操作列表ActionSheet CustomDialog 文本滑动选择器弹窗 消息提示框 警告弹窗 嵌入式软件 RTOS 系统升级 16.04 Termius Vultr 远程服务器 #http IO模型 代理 李心怡 selete 解决方案 静态IP solr 知行EDI 电子数据交换 知行之桥 EDI mapreduce 定义 核心特点 优缺点 适用场景 恒玄BES requests python库 #mcp #浏览器自动化 #AI NAT转发 NAT Server asi_bench 多个客户端访问 IO多路复用 TCP相关API 服务器部署ai模型 宕机切换 服务器宕机 IPMITOOL 硬件管理 技术共享 浏览器自动化 负载测试 VPN wireguard #STC8 #STM32 accept 哥sika 国产芯片 元服务 应用上架 regedit 开机启动 模拟实现 Office 端口开放 ubantu 底层实现 路径规划 命令键 Eigen CMake 自动化编译工具 linux上传下载 etl docker部署Python dock 加速 端口聚合 win11 windows11 网易邮箱大师 数字比特流 模拟信号 将二进制数据映射到模拟波形上 频谱资源 振幅频率相位 载波高频正弦波 containerd usb typec 改行学it BiSheng 线程同步与互斥 社交电子 clickhouse 架构与原理 域名服务 DHCP 符号链接 配置 vue在线预览excel和编辑 vue2打开解析xls电子表格 浏览器新开页签或弹框内加载预览 文件url地址或接口二进制文档 解决网页打不开白屏报错问题 RNG 状态 可复现性 随机数生成 机器人仿真 模拟仿真 AI导航站 eventfd 高性能 cangjie Java 日志框架 Log4j2 Logback SLF4J 结构化日志 企业级应用 ESP8266简单API服务器 Arduino JSON webserver SpringBoot proteus Ark-TS语言 跨平台 qtcreator 顽固图标 启动台 clipboard 剪贴板 剪贴板增强 Navigation 路由跳转 鸿蒙官方推荐方式 鸿蒙原生开发 coffeescript HarmonyOS SDK Map Kit 地图 云解析 云CDN SLS日志服务 云监控 黑马 苍穹外卖 PDF 图片 表格 文档扫描 发票扫描 vmvare nmcli docker命令大全 CLion hosts hosts文件管理工具 代理配置 企业级DevOps 机床主轴 热误差补偿 风电齿轮箱 故障诊断 物理-数据融合 预测性维护 进程操作 理解进程 #目标跟踪 #php Wi-Fi 工业4.0 超融合 代码规范 AimRT shard 事件分析 边缘服务器 利旧 AI识别 Windows 11 重装电脑系统 udp回显服务器 labview Web测试 泛微OA 开闭原则 KingbaseES #ai #AI编程 webgl 玩机技巧 软件分享 软件图标 历史版本 下载 macOS 玩游戏 接口返回 Github加速 Mac上Github加速 Chrome浏览器插件 学习笔记 C++11 lambda 包装类 English FreeLearning infini-synapse mysql8.4.5 Bilibili B站 WLAN 达梦 DM8 5分钟快速学 docker入门 rxjava Jenkins 配置凭证 线性代数 #计算机网络 #tcp/ip 无法解析服务器的名称或地址 SSL 域名 矩阵 田俊楠 云耀服务器 WINCC EF Core 客户端与服务器评估 查询优化 数据传输对象 查询对象模式 openlayers bmap tile server #c# #OPCUA av1 电视盒子 机顶盒ROM 魔百盒刷机 移动魔百盒 合成模型 扩散模型 图像生成 Attention ollama下载加速 macbook nginx默认共享目录 Windows Hello 摄像头 指纹 生物识别 redisson FreeFileSync 定时备份 figma 交叉编译 scikit-learn UFW MobileNetV3 sql注入 VAD 视频异常检测 VAR 视频异常推理 推理数据集 强化微调 GRPO docker search docker 失效 docker pull失效 docker search超时 扩展错误 #神经网络 #爬虫 HAProxy 直流充电桩 相差8小时 UTC 时间 sysctl.conf vm.nr_hugepages xss 执法记录仪 智能安全帽 smarteye chfs ubuntu 16.04 搭建个人相关服务器 迁移指南 win服务器架设 windows server 海康 Async注解 动态域名 风扇散热策略 曙光 海光 宁畅 中科可控 jQuery 云服务器租用 Modbustcp服务器 CSDN开发云 zipkin funasr asr 语音转文字 EasyTier #飞算Java炫技赛 #Java开发 MacOS录屏软件 ubuntu 18.04 Ubuntu 24.04 搜狗输入法闪屏 Ubuntu中文输入法 gerrit 亲测 视频号 恢复 Win10修改MAC skywalking #comfyui #WSL #分区 查看 ss 生活 医院门诊管理系统 分布式数据库 集中式数据库 业务需求 选型误 电子学会 触觉传感器 GelSight GelSightMini GelSight触觉传感器 概率与统计 随机化 位运算 几何计算 数论 系统架构设计师 Searxng 工作流自动化 AI智能体 #iotdb #时序数据库 #自然语言处理 #语言模型 #nginx #性能优化 #科技 h.264 查询数据库服务IP地址 SQL Server jetty undertow Nuxt.js ux URL 服务器正确解析请求体 联网 easyconnect 火山引擎 站群 多IP 静态NAT FreeRTOS 报警主机 豪恩 VISTA120 乐可利 霍尼韦尔 枫叶 时刻 参数服务器 分布式计算 数据并行 navicat threejs 3D 强制清理 强制删除 mac废纸篓 极限编程 自定义shell当中管道的实现 匿名和命名管道 红黑树 本地不受DeepSeek 九天画芯 铁电液晶 显示技术 液晶产业 技术超越 语法 Trae叒更新了? idm isaacgym 共享 设置 myeclipse 视频会议 scala #qt #图像处理 #nginx #数据库 #端口 #database #macos 内网环境 佛山戴尔服务器维修 佛山三水服务器维修 cpp-httplib 业界资讯 hexo 安防软件 授时服务 北斗授时 充电桩平台 充电桩开源平台 rtcp OpenAI 协作 FS100P siteground siteground安装wp 一键安装wordpress 服务器安装wordpress bert 食用文档 #MCP android-ndk RHCE vsode 黑屏 mac完美终端 #OCCT #Qt #nacos xpath定位元素 uprobe 手动分区 FCN #iotdb #重构 #安全 #web安全 压测 Unity插件 SysBench 基准测试 TrueLicense gpu 转流 rtsp取流 rtmp推流 虚拟主机 物理服务器租用 broadcom 智能手表 Pura80 WATCH 5 GDB调试 Ubuntu环境 四层二叉树 断点设置 nvm安装 #mobaxterm #termius #electerm #tabby #termcc #rockylinux #rhel #操作系统 #系统安装 #ansible #role #galaxy #ansible-galaxy linux 命令 sed 命令 ELF加载 仓库 实时语音识别 流式语音识别 敏捷开发 #时序数据库 #excel #Linux #Ubuntu #ubuntu24 #ubuntu2404 #ubuntu安装 #sudo #PG处理POI分类数据 #Java处理POI分类数据 #ApachePOI数据处理 #高德POI分类数据存储 #POI数据分类存储 网络犯罪 人工智能 #大数据 vscode 1.86 sentinel 制造 小亦平台 运维问题解决方法 gaussdb问题解决 #阿里云 汽车 arkts arkui 效率 #矫平机 #校平机 #铁 #钢 #kali proxy模式 最新微服务 PP-OCRv5 ubuntu20.04 OCR NGINX POD #redis #缓存 #web安全 #网络安全 #渗透测试 #计算机 #转行 #职场发展 #干货分享 #电脑上不了网 #IP设置 #网卡驱动 #路由器设置 #wifi设置 #网络防火墙 #无法连接到这个网络 #飞书 高效I/O 模板 泛型编程 能源 选择排序 地平线5 机架式 IDC 开启黑屏 java18 whistle mujoco IT 护眼模式 激光雷达 镭眸 路由器 ohmyzsh #小程序 #DevEco Studio #HarmonyOS Next #conda #信息可视化 #qml 项目部署 智能问答 Milvus Modbus TCP pow 指数函数 优化 集合 List OpenTiny 中文分词 #物联网 #算法 #洛谷 #强连通分量 #缩点 #vue.js #前端 #云原生 #阿里云 #gpt #chatgpt 恒源云 AISphereButler authing 低成本 tty2 pikachu靶场 XSS漏洞 XSS DOM型XSS 物理机服务器 统信uos Mac软件 实时日志 logs NTP服务器 重置密码 安全整改 cp 进度显示 #华为云 #云服务部署 #搭建AI #Flexus X实例 watchtower homeassistant 基本指令 N8N UDS Bootloader vue2 #架构 #分布式 #单机架构 #微服务 服务器托管 云托管 数据中心 idc机房 dos 批处理 日期 #shell #脚本 #postgresql #kubernetes #sql #学习 #自动化测试 #软件测试 电商平台 lrzsz mobaxterm #其他 风扇控制软件 #计算机网络 #网络攻击模型 #端口占用 #系统详情 集群管理 微信自动化工具 微信消息定时发送 #系统架构 #inlong #笔记 #intellij-idea #idea #intellij idea Bluedroid #默认分类 #tensorflow #pip #图论 #深度优先 #vue.js fast 责任链模式 SonarQube #HTML #核心知识点 #web #知识点 #网页开发 #pycharm A2A #unity #着色器 #mc #服务器搭建 #mc服务器搭建 #mc服务器 #Dify #电脑 #经验分享 几何绘图 三角函数 guava #毕设 #租房管理系统 #论文 #虚拟地址 #虚拟地址空间 #写时拷贝 #嵌入式硬件 #部署配置docker #容器化 #后端 #jenkins #测评 #CCE #Dify-LLM #Flexus #VNC #jdk #编程 #macos26 #启动台 WinCC OT与IT SCADA 智能制造 MES 信奥 #echarts #https #进程状态 #僵尸进程 #孤儿进程 #挂起 #nginx配置 #nginx案例 #nginx详解 细胞分割 计数自动化 图像分析 #eureka #系统架构 #网络协议 #ip #机器人 #音视频 #AIGC #开源 #Agent #智能运维 #AI开发平台 #AI工具链 #智能路由器 #NAT #信息与通信 #Ollama #agent #向量库 #fastAPI #langchain #tcp/ip #面试 #职场和发展 #iot 连接失败 Mosquitto #aws #搜索引擎 #elasticsearch #全文检索 #进程优先级 #进程切换 #Linux调度算法 #寄存器 #AI编程 #低代码 #物联网 #进程 #fork #深信服运维安全管理系统 #远程命令执行漏洞 #GESP C++ #C++程序竞赛 #c语言 #程序人生 dfs #MCP协议 #typescript #实战指南 #MCP服务器 #gitlab #github #RAG #Cookie #Session #HTTP #截图工具 #jvm #实时流处理 #设备故障预测 #Flink #rocketmq #零拷贝 #DeepSeek #蓝耘智算 #微信小程序 #配置教程 #入门教程 #安装教程 #图文教程 #数据库架构 #安全架构 #神经网络 #Linux的进程间通信 #node.js #驱动 #嵌入式 #信奥赛 #深度学习 #概率论 #统信uos #spring boot #Linux的基础IO #开源 #AI写作 #raid #raid阵列 #需求分析 #区块链 #数据分析 #github #美食 #django #flask #node.js #硬盘读取 #硬盘读取失败 #MAC电脑读取硬盘 #android #缓冲区 #Linux #golang #哈希算法 #散列表 #beego #go1.19 #beautifulsoup #CMake #Debian #CentOS #struts #VMware #VMWare Tool #LoTDB #Apache IoTDB #腾讯云 #elasticsearch #list #stl #react.js #javascript #React 编译器 #自动优化 #记忆化技术 #重新渲染优化 #Linux的进程信号 #RBAC桎梏 #角色爆炸 #静态僵化 #授权对象体系 #组织维度 #业务维度 #intellij-idea #内网穿透 Excel转json Excel转换json Excel累加转json python办公 #leetcode #矩阵 #使用教程 #unix #ruby #哈希表 #gitee #权限