IDE/mingw下动态库(.dll和.a文件)的生成和部署使用(对比MSVC下.dll和.lib)

news2024/11/25 13:16:39

文章目录

  • 概述
  • 问题的产生
    • 基于mingw的DLL动态库
    • 基于mingw的EXE可执行程序
    • Makefile文件中使用Qt库的\*.a文件
    • mingw下的*.a 文件 和 *.dll 到底谁起作用
    • 小插曲
  • mingw 生成的 \*.a文件到底是什么
  • 为啥mingw的dll可用以编译链接过程
  • 转换为lib引导文件

概述

本文介绍了 QtCreator + mingW 集成开发环境下的动态库生成和使用方法,重点分析了mingw下动态库项目编译后生成的*.a文件的作用到底是什么。本文还对比分析了mingw下动态库的部署和使用与MSVC下动态库生成和使用方式上的不同。
使用MingW编译器时,没有生成.lib引导文件,那么mingW是如何完成动态库链接过程的呢?而且经验告诉我们,mingw下,可执行程序使用dll时,是可以直接指向dll文件进行编译链接过程的,它是怎么做到的呢?

关于VS集成开发环境下的DLL生成和部署使用,可参考《IDE/在VS下DLL动态库的部署和加载问题分析》,以更好对比分析。

MinGW 提供了一个开发环境,可以方便地在 Windows 平台上进行 C、C++ 和其他编程语言的开发。开发人员可以使用 MinGW 提供的工具和库来编写 Windows 应用程序,而不需要依赖于 Microsoft Visual Studio 或其他商业开发工具。MinGW 是基于 GNU 工具集的一个分支,它允许开发人员在 Windows 环境中使用类似于 Linux 下的开发工具,如 GCC 编译器、GNU Make 等,以及一些常用的库文件,如 C/C++ 运行时库、Windows API 的头文件等。

问题的产生

Demo 代码 的总体目录分布,E:\TestDll,下设:bin、bin_d、DllOfMingw、ExeOfMingw 目录,DllOfMingw.pro 位于DllOfMingw目录;ExeOfMingw.pro 位于 ExeOfMingw 目录。特殊测试步骤上,还设 E:\TestDll\lib 目录。

基于mingw的DLL动态库

在 Qt Creator 文件菜单下,选择新建文件或项目,在弹出的选项卡中,选择 Library - C++ Library,新建名为 DllOfMingw 的工程。
在这里插入图片描述
Qt modules 选择 Qt 无关,Kits 选择 Mingw 64…

//DllOfMingw.pro 
CONFIG -= qt

TEMPLATE = lib
DEFINES += DLLOFMINGW_LIBRARY

CONFIG += c++11

Debug:DESTDIR = $$PWD/../bin_d
Debug: TARGET = dllofmingw_d

Release: DESTDIR = $$PWD/../bin
Release: TARGET = dllofmingw

SOURCES += \
    dllofmingw.cpp

HEADERS += \
    dllofmingw.h \
    dllofmingw_global.h

DEFINES += QT_DEPRECATED_WARNINGS
//dllofmingw_global.h
#ifndef DLLOFMINGW_GLOBAL_H
#define DLLOFMINGW_GLOBAL_H

#if defined(_MSC_VER) || defined(WIN64) || defined(_WIN64) || defined(__WIN64__) || defined(WIN32) || defined(_WIN32) || defined(__WIN32__) || defined(__NT__)
#  define Q_DECL_EXPORT __declspec(dllexport)
#  define Q_DECL_IMPORT __declspec(dllimport)
#else
#  define Q_DECL_EXPORT     __attribute__((visibility("default")))
#  define Q_DECL_IMPORT     __attribute__((visibility("default")))
#endif

#if defined(DLLOFMINGW_LIBRARY)
#  define DLLOFMINGW_EXPORT Q_DECL_EXPORT
#else
#  define DLLOFMINGW_EXPORT Q_DECL_IMPORT
#endif

#endif // DLLOFMINGW_GLOBAL_H
//dllofmingw.h
#ifndef DLLOFMINGW_H
#define DLLOFMINGW_H
#include <string>
#include "dllofmingw_global.h"

class DLLOFMINGW_EXPORT DllOfMingw
{
public:
    DllOfMingw();
public:
    std::string InvokeTest();
};
#endif // DLLOFMINGW_H
//dllofmingw.cpp
#include "dllofmingw.h"

DllOfMingw::DllOfMingw() { }

std::stringDllOfMingw::InvokeTest()
{ return "Dll Interface was invoked!"; }

以Debug模式编译上述项目,在E:\TestDll\bin_d目录下生成两个文件,
在这里插入图片描述
它们是干什么的,尤其是 libdllofmingw_d.a 到底是干什么的,容后再叙。

基于mingw的EXE可执行程序

在 Qt Creator 文件菜单下,选择新建文件或项目,在弹出的选项卡中,选择 Application,新建名为 ExeOfMingw 的Qt控制台工程。选择与DLL项目相同的Kits设置。项目创建与DLL一致,均为 E:\TestDll 目录。

//ExeOfMingw.pro
QT -= gui

CONFIG += c++11 console
CONFIG -= app_bundle

DEFINES += QT_DEPRECATED_WARNINGS

SOURCES += \
        main.cpp

# you'd better build a public include
INCLUDEPATH += $$PWD/../DllOfMingw

win32 {
    Debug:LIBS  +=   -L$$PWD/../bin_d \
                     -ldllofmingw_d

    Release:LIBS  += -L$$PWD/../bin \
                      -ldllofmingw
}

# .exe's dir same as .dll file
Debug:DESTDIR = $$PWD/../bin_d
Release: DESTDIR = $$PWD/../bin
//mian.cpp
#include <QCoreApplication>
#include <QDebug>
#include "dllofmingw.h"

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    DllOfMingw aDll;
    qDebug() << QString::fromLocal8Bit(aDll.InvokeTest().c_str());

    return a.exec();
}

Makefile文件中使用Qt库的*.a文件

在上述测试代码下,DLL和EXE均可正常编译和执行。运行可输出 “Dll Interface was invoked!”…

之前在整理其他集成开发环境相关问题的时候就发现过,在Makefile文件中,LIBS中对Qt库的引用使用的是*.a文件,当时只作了记录并未细究。以上述正常编译和运行的代码为例子,打开ExeOfMingw 项目编译目录下的 Makefile.Debug 文件,

LIBS = -LE:\TestDll\bin_d -ldllofmingw_d D:\Qt\Qt5.12.8\5.12.8\mingw73_64\lib\libQt5Cored.a  

此时的相关的编译输出,截图如下,可以与makefile相互匹配上,
在这里插入图片描述
可惜的是,我们无法通过红色框标记的内容,来判断出 ExeOfMingw 在编译阶段,到底使用了 dllofmingw_d.dll 和 libdllofmingw_d.a 的哪一个。不过,看到 ExeOfMingw 在LIBS中引用的是libQt5Cored.a 文件,我们大概率先猜测,“-LE:\TestDll\bin_d -ldllofmingw_d” 会指向 $$PWD/…/bin_d/libdllofmingw_d.a 文件,但事实如此吗?

mingw下的*.a 文件 和 *.dll 到底谁起作用

单纯地结合VS下动态库部署和执行的相关理论常识,DLL它也不应该与编译有关才对!但是以往的经验早就告诉了我们,在mingw编译套件下,dll文件似乎是在编译过程中起到作用的。为此,我们将在上述正常编译和运行的程序部署的基础上,逐步展开测试。注意,为了保证测试的可靠性,我每次重新编译前,均是手动删除上次编译生成的过程文件。

Test-1
我们重点关注 libdllofmingw_d.a 这个文件,并猜测它可能与 MSVC编译器下的动态库引导文件起到了相同的作用。为此,我们删除 E:\TestDll\bin_d\libdllofmingw_d.a 文件,重新执行 ExeOfMingw 编译,并无编译异常发生,运行也无误。
Test-2
然后我们将 libdllofmingw_d.a 恢复回来,将 dllofmingw_d.dll 删除,再次重新执行 ExeOfMingw 编译,也不存在编译异常。dll是运行时加载使用的,没有它,程序肯定是无法正常运行的。
Test-3
我们在 《IDE/集成开发环境 Qt Creator+MSVC编译器+CDB调试器》文中,已经测试过,在使用MSVC编译器的情况下,pro工程文件中的LIBS必须配置动态库引导文件lib的路径和名称,否则无法通过编译。前文中的测试,我们每次只是删除了 dllofmingw_d.dll 或 libdllofmingw_d.a 中的一个,如果两个一起删除呢?
在这里插入图片描述
呢,编译报错了,找不到指定的 dllofmingw_d 库了。而且此处的含义应该是:即没有找到 dllofmingw_d.dll ,也没有找到 libdllofmingw_d.a 文件。因为,但凡他俩存在一个,都没有出现编译错误。
再来一轮回归测试,
只将 dllofmingw_d.dll 添加回到 E:\TestDll\bin_d,编译 ExeOfMingw 无误,运行无误。
只将 libdllofmingw_d.a 添加回到 E:\TestDll\bin_d,编译 ExeOfMingw 无误,但程序无法正常运行。
Test-4
来点狠的,使用migw编译器时,我若不进行 LIBS配置,
在这里插入图片描述

临时结论,
引用 mingw编译的DLL时,也必须要配置 LIBS 路径和文件,但是对于编译过程,只要存在 dllofmingw_d.dll 或 libdllofmingw_d.a 中的其中任意一个,即可通过编译过程。因此可以猜测?mingw编译动态库项目时生成的 *.lib文件 和 *.a 文件,都可以在编译环节支持链接到调用它的可执行程序中。

验证 *.a文件对编译过程的支持,
进一步的,我们将 *.a 脱离 bin文件夹,放到单独的E:\TestDll\lib文件夹下,dllofmingw_d.dll依然放在E:\TestDll\bin_d下,相应的修改 ExeOfMingw.pro 文件中的 LIBS 配置,

win32 {
    Debug:LIBS  +=   -L$$PWD/../lib \
                     -ldllofmingw_d

    Release:LIBS  += -L$$PWD/../lib \
                      -ldllofmingw
}

经过测试,可以通过编译过程,运行也没有任何异常。

最后的几个结论,

  • mingw下的动态库引用,也是必须要进行LIBS配置的。
  • mingw下编译动态库项目时生成的 lib*.a文件,可以用以编译链接过程。
  • 且qmke构建的项目中,对Qt框架库的引用,LIBS配置的就是 *.a类型的文件。
  • 如果没有 *.a文件,只有mingw下生成的.dll文件,也是能支持编译链接过程的。

如此看来,针对动态库项目,把mingw下的*.a文件类比为MSVC下的*.lib引导文件,并没有什么大问题,它们的命名方式和功能都基本一致。差别较大的地方在于,mingw下的.dll类型的文件,自身也可以参与编译链接过程,而msvc下生成的.dll文件并没有此功能。

小插曲

在某个测试阶段,我遇到了如下运行异常。编译没有问题,但是程序总是无法启动,连main函数都进不去。
在这里插入图片描述
尝试,重新启动QtCreator 并未生效。“qtcreator_process_stub.exe” 是 Qt Creator 中用于与正在调试的应用程序进行交互的帮助进程。它允许 Qt Creator 与应用程序进行通信,设置断点,检查变量并控制调试过程。如上错误消息,“qtcreator_process_stub.exe” 进程无法启动,但返回 “操作成功完成”,意味着进程的执行本身并没有发生错误,操作系统返回的进程退出代码是 “0”,代表进程正常退出。

我将,dllofmingw_d.dll 和 ExeOfMingw.exe 拷贝到Qt对应的bin库下执行,没有问题。我关机重启了PC,依然无济于事。于是,我将关于动态库的引用全部注释掉,也无济于事。我随便新建一个新的控制台应用程序,测试我的IDE环境有没有问题? 结果悲催了,不能用了竟然。难道,我的IDE被Qt公司使绊子啦?
使用 Everything 搜索 qtcreator_process_stub 找到它,D:\Qt\Qt5.9.3\Tools\QtCreator\bin,并使用命令窗口执行它,
在这里插入图片描述
结合此情此景,我还能想到的可能是,杀毒软件,打开,果然,从隔离区将上述文件恢复后,相关问题不攻自破。
在这里插入图片描述

mingw 生成的 *.a文件到底是什么

在VS & MSVC下当我们使用 动态库隐式加载方式时,必须要有 *.lib的动态引导文件,才可以正常编译。在mingw下没有 *.lib文件生成, *.a 文件看上去倒是有点类似 MSVC下的 *.lib,但此时我还不确定 *.a文件到底是啥 ?有的资料中显示, *.a 文件是静态库文件,但我觉得这就跟有人胡说MSVC下的 *.lib文件是静态库文件一样。

为进一步说明,mingw下的 *.a 文件不是静态库文件,我们新建一个mingw下的静态库项目,将其实现成DLL一致,并对比它们。

在 Qt Creator 文件菜单下,选择新建文件或项目,在弹出的选项卡中,选择 Library - C++ Library,项目名称 SllOfMingw,创建路径为E:\TestDll,与DLL项目一致。选择项目类型为 Statically Linked Library 静态链接库。Qt module 还是none,与Qt无关,Kits也还选择mingw 64… 将 SllOfMingw 类与 DllOfMingw 类 做一致的实现…
在这里插入图片描述
观察静态库项目,发现,其没有了DLL项目下的 dllofmingw_global.h 这样的导出宏定义;pro文件相比DLL,其中多出来一个 CONFIG += staticlib 配置。为了具有更好的可比性,我们将SLL和DLL实现为一样的接口和属性。

//SllOfMingw.pro
CONFIG -= qt
CONFIG += c++11

TEMPLATE = lib
CONFIG += staticlib

DEFINES += QT_DEPRECATED_WARNINGS

Debug:DESTDIR = $$PWD/../bin_d
Debug: TARGET = sllofmingw_d

Release: DESTDIR = $$PWD/../bin
Release: TARGET = sllofmingw

SOURCES += \
    sllofmingw.cpp
HEADERS += \
    sllofmingw.h
//sllofmingw.h
#ifndef SLLOFMINGW_H
#define SLLOFMINGW_H

#include <string>

class SllOfMingw
{
public:
    SllOfMingw();
public:
    std::string InvokeTest();
};

#endif // SLLOFMINGW_H
//sllofmingw.cpp
#include "sllofmingw.h"

SllOfMingw::SllOfMingw() { }

std::string SllOfMingw::InvokeTest() {
    return "Sll Interface was invoked!"; }

编译完成后可知,该静态库项目仅仅生成了名为 libsllofmingw_d.a 的静态库文件,如下红框标记。
在这里插入图片描述
另外,
我们也注意到,虽然都是.a静态库文件类型的后缀,但是 libsllofmingw_d.a 真静态库文件比 libdllofmingw_d.a 这假静态库文件要大一个数量级。因此可断定,libdllofmingw_d.a 不是真正的静态库文件,这与MSVC下编译生成的*.lib文件不是真正的静态库文件如出一辙。与MSVC下的.lib引导文件一样,mingw动态库项目生成的.a类型的文件,也具有参与编译链接过程的能力,顾,完全也可以称此时的.a文件为mingw下的动态库引导文件。

为啥mingw的dll可用以编译链接过程

先给自己广普下编译器的链接过程,
编译器的连接过程是将多个编译后的目标文件(通常是 .obj 文件)和库文件(静态库或动态库)合并成最终的可执行文件或共享库的过程。连接器Linker的连接过程通常分为以下几个步骤:
符号解析(Symbol Resolution):连接器首先需要解析目标文件中的符号引用。符号引用是指在一个目标文件中引用了另一个目标文件或库文件中定义的函数、变量等符号。
地址重定位(Address Relocation):解析完符号引用后,连接器需要对引用进行地址重定位。这是因为目标文件中的符号地址是相对于目标文件自身的,连接器需要根据目标文件在最终可执行文件或共享库中的位置,对这些地址进行修正。
合并目标文件:连接器将所有的目标文件和库文件合并成一个单一的可执行文件或共享库。这一步通常包括解决符号冲突,以及将所有目标文件和库文件中的代码和数据按照一定的规则组织在一起。
生成可执行文件或共享库:连接器将合并后的目标文件和库文件生成最终的可执行文件或共享库。在生成可执行文件时,连接器会为程序的入口点设置正确的入口地址,使得程序能够正确地开始执行。

一种特殊的动态链接DLL的方法,
Mingw使用DLL本身作为动态库的引导文件,主要是因为它采用了一种称为"Load-Time Dynamic Linking"的链接方式。这是一种在程序加载时动态链接DLL的方法。当程序启动时,Mingw会解析DLL文件的导出表,并将DLL中的符号地址与程序中的对应符号进行绑定。这样,在程序运行过程中,当需要调用DLL中的函数或使用DLL中的数据时,程序就可以直接通过绑定的地址进行调用,而无需再进行动态链接。
这种链接方式的优势是在程序启动时就已经完成了所有的动态链接操作,因此在运行时可以更快地调用DLL中的函数,避免了运行时的动态链接开销。另外,由于Mingw是一个开源的编译器,它不像MSVC那样受到特定的商业约束和限制。因此,Mingw可以更灵活地处理动态链接的方式,选择将DLL本身作为动态库的引导文件。这种方式在一定程度上简化了编译和链接过程,使得Mingw可以更方便地与开源的DLL库进行集成和使用。

转换为lib引导文件

通常情况下,Mingw生成的DLL可以用于编译链接过程是因为它使用了与MSVC兼容的运行时库,可以与MSVC编译的可执行文件进行链接。而MSVC生成的DLL由于使用了自己的运行时库,所以不能直接与Mingw编译的可执行文件进行链接。如果需要在MSVC编译的项目中使用Mingw生成的DLL,需要进行一些额外的配置和适配工作。
但也要注意,使用 MinGW 编译生成的 DLL 文件通常依赖于 MinGW 的运行时库(例如 mingw32.dll),这些库在没有 MinGW 的系统上可能不存在或不兼容。因此需要确保将这些依赖性包含在生成的 DLL 文件中。这种跨编译器的装换并不是一件简单的事情,不到万不得已,是不建议如此操作的。

接下来我们将尝试将 DllOfMingw 项目生成的DLL转换成可以在mscv下使用的库…

在 D:\Qt\Qt5.12.8\Tools\mingw730_64\bin 下找到 gendef.exe 工具,该工具从 DLL 文件生成 .def 文件。
在这里插入图片描述
成功生成到了,D:\Qt\Qt5.12.8\Tools\mingw730_64\bin\dllofmingw_d.def,哈哈,肯定还有其他指令参数,没再细究。直接剪切dllofmingw_d.def到我的项目文件目录E:\TestDll\bin_d,进行下一步,
打开 Visual Studio 开发人员命令提示符,使用 lib 命令来生成 .lib 文件。命令如下,
在这里插入图片描述
如上,同时生成了.lib和.exp两种文件,
在这里插入图片描述
接下来我们新建一个VS项目,动态库部署和代码都没有问题,但是,我并没有成功。编译报错,

#include <stdio.h>
#include "dllofmingw.h"

int main()
{
    DllOfMingw aDll;
    printf("%s", aDll.InvokeTest().c_str());

    system("pause");
    return 0;
}

//ExeOfVS.obj : error LNK2019 : 无法解析的外部符号 "__declspec(dllimport) public: __cdecl DllOfMingw::DllOfMingw(void)" (__imp_ ? ? 0DllOfMingw@@QEAA@XZ),该符号在函数 main 中被引用
//ExeOfVS.obj : error LNK2019 : 无法解析的外部符号 "__declspec(dllimport) public: class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > __cdecl DllOfMingw::InvokeTest(void)" (__imp_ ? InvokeTest@DllOfMingw@@QEAA?AV ? $basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@XZ),该符号在函数 main 中被引用
//..\bin_d\ExeOfVS.exe : fatal error LNK1120 : 2 个无法解析的外部命令

通过上述告警信息,我发现,其中提示的导出符号,与dllofmingw_d.def中的定义,并不一致,

//dllofmingw_d.def
;
; Definition file of dllofmingw_d.dll
; Automatic generated by gendef
; written by Kai Tietz 2008
;
LIBRARY "dllofmingw_d.dll"
EXPORTS
_ZN10DllOfMingw10InvokeTestB5cxx11Ev
_ZN10DllOfMingwC1Ev
_ZN10DllOfMingwC2Ev

我没时间继续该问题了,只能暂时放弃。最后这小节,与本文的主要目的,契合度并不大,如果以后有机会将单独开篇继续。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/780963.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

17 界面布局--登录界面

要点&#xff1a; 利用widgets做布局&#xff1a;水平&#xff0c;垂直&#xff0c;栅格 利用弹簧设置收缩 widget宽高比实际控件大很多&#xff1a;设置Fixed 如果需要去除其余边框间隙可以设置layout 将最小尺寸和最大尺寸设置为固定即为固定尺寸 设置窗口标题&#xff1a;wi…

基于DeepFace模型设计的人脸识别软件

完整资料进入【数字空间】查看——baidu搜索"writebug" 人脸识别软件(无外部API) V2.0 基于DeepFace模型设计的人脸识别软件 V1.0 基于PCA模型设计的人脸识别软件 V2.0 更新时间&#xff1a;2018-08-15 在观看了吴恩达老师的“深度学习课程”&#xff0c;了解了深…

关于新手学习Ubuntu使用vim,如何使用c/cpp的编译器以及如何使用makefile的详细记录

ubuntu下 首先如何编辑 1.启动vim编辑器 打开终端&#xff0c;输入vim&#xff0c;按回车键。 vim gcc.c 2.进入编辑模式 输入i ,进入插入模式。就可以修改文件内容了。 按“ESC”退出编辑模式。 3.退出 Shift键 “:”&#xff0c;切换到命令模式。 输入“q”后回车&…

基于OpenCV的红绿灯识别

基于OpenCV的红绿灯识别 技术背景 为了实现轻舟航天机器人实现红绿灯的识别&#xff0c;决定采用传统算法OpenCV视觉技术。 技术介绍 航天机器人的红绿灯识别主要基于传统计算机视觉技术&#xff0c;利用OpenCV算法对视频流进行处理&#xff0c;以获取红绿灯的状态信息。具…

【Linux】Tcp服务器的三种与客户端通信方法及守护进程化

全是干货~ 文章目录 前言一、多进程版二、多线程版三、线程池版四、Tcp服务器日志的改进五、将Tcp服务器守护进程化总结 前言 在上一篇文章中&#xff0c;我们实现了Tcp服务器&#xff0c;但是为了演示多进程和多线程的效果&#xff0c;我们将服务器与客户通通信写成了一下死循…

【Linux】 由“进程”过渡到“线程” -- 什么是线程(thread)?

知识引入初识线程1.什么叫做进程&#xff1f;2.什么叫做线程&#xff1f;3.如何看待我们之前学习的进程&#xff1f; 理解线程创建线程函数调用1.线程一旦被创建&#xff0c;几乎所有资源都是被线程所共享的2.与进程之间切换相比&#xff0c;线程的切换 初识线程总结&#xff1…

JWT 的使用

一、简介 JWT将用户的一些信息存储在客户端&#xff0c;访问后台时会带着JWT&#xff0c;服务器要对这个JWT进行检验。 由于signKey是存放在服务器端的&#xff0c;所以比较安全只要JWT被篡改就会立刻发现。 JWT认证的优势 1.简洁&#xff1a;JWT Token数据量小&#xff0c;传…

WebRTC带宽评估 -- Transport-wide Congestion Control

简述&#xff1a;在RTP包中增加transport-wide-cc扩展头&#xff0c;放置传输层面的包序号。视频接收端记录RTP包的接收时间&#xff0c;并通过RTCP Feedback消息反馈到视频发送端&#xff0c;发送端结合缓存的RTP包发送时间&#xff0c;基于丢包和延迟估算当前带宽&#xff0c…

zabbix 企业级监控 (3)Zabbix-server监控mysql及httpd服务

目录 web界面设置 server.zabbix.com 服务器操作 编辑 chk_mysql.sh脚本 查看web效果 web界面设置 1. 2. 3. 4. 5. 6. 7. 8. server.zabbix.com 服务器操作 [rootserver ~]# cd /usr/local/zabbix/etc/ [rootserver etc]# vim zabbix_agentd.conf UnsafeUserParameters1 Us…

Java当中的栈

栈的理解 栈&#xff08;Stack&#xff09;是一种受限的线性数据结构&#xff0c;所谓受限是指栈只暴露栈顶和栈底的操作&#xff0c;其底层是由数组实现的。栈的特性是先进后出。 常用方法 注意上面的peek()方法和pop()方法的区别&#xff01; 实例 import java.util.Stack…

【计算机视觉 | 图像分割】arxiv 计算机视觉关于图像分割的学术速递(7 月 19 日论文合集)

文章目录 一、分割|语义相关(12篇)1.1 Disentangle then Parse:Night-time Semantic Segmentation with Illumination Disentanglement1.2 OnlineRefer: A Simple Online Baseline for Referring Video Object Segmentation1.3 MarS3D: A Plug-and-Play Motion-Aware Model for…

LeetCode74.Search-A-2d-Matrix<搜索二维矩阵>

题目&#xff1a; 思路&#xff1a; 矩阵&#xff0c;搜索数是否在矩阵内。那就查找他是否在每一行中。如果符合这一行的范围&#xff0c;那就一直找这一列是否存在&#xff0c;如果存在返回true&#xff1b;否则false&#xff1b; 代码是&#xff1a; //codeclass Solution …

Istio 安全管理 加密证书中心

1 tls认证 2 设置ACL 允许哪些客户端可以访问 哪些客户端不能访问 3 istio里面的认证 加密是可以分为三种类型 对称加密&#xff08;加密和解密用的是同一个密钥&#xff09;非对称加密哈希函数 对称加密 A要发送数据传送给B&#xff0c;那么A要使用一个密钥&#xff0c;里面…

MySQL-数据库读写分离(下)

♥️作者&#xff1a;小刘在C站 ♥️个人主页&#xff1a; 小刘主页 ♥️努力不一定有回报&#xff0c;但一定会有收获加油&#xff01;一起努力&#xff0c;共赴美好人生&#xff01; ♥️学习两年总结出的运维经验&#xff0c;以及思科模拟器全套网络实验教程。专栏&#xf…

Verilog 学习之路二——基础学习总结(摘取自菜鸟教程)

目录 1 Verilog 设计方法2. 基础语法2.1 格式2.2 数值表示数值种类表示方法 2.3 数据类型2.4 表达式 3. 编译指令4. 连续赋值5. 过程结构6 过程赋值7 时序控制8 语句块9 循环10 函数例子-数码管译码 1 Verilog 设计方法 Verilog 的设计多采用自上而下的设计方法&#xff08;to…

TypeScript + React 环境搭建

React 安装 vscode 或者 webstrom 代码编辑器TypeScript 开发环境搭建1.1、下载 node.js1.2、安装 node.js1.3、npm 安装 typeScript1.4、创建和编写 ts 文件1.5、编译1.6、运行 js文件 React 环境搭建2.1、homebrow2.2、安装 cnpm&#xff1a;2.3、安装yarn&#xff1a;2.4、安…

[oeasy]python0074[专业选修]字节序_byte_order_struct_pack_大端序_小端序

进制转化 回忆上次内容 上次 总结了 计算字符串值的函数 eval 四种进制的转化函数 binoctinthex 函数名前缀目标字符串所用进制bin0b二进制oct0o八进制hex0x十六进制eval无前缀十进制 数字41 和 字符串"41" 的不同 字符串"41" 两个字符字符存储依据是…

部署ELK+Kafka+Filebeat日志收集分析系统

部署ELKKafkaFilebeat日志收集分析系统 文章目录 部署ELKKafkaFilebeat日志收集分析系统一、ELK 简介1、ELK日志分析系统组成2、Elasticsearch&#xff08;es&#xff09;3、Logstash4、Kibana5、日志处理步骤 二、Elasticsearch介绍1、Elasticsearch核心概念2、开启分片副本的…

AcWing 244. 谜一样的牛—树状数组、二分

题目链接 AcWing 244. 谜一样的牛 题目描述 分析 这道题挺巧妙的&#xff0c;感觉树状数组方面的题就是比较难想&#xff0c;先分析一下样例&#xff0c;样例中每头牛前面比自己低的牛的数量分别为 0 1 2 1 0牛的高度是1~n的排列&#xff0c;如何分析出每头牛的高度呢&…

Linux学习之if判断的使用

if的基本用法 if后边可以直接跟着命令。 echo "good" > ifecho.txt把good输出到当前目录下ifecho.txt文件里边&#xff0c;cat ifecho.txt首先可以看一下这个文件里边的内容。 然后依次输入&#xff1a; if cat ifecho.txt thenecho "right" fi可以看…