• 【C++软件实战问题排查经验分享系列 ②】 调试遇到0xfeeefeee、0xcdcdcdcd等异常值 | 动态库加载失败 | 程序启动报错与启动失败 | 软件操作权限系列问题总结

【C++软件实战问题排查经验分享系列 ②】 调试遇到0xfeeefeee、0xcdcdcdcd等异常值 | 动态库加载失败 | 程序启动报错与启动失败 | 软件操作权限系列问题总结

2025-04-26 14:51:52 1 阅读

目录

1、Debug调试时遇到0xfeeefeee、0xcdcdcdcd等异常值(要熟悉这些常见的异常值)

1.1、异常值0xcccccccc和0xcdcdcdcd

1.2、异常值0xfeeefeee

1.3、异常值0xdddddddd

2、动态库加载失败详细总结

2.1、动态库的隐式加载与显式加载

2.2、动态库加载失败对程序的影响

2.3、动态库加载失败的原因分析与总结

2.3.1、dll位数与依赖它的模块位数不一致,导致dll库加载失败

2.3.2、dll库依赖的库有问题,导致dll加载失败

2.3.2.1、dll库依赖的库在当前系统中找不到

2.3.2.2、dll库调用其依赖的库中的接口,但该接口在被依赖的库中找不到

2.3.3、在某些系统上会出现LoadLibrary加载dll库失败的问题,需要使用LoadLibraryEx接口

2.4、使用Process Explorer工具查看程序加载了哪些动态库以及动态加载的库有没有加载起来

2.5、使用Dependency Walker工具查看dll库的依赖关系以及调用的接口,排查动态库加载失败问题

3、程序启动报错与启动失败 

3.1、依赖的dll库找不到与调用的接口在依赖的库中找不到

3.2、依赖的dll库位数(32位/64位)不一致

3.3、UI线程发生死循环或死锁

4、软件操作权限问题

4.1、管理员权限与标准用户权限

4.2、权限不对等导致程序相互操作失败

5、最后


C++软件异常排查从入门到精通系列教程(核心精品专栏,订阅量已达5000多个,欢迎订阅,持续更新...)https://blog.csdn.net/chenlycly/article/details/125529931C/C++实战专栏(重点专栏,专栏文章已更新500多篇,订阅量已达3000多个,欢迎订阅,持续更新中...)https://blog.csdn.net/chenlycly/article/details/140824370C++ 软件开发从入门到实战(重点专栏,专栏文章已更新300多篇,欢迎订阅,持续更新中...)https://blog.csdn.net/chenlycly/category_12695902.htmlVC++常用功能开发汇总(专栏文章列表,欢迎订阅,持续更新...)https://blog.csdn.net/chenlycly/article/details/124272585C++软件分析工具从入门到精通案例集锦(专栏文章,持续更新中...)https://blog.csdn.net/chenlycly/article/details/131405795开源组件及数据库技术(专栏文章,持续更新中...)https://blog.csdn.net/chenlycly/category_12458859.html网络编程与网络问题分享(专栏文章,持续更新中...)https://blog.csdn.net/chenlycly/category_2276111.html       我们在开发调试C++软件的过程中,时常会遇到0xfeeefeee、0xcdcdcdcd等异常值 、动态库加载失败、程序启动报错与启动失败、软件操作权限等问题本文对这些常见问题的分析与排查方法进行了详细的总结,并给出相关的实战分析实例,供大家借鉴或参考。


       当前是C++软件实战问题排查经验分享系列第2期,第1期的分享已经发布,感兴趣的话,可以去查看文章:

【C++软件实战问题排查经验分享系列 ①】UI界面卡顿 | CPU占用高 | GDI对象泄漏 | 线程堵塞 系列问题排查总结https://blog.csdn.net/chenlycly/article/details/147382470


1、Debug调试时遇到0xfeeefeee、0xcdcdcdcd等异常值(要熟悉这些常见的异常值)

       大家在Visual Studio中进行Debug下代码调试时,时常会遇到0xfeeefeee、0xcccccccc、0xcdcdcdcd和0xdddddddd等异常值,如果把这些异常值当做地址去访问,则会触发内存访问违例,导致程序崩溃。我相信很多人都遇到过这几个异常值,如果对这几个异常值的含义比较熟悉,则能够结合现有代码快速定位问题。

为什么访问0xfeeefeee、0xcccccccc、0xcdcdcdcd和0xdddddddd这几个内存地址会触发内存访问违例呢?

因为对于32程序,0xfeeefeee、0xcccccccc、0xcdcdcdcd和0xdddddddd这几个内存地址是属于内核态内存地址的范围,而我们的业务代码一般是运行在用户态的,用户态的代码是禁止访问内核态内存地址的,所以会触发内存访问违例,导致软件异常!

       这几个常见的异常值的说明,如下所示:(主要关注0xfeeefeee、0xcccccccc、0xcdcdcdcd和0xdddddddd这4个异常值

* 0xcccccccc : Used by Microsoft's C++ debugging runtime library to mark uninitialised stack memory.
* 0xcdcdcdcd : Used by Microsoft's C++ debugging runtime library to mark uninitialised heap memory.
* 0xfeeefeee : Used by Microsoft's HeapFree() to mark freed heap memory.
* 0xdddddddd:Used by MicroQuill's SmartHeap and Microsoft's C/C++ debug free() function to mark freed heap memory.
* 0xabababab : Used by Microsoft's HeapAlloc() to mark "no man's land" guard bytes after allocated heap memory.
* 0xabadcafe : A startup to this value to initialize all free memory to catch errant pointers.
* 0xbaadf00d : Used by Microsoft's LocalAlloc(LMEM_FIXED) to mark uninitialised allocated heap memory.
* 0xbadcab1e : Error Code returned to the Microsoft eVC debugger when connection is severed to the debugger.
* 0xbeefcace : Used by Microsoft .NET as a magic number in resource files.

1.1、异常值0xcccccccc和0xcdcdcdcd

       对于0xcccccccc和0xcdcdcdcd,在 debug 模式下,Visual Studio会把未初始化的栈内存全部填充成0xcccccccc,当成字符串看就是“烫烫烫烫……”;Visual Studio会把未初始化的堆内存全部填充成 0xcdcdcdcd,当成字符串看就是 “屯屯屯屯……”。所以遇到这两个值时,一般是变量未初始化引起的。

       关于排查0xcdcdcdcd异常值引发异常崩溃的实战排查案例,可以查看我之前写的文章:

排查软件启动时访问了0xcdcdcdcd内存地址导致内存访问违例的崩溃https://blog.csdn.net/chenlycly/article/details/1252667350xcdcdcdcd异常值引发C++程序崩溃问题的详细分析https://blog.csdn.net/chenlycly/article/details/128380751

1.2、异常值0xfeeefeee

       对于0xfeeefeee,是Debug下用来标记堆上已经释放掉的内存,即已经释放的堆内存中会被填充成0xfeeefeee。注意,如果指针指向的内存被释放了,指针变量本身的地址是没做改变的,还是其之前指向的内存的地址,只是其指向的堆内存中被填充成0xfeeefeee。如果该指针是一个类的成员变量,并且该类对象是在堆上分配内存的,则该类对象的堆内存被释放后(对于C++类,通常是执行delete操作),类对象中的指针变量就会被赋值为0xfeeefeee。所以,遇到这个0xfeeefeee时,可能是相关内存被释放引起的。

      关于排查0xfeeefeee异常值引发异常崩溃的实战排查案例,可以查看我之前写的文章:
排查软件关闭时访问了0xfeeefeee内存地址导致内存访问违例的崩溃https://blog.csdn.net/chenlycly/article/details/125267046

1.3、异常值0xdddddddd

       对于0xdddddddd,是Debug下用来标记堆上已经释放掉的内存,即已经释放的堆内存会被填充成0xdddddddd。之前在项目问题中看到的基本都是0xfeeefeee,没见到过0xdddddddd,但前段时间在Debug下调试代码时遇到了,代码中访问了已经释放的内存,内存中都被置为0xdddddddd,这还是第一次遇到0xdddddddd异常值!正是通过0xdddddddd的说明,得知这个0xdddddddd是用来填充已经释放的堆内存,以这个为线索,快速地定位了问题!

       关于排查0xdddddddd异常值引发异常崩溃的实战排查案例,可以查看我之前写的文章:
访问0xdddddddd内存地址引发软件崩溃的问题排查https://blog.csdn.net/chenlycly/article/details/139800126访问0xdddddddd内存地址引发软件崩溃的又一问题排查https://blog.csdn.net/chenlycly/article/details/132631020       关于上述0xcccccccc、0xcdcdcdcd、0xfeeefeee 和 0xdddddddd异常值的详细说明,可以查看我之前写的文章:

C++ 中常见异常内存地址或异常值的说明(0xcccccccc、0xcdcdcdcd、0xfeeefeee 和 0xdddddddd 等)https://blog.csdn.net/chenlycly/article/details/128285918

2、动态库加载失败详细总结

       程序启动时,系统会给根据程序的位数(32位 / 64位)分配指定大小的进程空间(虚拟内存空间),系统先将exe主程序依赖的多个dll库加载到进程空间中,然后再将exe主程序文件加载到进程空间中,然后进入main函数,程序启动起来开始运行。如果启动过程有dll库加载失败(非动态加载,且会弹出报错提示框),则会终止程序启动的进程,程序启动失败!

2.1、动态库的隐式加载与显式加载

       在详细讨论动态库加载失败的主题之前,需要先讲解一下dll动态库的隐式加载与显式加载。 程序中引用dll(调用dll中的接口),在dll加载时,可分隐式加载和动态显式加载两种方式。

       dll动态库隐式加载,是包含dll库的头文件并引入dll库对应的lib导入库,然后在代码中调用dll库的导出接口(编译链接时,会到dll对应的lib导入库中链接代码中调用的dll库的导出接口)。在程序中使用#pragma预编译指令引入dll库对应的lib导入库:

#pragma comment( lib, "libcurl.lib")
或者在VS的工程配置中配置导入库:

       dll库的显式加载,是调用LoadLibrary或者LoadLibraryEx去动态地加载dll库。 对于显式加载的库,需要调用GetProcAddress接口去获取dll库中API接口的函数,然后通过该地址去调用API函数。比如如下的一段代码:

BOOL AutoRegsvr32( LPCTSTR lpszDllPath )
{
    if ( lpszDllPath == NULL )
    {
        return;
    }
 
    // 改用LoadLibraryEx,并使用LOAD_WITH_ALTERED_SEARCH_PATH参数,避免部分系统无法加载到dll的问题。
    HINSTANCE hInstLib = LoadLibraryEx( lpszDllPath, NULL, LOAD_WITH_ALTERED_SEARCH_PATH );
    if ( NULL == hInstLib )
    {
        return FALSE;
    }
 
    typedef HRESULT (*DllRegisterServer)(void);
    DllRegisterServer dllRegisterServer = (DllRegisterServer)GetProcAddress( hInstLib, "DllRegisterServer" );
    if ( dllRegisterServer != NULL )
    {
        HRESULT hr = dllRegisterServer();
    }
    else
    {
        FreeLibrary(hInstLib);
        return FALSE;
    }
 
    FreeLibrary(hInstLib);
    return TRUE;
}

显式加载的dll库,不会在程序启动时加载,而是在代码执行到LoadLibrary或者LoadLibraryEx函数的调用时才会动态的加载。如果dll库加载失败,也不会导致程序启动失败。

2.2、动态库加载失败对程序的影响

       要看动态库加载失败对程序的影响,要考虑动态库是隐式加载还是显式动态加载的。

       对于隐式加载的动态库,会在程序启动时加载,如果动态库加载失败,则会终止程序的启动,程序启动失败。如果隐式加载的动态库加载失败是因为找不到接口,则会弹出如下的提示框:
如果因为找不到依赖库,则会弹出如下的错误:

​       对于显式加载的动态库,是在代码中调用LoadLibrary或LoadLibraryEx去加载的。不是在程序启动时加载的,是运行到加载库的LoadLibrary或LoadLibraryEx接口调用时才会加载如果显式动态加载的库加载失败,不会对程序启动产生影响,只是会对程序中的业务功能带来影响(因为库加载不起来,就无法调用库中的接口去实现业务功能)。对于显式加载,不管是因为找不到接口还是找不到依赖的库,动态加载的库加载失败,不会报错。

2.3、动态库加载失败的原因分析与总结

       这里我们详细讨论一下dll加载失败的原因,不管是通过dll库的导入库隐式加载的,还是通过调用LoadLibrary或者LoadLibraryEx动态加载的,原因都是一样的,主要有以下三个原因:

1)问题dll的位数与依赖它的模块位数不一致;
2)问题dll依赖的库在当前系统中找不到;
3)问题dll调用底层库的接口,在底层库中找不到。可能接口改参数了(新增或删除了部分参数,或者修改了原有参数的类型)、可能接口改名称了。


       在这里,给大家重点推荐一下我的几个热门畅销专栏,欢迎订阅:(博客主页还有其他专栏,可以去查看)

专栏1:该精品技术专栏的订阅量已达到8000多个,专栏中包含大量项目实战分析案例,有很强的实战参考价值,广受好评!专栏文章持续更新中,已经更新到200篇以上!欢迎订阅!)

C++软件调试与异常排查从入门到精通系列文章汇总https://blog.csdn.net/chenlycly/article/details/125529931

本专栏根据多年C++软件异常排查的项目实践,系统地总结了引发C++软件异常的常见原因以及排查C++软件异常的常用思路与方法,详细讲述了C++软件的调试方法与手段,以图文并茂的方式给出具体的项目问题实战分析实例(很有实战参考价值),带领大家逐步掌握C++软件调试与异常排查的相关技术,适合基础进阶和想做技术提升的相关C++开发人员!

考察一个开发人员的水平,一是看其编码及设计能力,二是要看其软件调试能力!所以软件调试能力(排查软件异常的能力)很重要,必须重视起来!能解决一般人解决不了的问题,既能提升个人能力及价值,也能体现对团队及公司的贡献!

专栏中的文章都是通过项目实战总结出来的,包含大量项目问题实战分析案例,有很强的实战参考价值!专栏文章还在持续更新中,预计文章篇数能更新到200篇以上!

专栏2:(本专栏涵盖了C++多方面的内容,是当前重点打造的专栏,订阅量已达5000多个,专栏文章已经更新到500多篇,持续更新中...)

C/C++实战进阶(专栏文章,持续更新中...)https://blog.csdn.net/chenlycly/category_11931267.html

以多年的开发实战为基础,总结并讲解一些的C/C++基础与项目实战进阶内容,以图文并茂的方式对相关知识点进行详细地展开与阐述!专栏涉及了C/C++领域多个方面的内容,包括C++基础及编程要点(模版泛型编程、STL容器及算法函数的使用等)、数据结构与算法、C++11及以上新特性(不仅看开源代码会用到,日常编码中也会用到部分新特性,面试时也会涉及到)、常用C++开源库的介绍与使用、代码分享(调用系统API、使用开源库)、常用编程技术(动态库、多线程、多进程、数据库及网络编程等)、软件UI编程(Win32/duilib/QT/MFC)、C++软件调试技术(排查软件异常的手段与方法、分析C++软件异常的基础知识、常用软件分析工具使用、实战问题分析案例等)、设计模式、网络基础知识与网络问题分析进阶内容等。

专栏3:  

C++常用软件分析工具从入门到精通案例集锦汇总(专栏文章,持续更新中...)https://blog.csdn.net/chenlycly/article/details/131405795

常用的C++软件辅助分析工具有SPY++、PE工具、Dependency Walker、GDIView、Process Explorer、Process Monitor、API Monitor、Clumsy、Windbg、IDA Pro等,本专栏详细介绍如何使用这些工具去巧妙地分析和解决日常工作中遇到的问题,很有实战参考价值!

专栏4:   

VC++常用功能开发汇总(专栏文章,持续更新中...)https://blog.csdn.net/chenlycly/article/details/124272585

将10多年C++开发实践中常用的功能,以高质量的代码展现出来。这些常用的高质量规范代码,可以直接拿到项目中使用,能有效地解决软件开发过程中遇到的问题。

专栏5: 

C++ 软件开发从入门到精通(专栏文章,持续更新中...)https://blog.csdn.net/chenlycly/category_12695902.html

根据多年C++软件开发实践,详细地总结了C/C++软件开发相关技术实现细节,分享了大量的实战案例,很有实战参考价值。


2.3.1、dll位数与依赖它的模块位数不一致,导致dll库加载失败

       如果dll库加载失败,我们可以先确认一下dll库的位数是否与依赖该dll的模块(依赖该dll的模块可能是其他dll,也可能是exe主程序)的位数一致,因为32位dll库是不能和64位模块混用的,位数必须要一致才能使用。当然这种情况在项目中比较少见,这只是一种可能的原因,实际项目中比较少,一般不用特别关注这种情况。比如32位的exe主程序是不能加载使用64位dll库的,如果将位数不同的模块混在一起,程序启动时回报0xC000007B错误(对应dll库是隐式加载的,隐式加载才会报错),如下所示:

​导致程序启动报0xC000007B错误。关于0xC000007B错误的实战分析案例,可以查看我之前写的文章:

使用Dependency Walker和Process Explorer排查程序启动时缺少ucrtbase.dll等运行时库以及报0xC000007B错误https://blog.csdn.net/chenlycly/article/details/131505299https://blog.csdn.net/chenlycly/article/details/131505299       至于如何查看dll、exe等二进制文件的位数,可以用dumpbin.exe或者PE查看工具EXE Explorer,相关查看方法可以查看我的文章:
使用Dumpbin工具查看C++二进制文件的位数、时间戳及dll库的依赖关系 https://blog.csdn.net/chenlycly/article/details/140153214如何查看exe和dll等二进制文件的生成时间(时间戳)和位数(32位/64位)http://%20https//blog.csdn.net/chenlycly/article/details/140043291

2.3.2、dll库依赖的库有问题,导致dll加载失败

       dll库依赖的库有问题(当前问题dll依赖的更下层的库),主要有两种情况:

1)dll库依赖的库在当前系统中找不到;
2)dll库中调用了其依赖库中的接口,但该接口在被依赖的库中找不到。可能接口改参数了(新增或删除了部分参数,或者修改了原有参数的类型)、可能接口改名称了。

2.3.2.1、dll库依赖的库在当前系统中找不到

       如果dll库依赖的库在当前系统中找不到,则该dll库会加载失败(加载dll之前,会先将当前dll依赖的库先加载起来,依赖的库都加载起来后,才会去加载当前的dll)。

       如果该dll库是隐式加载的,则一般在程序启动时加载,会报类似这个错误:

​这个问题在我们项目中也经常出现,引发这类问题可能有两个典型的场景:

1)一个场景是,在发布程序时,没有将程序模块依赖的C/C++运行时dll库一起发布,而这些运行时库在其他电脑上可能没有,所以我们在发布程序时要将相关运行时库带上。
2)另一个场景是,底层模块因为重构或者业务需要,新增了一个dll模块,没有通知上层产品,导致上层软件产品在打包时没有将新增的dll库打包进去。

2.3.2.2、dll库调用其依赖的库中的接口,但该接口在被依赖的库中找不到

       如果dll库调用其依赖的库中的接口在被依赖的库中找不到,则该dll库也会加载失败。如果该dll库是隐式加载的,则在程序启动时会报类似这个错误:

​出现这类问题,一般是库与库的版本不一致导致的。在编译时引用了正确的dll库的导入库lib,编译是没问题的,但在程序打包时拷贝的是老版本的dll库,导致程序运行时出现调用的接口在底层的库中找不到。

       至于为什么在依赖库中找不到接口呢?可能找不到的接口,在新版本库中被删除了,或者接口名称被修改了,亦或是接口的参数被修改了(比如增加了参数、删除了参数或者修改了参数类型)。关于接口参数被修改导致找不到接口的实例可以查看我之前写的文章:
使用Process Explorer和Dependency Walker排查dll动态库没法调试的问题(dll库加载失败导致没法动态调试)https://blog.csdn.net/chenlycly/article/details/140803687

2.3.3、在某些系统上会出现LoadLibrary加载dll库失败的问题,需要使用LoadLibraryEx接口

      我们在项目中遇到过几次使用LoadLibrary加载dll库失败的问题,dll库的路径是正确的(文件是存在的),但就是加载失败!当时深入研究了一下,参考Reactos开源系统中的regsvr32.exe中加载dll库的源码实现,将LoadLibrary改成了LoadLibraryEx,并传入LOAD_WITH_ALTERED_SEARCH_PATH参数,相关代码如下所示:

BOOL AutoRegsvr32( LPCTSTR lpszDllPath )
{
    if ( lpszDllPath == NULL )
    {
        return;
    }
 
    // 改用LoadLibraryEx,并使用LOAD_WITH_ALTERED_SEARCH_PATH参数,避免部分系统无法加载到dll的问题。
    HINSTANCE hInstLib = LoadLibraryEx( lpszDllPath, NULL, LOAD_WITH_ALTERED_SEARCH_PATH );
    if ( NULL == hInstLib )
    {
        return FALSE;
    }
 
    typedef HRESULT (*DllRegisterServer)(void);
    DllRegisterServer dllRegisterServer = (DllRegisterServer)GetProcAddress( hInstLib, "DllRegisterServer" );
    if ( dllRegisterServer != NULL )
    {
        HRESULT hr = dllRegisterServer();
    }
    else
    {
        FreeLibrary(hInstLib);
        return FALSE;
    }
 
    FreeLibrary(hInstLib);
    return TRUE;
}

       关于使用LoadLibrary加载dll库失败的实战分析案例,可以查看我之前的文章:(参考开源操作系统ReactOS的内部实现源码,将LoadLibrary改成了LoadLibraryEx,并传入LOAD_WITH_ALTERED_SEARCH_PATH参数

【C++动态库】DLL动态库加载失败导致程序启动报错以及DLL库加载失败的常见原因分析与总结https://blog.csdn.net/chenlycly/article/details/142714236       据说这个用LoadLibrary加载dll库失败的问题,是因为部分Win7系统中LoadLibrary系统API函数内部实现的有缺陷导致的(当时项目中遇到的问题好像就是发生在Win7系统中的), 可以安装一个微软官方的补丁去解决。但给每个出问题的电脑都去安装补丁,是不现实的,最好的解决办法还是使用上面讲到的LoadLibraryEx接口去解决。

2.4、使用Process Explorer工具查看程序加载了哪些动态库以及动态加载的库有没有加载起来

       Process Explorer类似于Windows任务管理器,可以查看当前系统中启动的进程信息,但功能比Windows任务管理器要强大很多。使用Process Explorer工具可以查看目标程序加载了哪些动态库,也可以确认哪些动态加载的库有没有加载起来。

       打开Process Explorer后,在进程列表中选中目标进程,就可以查看到当前进程记载了哪些dll库,可以查看这些库的路径:

       隐式加载的动态库,在程序启动时加载,如果加载失败,则会导致程序启动失败。而显式动态加载的dll库,加载失败不会对程序启动产生影响,有时我们需要去确认显式加载的dll库有没有加载起来,可以用Process Explorer查看,如果加载的dll库列表中找不到动态加载的库,则说明该库动态加载失败。

2.5、使用Dependency Walker工具查看dll库的依赖关系以及调用的接口,排查动态库加载失败问题

       对于因为接口找不到以及依赖的库找不到导致的动态库加载失败或者exe程序启动失败,直接使用Dependency Walker工具打开这个问题dll或者exe主程序查看库与库之间的依赖关系即可找到原因。

       具体分析方法和步骤,直接查看使用Dependency Walker查看库的依赖关系排查问题的项目问题实战分析案例即可,查看我的文章:
使用Process Explorer和Dependency Walker排查C++程序中dll库动态加载失败问题https://blog.csdn.net/chenlycly/article/details/140731158使用Dependency Walker和Process Explorer排查瑞芯微工具软件RKPQTool.exe启动报错的问题https://blog.csdn.net/chenlycly/article/details/140731614使用Process Explorer和Dependency Walker排查dll动态库没法调试的问题(dll库加载失败导致没法动态调试)https://blog.csdn.net/chenlycly/article/details/140803687

3、程序启动报错与启动失败 

       程序启动时,会优先将程序依赖的所有dll库加载到进程空间中,待所有库加载成功后,进入exe主程序的main函数,exe主程序才启动运行起来。如果程序依赖的dll库有问题,则会终止程序启动进程,程序启动失败。程序启动报错或者启动失败,大体有以下几个原因:

1)依赖的dll库在当前系统中找不到;
2)调用的接口在依赖的dll库中找不到;
3)依赖的dll库位数(32位/64位)不一致;
4)UI线程发生死循环或者死锁,导致UI界面显示不出来。

3.1、依赖的dll库找不到与调用的接口在依赖的库中找不到

       对于隐式加载的库,都是在程序启动时加载的,如果隐式加载的库加载失败,会弹出报错提示框,则会终止当前主程序的启动,程序启动失败。

      隐式加载的动态库加载失败,如果是因为依赖的库找不到,会弹出这样的提示框:

​如果是因为调用的接口在依赖的库中找不到,则会弹出如下的提示框:

​       不仅是动态库会依赖其他动态库,exe主程序会直接调用动态库的接口,也是依赖很多动态库的。如果exe直接依赖的这些动态库有问题,也会弹出上述类似的报错提示框。exe主程序直接依赖一些动态库,这些动态库又依赖其他动态库,这样就形成了一个动态库依赖链,exe主程序启动时会把这个依赖链中的所有动态库都加载起来,都加载起来后才会进入exe主程序的main函数,exe主程序才运行起来。所以exe主程序启动报错,可能是exe主程序直接依赖的库有问题,也有可能是直接依赖的这些库依赖的底层库有问题。

3.2、依赖的dll库位数(32位/64位)不一致

       我们上面讲到,除了依赖库或者调用的接口找不到,如果32位模块(exe/dll)与64位模块混用(exe/dll),会报关于0xC000007B错误,如下所示:

​       关于0xC000007B错误的实战分析案例,可以查看我之前写的文章:
使用Dependency Walker和Process Explorer排查程序启动时缺少ucrtbase.dll等运行时库以及报0xC000007B错误https://blog.csdn.net/chenlycly/article/details/131505299

3.3、UI线程发生死循环或死锁

       还有一种特殊的启动失败,就是在启动过程中,exe主程序的UI线程卡住了,可能是UI线程中调用了某个接口内部发生了死循环或者发生了死锁,导致该接口一直没有返回,导致UI线程卡死,UI界面没有显示出来。给一种感觉,就是程序启动没反应,其实到任务管理器中能看到程序进程,就是没有将UI界面显示出来。

       那如何确实是死循环导致的还是死锁导致的呢?如何进行排查呢?首先看一下任务管理器,看看软件进程的CPU占用是否高。程序启动时不会干很多事情,正常情况下CPU占用不会高,如果CPU占用高,那可以基本断定程序中发生死循环。关于高CPU占用的实战分析案例,我写过多篇文章,可以查看:
使用Process Explorer/Process Hacker和Windbg高效排查C++程序高CPU占用问题https://blog.csdn.net/chenlycly/article/details/140731953使用Process Explorer和Clumsy工具定位软件高CPU占用问题https://blog.csdn.net/chenlycly/article/details/130038272       如果能排除死循环,那可能是发生死锁了,可以将Windbg附加到当前进程上进行分析。将Windbg附加到出问题的进程上,查看所有线程的函数调用堆栈,看看哪些线程调用了WaitForSingleObject等等待函数,结合这些线程堆栈中调用的函数,确定这些线程和哪些业务有关。必要时也要结合日志去排查并最终定位问题。之前写过使用Windbg排查多线程死锁的实战案例,可以去查看我的文章:

使用Windbg分析多线程临界区死锁问题分享https://blog.csdn.net/chenlycly/article/details/128532743

4、软件操作权限问题

4.1、管理员权限与标准用户权限

        在Windows中,程序的运行权限主要有两种,一种是标准用户权限(非管理员权限),一种是管理员权限。有些操作是需要管理员权限的,比如向系统中注册控件、向C:Program Files等系统关键路径中执行写操作(创建文件、向文件中写入内容等)、向HKEY_LOCAL_MACHINE注册表路径下执行写操作(创建注册表项、向注册表项写入内容等)。如果程序中要执行这些需要管理员权限的操作,需要以管理员权限运行,否则会操作失败。

一般安装程序需要以管理员权限运行,因为可能需要执行上述需要管理员权限的操作。

       要让一个程序以管理员权限运行,一般有以下三种方法:

1)在程序的工程属性中设置requireAdministrator配置选项;
2)在启动程序时,选择右键点击程序或者程序的快捷方式,在弹出的右键菜单中选择以管理员身份运行;
3)在程序中启动另一个程序,可以调用ShellExecuteEx接口传入runas参数,将另一个程序以管理员权限启动起来。

4.2、权限不对等导致程序相互操作失败

       权限不对等(运行权限不同,一个以标准用户权限运行,一个以管理员权限运行)的两个程序,在相互操作时会出现失败的问题。不同权限的两个程序进程,在相互操作时遵循以下的规则:

1)同等权限的两个程序进程,可以相互操作;

2)低权限(标准用户权限)的程序进程,不能操作高权限(管理员权限)的程序进程;

3)高权限(管理员权限)的程序进程,可以操作低权限(标准用户权限)的程序进程;

       比如当我们需要将Windbg附加到目标进程上进行动态调试时,如果目标程序是以管理员权限运行的,而Windbg是直接双击桌面快捷方式启动的,是以标准用户权限运行,将Windbg附加到进程上会提示附加失败:

​因为Windbg是以标准用户权限运行的,而要附加的目标进程是以管理员权限运行的,两个程序权限不对等,所以附加失败。

       再比如我们使用API Monitor工具去监测目标程序对API函数调用时,如果API Monitor是直接双击以标准用户权限运行,那在API Monitor中显示的进程列表中是看不到以管理员权限运行的程序进程的。比如我们要监测QQ安装包程序的函数调用,QQ安装包是以管理员权限运行的,API Monitor是直接双击以标准用户权限运行,在API Monitor显示的进程列表中是看不到QQ安装包进程的。此时必须以管理员权限运行API Monitor,进程列表中才能看到QQ安装包进程:

​看到QQ安装包进程,才能开启对QQ安装包进程的监测。 

       因为权限不够导致的不能操作问题,直接右键以管理员权限运行程序即可。

      关于Windows应用程序运行权限以及因为权限不对等引发软件工具无法正常使用的实例分析,可以查看我之前写的文章:

Windows UAC权限详解以及因为权限不对等引发软件工具无法正常使用的实例分析https://blog.csdn.net/chenlycly/article/details/142304665

5、最后

      上述内容均是从项目中遇到的实战问题总结归纳出来的,很有实战参考价值,希望能帮到大家。 


       当前是C++软件实战问题排查经验分享系列第2期,第1期的分享已经发布,感兴趣的话,可以去查看文章:

【C++软件实战问题排查经验分享系列 ①】UI界面卡顿 | CPU占用高 | GDI对象泄漏 | 线程堵塞 系列问题排查总结https://blog.csdn.net/chenlycly/article/details/147382470


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

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP 服务器 linux 运维 游戏 云计算 进程 操作系统 进程控制 Ubuntu ssh deepseek Ollama 模型联网 API CherryStudio python MCP llama 算法 opencv 自然语言处理 神经网络 语言模型 javascript 前端 chrome edge 数据库 centos oracle 关系型 安全 分布式 Dell R750XS 科技 ai java 人工智能 个人开发 阿里云 网络 网络安全 网络协议 ubuntu harmonyos 华为 开发语言 typescript 计算机网络 react.js 前端面试题 node.js 持续部署 tcp/ip YOLO 深度学习 pytorch nuxt3 vue3 android c++ c语言 spring sql KingBase fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse 银河麒麟 kylin v10 麒麟 v10 spring boot websocket docker 实时音视频 filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 adb nginx 监控 自动化运维 自动化 蓝耘科技 元生代平台工作流 ComfyUI pycharm conda pillow django flask web3.py kubernetes 容器 学习方法 经验分享 程序人生 gitlab numpy json html5 firefox macos RTSP xop RTP RTSPServer 推流 视频 kvm 无桌面 命令行 zotero WebDAV 同步失败 代理模式 IIS .net core Hosting Bundle .NET Framework vs2022 笔记 C 环境变量 进程地址空间 ollama llm php http ESP32 microsoft arm开发 架构 权限 mysql eureka web安全 机器学习 云原生 AIGC pppoe radius AI agent prometheus 监控k8s集群 集群内prometheus vue.js audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 windows java-ee udp 博客 僵尸进程 react next.js 部署 部署next.js rust YOLOv8 NPU Atlas800 A300I pro 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP 远程工作 远程登录 telnet 机器人 mongodb qt 多线程服务器 TCP服务器 qt项目 qt项目实战 qt教程 bash 小程序 flash-attention 报错 Dify 编辑器 ide uni-app 宝塔面板 同步 备份 建站 安全威胁分析 AI编程 vscode 1.86 豆瓣 追剧助手 迅雷 nas 微信 内存 目标检测 计算机视觉 Docker Hub docker pull 镜像源 daemon.json Linux LDAP https jvm kylin 面试 后端 aws googlecloud 服务器繁忙 备选 网站 api 调用 示例 银河麒麟桌面操作系统 Kylin OS 国产化 Reactor 设计模式 性能优化 C++ jenkins gitee tomcat postman mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 maven intellij idea 腾讯云 IIS服务器 IIS性能 日志监控 MQTT mosquitto 消息队列 智能路由器 外网访问 内网穿透 端口映射 word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 sqlite openssl 密码学 shell 根服务器 spring cloud intellij-idea kafka hibernate sqlserver vscode 统信 国产操作系统 虚拟机安装 游戏程序 ftp github git jdk android studio golang redis apache 孤岛惊魂4 运维开发 安全架构 医疗APP开发 app开发 GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 ssl DeepSeek-R1 API接口 爬虫 Headless Linux pdf 华为认证 网络工程师 交换机 开源 Linux网络编程 AI 数据集 visualstudio live555 rtsp rtp virtualenv arm debian 嵌入式硬件 驱动开发 硬件工程 嵌入式实习 电脑 交互 代码调试 ipdb fpga开发 ecmascript nextjs reactjs vim 搜索引擎 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 MI300x DeepSeek ux 多线程 单片机 stm32 重启 排查 系统重启 日志 原因 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap 开发环境 SSL证书 svn 能力提升 面试宝典 技术 IT信息化 创意 社区 串口服务器 c# Flask FastAPI Waitress Gunicorn uWSGI Uvicorn 银河麒麟操作系统 rpc 远程过程调用 Windows环境 直播推流 C语言 Docker Compose docker compose docker-compose 物联网 flutter Hyper-V WinRM TrustedHosts JAVA IDEA Java idm 联想开天P90Z装win10 TRAE matlab excel asi_bench ecm bpm C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 Deepseek mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 MCP server C/S LLM ci/cd ddos agi ansible playbook gpu算力 3d 数学建模 网络结构图 华为云 springsecurity6 oauth2 授权服务器 前后端分离 html FunASR ASR 向日葵 佛山戴尔服务器维修 佛山三水服务器维修 go file server http server web server 集成学习 集成测试 Cursor oceanbase rc.local 开机自启 systemd 麒麟 学习 ffmpeg 音视频 媒体 深度优先 图论 并集查找 换根法 树上倍增 pygame 小游戏 五子棋 MNN Qwen chatgpt 大模型 llama3 Chatglm 开源大模型 dify hugo 远程桌面 gaussdb ruoyi 负载均衡 xss 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 jupyter pip 相机 unix 智能手机 大数据 矩阵 软件工程 工业4.0 ocr 思科模拟器 思科 Cisco mysql离线安装 ubuntu22.04 mysql8.0 IM即时通讯 QQ 企业微信 剪切板对通 HTML FORMAT 微服务 源码 毕业设计 课程设计 list 模拟实现 rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK elasticsearch 无人机 ui kind AI写作 AI作画 聊天室 fd 文件描述符 鸿蒙 华为od 小智AI服务端 xiaozhi TTS 其他 银河麒麟服务器操作系统 系统激活 hadoop Qwen2.5-coder 离线部署 hive Hive环境搭建 hive3环境 Hive远程模式 visual studio code unity webgl Linux的基础指令 cocoapods xcode Radius 数据分析 ios IMX317 MIPI H265 VCU 考研 数据结构 muduo onlyoffice 在线office 个人博客 SenseVoice 弹性计算 虚拟化 KVM 计算虚拟化 弹性裸金属 系统安全 鸿蒙系统 k8s windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 chrome 浏览器下载 chrome 下载安装 mac 谷歌浏览器下载 软件测试 proxy模式 EMQX 通信协议 HAProxy Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 vue css less 毕昇JDK 命令 grafana minio junit MySql SEO 漏洞 显示管理器 lightdm gdm CPU 主板 电源 网卡 程序 编程 性能分析 epoll 阻塞队列 生产者消费者模型 服务器崩坏原因 laravel HarmonyOS Next 实战案例 SSH Xterminal 实时互动 半虚拟化 硬件虚拟化 Hypervisor 远程连接 魔百盒刷机 移动魔百盒 机顶盒ROM unity3d 策略模式 单例模式 网络穿透 云服务器 n8n 工作流 workflow Netty 即时通信 NIO HTTP 服务器控制 ESP32 DeepSeek Linux24.04 deepin 文件系统 路径解析 田俊楠 反向代理 中间件 可信计算技术 网络攻击模型 致远OA OA服务器 服务器磁盘扩容 ollama下载加速 .netcore express okhttp CORS 跨域 游戏机 deepseek r1 双系统 GRUB引导 Linux技巧 vasp安装 查询数据库服务IP地址 SQL Server Windows 语音识别 AutoDL 流水线 脚本式流水线 efficientVIT YOLOv8替换主干网络 TOLOv8 HCIE 数通 客户端 iphone SVN Server tortoise svn r语言 数据挖掘 数据可视化 1024程序员节 ip 计算机 程序员 iperf3 带宽测试 make命令 makefile文件 dubbo W5500 OLED u8g2 gateway Clion Nova ResharperC++引擎 Centos7 远程开发 ShenTong 图像处理 业界资讯 前端框架 webrtc kamailio sip VoIP Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 大数据平台 信号处理 信息与通信 银河麒麟高级服务器 外接硬盘 Kylin WSL2 线程 jar gradle redhat 安卓 wireshark VMware安装Ubuntu Ubuntu安装k8s 镜像 Java Applet URL操作 服务器建立 Socket编程 网络文件读取 AI大模型 大模型入门 大模型教程 ROS 自动驾驶 OD机试真题 华为OD机试真题 服务器能耗统计 ukui 麒麟kylinos openeuler rust腐蚀 dns .net 低代码 回显服务器 UDP的API使用 vSphere vCenter navicat springboot Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 升级 CVE-2024-7347 VPS MacOS录屏软件 烟花代码 烟花 元旦 AI-native Docker Desktop 智能音箱 智能家居 etcd 数据安全 RBAC yolov8 mamba Vmamba jmeter 需求分析 规格说明书 zabbix Typore 微信小程序 openEuler web XCC Lenovo 飞书 繁忙 解决办法 替代网站 汇总推荐 AI推理 CDN web3 恒源云 selenium 测试工具 dba tcp autodl dity make 软件定义数据中心 sddc 王者荣耀 big data devops oneapi bcompare Beyond Compare 交叉编译 嵌入式 open webui 模拟器 教程 IMM 安装教程 GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 硬件架构 Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 embedding echarts 传统数据库升级 银行 大语言模型 LLMs 单一职责原则 IPMITOOL BMC 硬件管理 token sas 鲲鹏 FTP 服务器 GCC Linux环境 游戏引擎 抗锯齿 cursor 计算机外设 LORA NLP ardunio BLE gitea asp.net大文件上传 asp.net大文件上传下载 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 iis 移动云 云服务 lio-sam SLAM wsl 图形化界面 Node-Red 编程工具 流编程 zookeeper nfs SSL 域名 rsyslog armbian u-boot 缓存 系统架构 webstorm Trae IDE AI 原生集成开发环境 Trae AI yum apt 服务器主板 AI芯片 中兴光猫 换光猫 网络桥接 自己换光猫 WSL win11 无法解析服务器的名称或地址 ArkUI 多端开发 智慧分发 应用生态 鸿蒙OS 项目部署到linux服务器 项目部署过程 本地部署 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 asm 国内源 单元测试 功能测试 虚拟局域网 EasyConnect Cline Kali Linux 黑客 渗透测试 信息收集 tensorflow 黑客技术 网工 opensearch helm xpath定位元素 换源 Debian ssrf 失效的访问控制 postgresql tcpdump openwrt 视觉检测 vscode1.86 1.86版本 ssh远程连接 SSE open Euler dde 统信UOS db LLM Web APP Streamlit 显卡驱动 wsl2 rabbitmq ruby 游戏服务器 TrinityCore 魔兽世界 sysctl.conf vm.nr_hugepages VMware安装mocOS VMware macOS系统安装 adobe elk Python 网络编程 聊天服务器 套接字 TCP Socket 群晖 bug gcc 环境迁移 c 虚拟机 Ubuntu 24.04.1 轻量级服务器 python3.11 dash 正则表达式 Kali selete 高级IO 文件分享 虚幻 实习 odoo 服务器动作 Server action P2P HDLC sentinel 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 微信分享 Image wxopensdk 毕设 springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 FTP服务器 KylinV10 麒麟操作系统 Vmware 微信公众平台 Agent 金仓数据库 2025 征文 数据库平替用金仓 ipython Linux PID 三级等保 服务器审计日志备份 DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 iBMC UltraISO 多个客户端访问 IO多路复用 TCP相关API 远程 执行 sshpass 操作 bootstrap 小艺 Pura X wps 软考 5G 3GPP 卫星通信 aarch64 编译安装 HPC WebUI DeepSeek V3 linux安装配置 bonding 链路聚合 树莓派 VNC 压力测试 rnn tailscale derp derper 中转 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 大文件秒传跨域报错cors windows日志 log4j Minecraft 防火墙 NAT转发 NAT Server Unity Dedicated Server Host Client 无头主机 stm32项目 netty Python基础 Python教程 Python技巧 VR手套 数据手套 动捕手套 动捕数据手套 linux驱动开发 seatunnel glibc npm 常用命令 文本命令 目录命令 输入法 HarmonyOS thingsboard 开机自启动 rag ragflow ragflow 源码启动 端口测试 H3C iDRAC R720xd freebsd dell服务器 css3 frp 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 XFS xfs文件系统损坏 I_O error es 腾讯云大模型知识引擎 加解密 Yakit yaklang iot k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm can 线程池 rclone AList webdav fnOS X11 Xming eclipse linux上传下载 健康医疗 互联网医院 rdp 实验 我的世界服务器搭建 HiCar CarLife+ CarPlay QT RK3588 Wi-Fi 超融合 合成模型 扩散模型 图像生成 ssh远程登录 Spring Security 我的世界 我的世界联机 数码 昇腾 npu UOS 统信操作系统 ESXi Dell HPE 联想 浪潮 safari Mac 系统 ISO镜像作为本地源 云电竞 云电脑 todesk 历史版本 下载 安装 DevEco Studio OpenHarmony 真机调试 IPMI 带外管理 职场和发展 jetty undertow linux 命令 sed 命令 etl NAS Termux Samba 温湿度数据上传到服务器 Arduino HTTP yaml Ultralytics 可视化 sdkman 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 服务器管理 配置教程 服务器安装 网站管理 远程控制 rustdesk 剧本 alias unalias 别名 dns是什么 如何设置电脑dns dns应该如何设置 ceph cuda cudnn nvidia 自动化任务管理 DeepSeek行业应用 Heroku 网站部署 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 prometheus数据采集 prometheus数据模型 prometheus特点 uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 ip命令 新增网卡 新增IP 启动网卡 camera Arduino 电子信息 状态模式 rpa Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 perf yum源切换 更换国内yum源 混合开发 环境安装 JDK PX4 测试用例 regedit 开机启动 DBeaver 数据仓库 kerberos 程序员创富 nlp VS Code Linux find grep composer 基础入门 ue5 vr 产测工具框架 IMX6ULL 管理框架 AD 域管理 网站搭建 serv00 算力 微信开放平台 微信公众号配置 openstack Xen 本地化部署 threejs 3D centos-root /dev/mapper yum clean all df -h / du -sh hexo TCP协议 京东云 开发 milvus edge浏览器 物联网开发 具身智能 强化学习 clickhouse 私有化 社交电子 Logstash 日志采集 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 玩机技巧 软件分享 软件图标 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 语法 langchain 直流充电桩 充电桩 minecraft 李心怡 SWAT 配置文件 服务管理 网络共享 Linux的权限 Nuxt.js trea idea Ubuntu Server Ubuntu 22.04.5 分布式训练 docker部署Python 热榜 ubuntu24.04.1 裸金属服务器 弹性裸金属服务器 p2p USB转串口 CH340 micropython esp32 mqtt 飞牛NAS 飞牛OS MacBook Pro harmonyOS面试题 prompt cnn 邮件APP 免费软件 软件需求 OpenSSH pgpool AD域 fast 软链接 硬链接 大模型应用 outlook NFS Windsurf DenseNet IPv4 子网掩码 公网IP 私有IP SSH 密钥生成 SSH 公钥 私钥 生成 CrewAI 离线部署dify ABAP 键盘 边缘计算 智能硬件 链表 模拟退火算法 EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 代理服务器 增强现实 沉浸式体验 应用场景 技术实现 案例分析 AR 项目部署 code-server 技能大赛 iftop 网络流量监控 存储维护 NetApp存储 EMC存储 SSH 服务 SSH Server OpenSSH Server 粘包问题 MS Materials chfs ubuntu 16.04 嵌入式系统开发 eNSP 企业网络规划 华为eNSP 网络规划 DocFlow gpt 串口驱动 CH341 uart 485 ubuntu24 vivado24 flink uv 信息可视化 网页设计 华为机试 数据库系统 C# MQTTS 双向认证 emqx 虚幻引擎 AISphereButler conda配置 conda镜像源 remote-ssh k8s集群资源管理 云原生开发 框架搭建 RAGFLOW 远程服务 自动化编程 做raid 装系统 mcu 火绒安全 内网服务器 内网代理 内网通信 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 服务器数据恢复 数据恢复 存储数据恢复 北亚数据恢复 oracle数据恢复 ai小智 语音助手 ai小智配网 ai小智教程 esp32语音助手 diy语音助手 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 西门子PLC 通讯 Attention 大模型部署 ros2 moveit 机器人运动 YOLOv12 雨云 NPS uniapp RAG 检索增强生成 文档解析 大模型垂直应用 办公自动化 自动化生成 pdf教程 RTMP 应用层 CentOS seleium chromedriver 自动化测试 skynet 产品经理 大模型微调 MDK 嵌入式开发工具 论文笔记 sublime text arcgis anaconda searxng 网络药理学 生物信息学 生信 PPI String Cytoscape CytoHubba 影刀 #影刀RPA# wsgiref Web 服务器网关接口 g++ g++13 opcua opcda KEPServer安装 pyautogui spark HistoryServer Spark YARN jobhistory 阿里云ECS 运维监控 wpf firewall VSCode 代理 raid5数据恢复 磁盘阵列数据恢复 嵌入式Linux IPC 自定义客户端 SAS CLion 僵尸世界大战 游戏服务器搭建 figma EMUI 回退 降级 gnu AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 服务器部署ai模型 bot Docker Anolis nginx安装 linux插件下载 leetcode 推荐算法 kali 共享文件夹 java-rocketmq v10 软件 ldap cd 目录切换 GIS 遥感 WebGIS Google pay Apple pay AI Agent 字节智能运维 mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 大大通 第三代半导体 碳化硅 curl wget 端口 查看 ss GoogLeNet ai工具 pyqt Ark-TS语言 Kylin-Server 内网环境 hosts springcloud h.264 灵办AI RustDesk自建服务器 rustdesk服务器 docker rustdesk dock 加速 政务 分布式系统 监控运维 Prometheus Grafana 流式接口 URL WebRTC easyui docker run 数据卷挂载 交互模式 win服务器架设 windows server gpt-3 文心一言 Open WebUI 迁移指南 VMware创建虚拟机 网卡的名称修改 eth0 ens33 cmos 硬件 元服务 应用上架 tidb GLIBC cpp-httplib ros RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 xrdp SRS 流媒体 直播 trae 序列化反序列化 crosstool-ng 信创 信创终端 中科方德 deep learning 人工智能生成内容 金融 飞牛nas fnos 知识库 RAGFlow 本地知识库部署 DeepSeek R1 模型 搭建个人相关服务器 网络用户购物行为分析可视化平台 大数据毕业设计 sqlite3 deekseek Ubuntu共享文件夹 共享目录 Linux共享文件夹 崖山数据库 YashanDB 拓扑图 视频编解码 源码剖析 rtsp实现步骤 流媒体开发 wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 VLAN 企业网络 linux环境变量 多层架构 解耦 性能测试 GPU 雨云服务器 车载系统 远程看看 远程协助 知识图谱 QT 5.12.12 QT开发环境 Ubuntu18.04 分析解读 架构与原理 neo4j docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos cpu 实时 使用 minicom 串口调试工具 相差8小时 UTC 时间 LInux 信号 RAID RAID技术 磁盘 存储 risc-v 风扇控制软件 swoole Deepseek-R1 私有化部署 推理模型 EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 欧标 OCPP Invalid Host allowedHosts MacMini 迷你主机 mini Apple 软负载 多进程 宠物 免费学习 宠物领养 宠物平台 visual studio lua vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 干货分享 黑客工具 密码爆破 docker命令大全 nac 802.1 portal 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 压测 ECS 域名服务 DHCP 符号链接 配置 CentOS Stream 音乐库 飞牛 实用教程 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 宕机切换 服务器宕机 triton 模型分析 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 线性代数 电商平台 Cookie transformer midjourney DOIT 四博智联 蓝桥杯 PVE ue4 着色器 7z 环境配置 Claude rocketmq av1 电视盒子 大模型面经 大模型学习 状态管理的 UDP 服务器 Arduino RTOS AnythingLLM AnythingLLM安装 命名管道 客户端与服务端通信 深度求索 私域 Xinference ubuntu20.04 开机黑屏 jina Unity插件 匿名管道 技术共享 iventoy VmWare OpenEuler keepalived sonoma 自动更新 xshell termius iterm2 磁盘监控 基础环境 服务器配置 mariadb 数据库开发 database Redis Desktop chrome devtools 多路转接 执法记录仪 智能安全帽 smarteye SysBench 基准测试 ArcTS 登录 ArcUI GridItem 流量运营 arkUI 服务网格 istio Jellyfin js mybatis 沙盒 系统开发 binder framework 源码环境 word TrueLicense matplotlib x64 SIGSEGV xmm0 USB网络共享 Playwright DNS UDP grub 版本升级 扩容 服务器时间 浏览器开发 AI浏览器 ssh漏洞 ssh9.9p2 CVE-2025-23419 bat 游戏开发 firewalld 设备 PCI-Express vmware 卡死 鸿蒙开发 移动开发 llama.cpp 音乐服务器 Navidrome 音流 捆绑 链接 谷歌浏览器 youtube google gmail AI代码编辑器 .net mvc断点续传 ping++ rime 图形渲染 黑苹果 Erlang OTP gen_server 热代码交换 事务语义 sequoiaDB docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 大模型推理 IO模型