Qt的.pro文件中宏的作用

Qt的.pro文件中宏的作用

今天在学习别人的Qt项目时,看到.pro Qt的项目文件中几个宏的定义不知道是什么意思,于是就想着记录下来以备后面复习。

1.greaterThan(QT_MAJOR_VERSION, 5): QT += core5compat:

1.1 作用

  • 版本判断与模块添加greaterThan(QT_MAJOR_VERSION, 5)用于判断当前使用的Qt版本主版本号是否大于5,如果是,则执行冒号后面的QT += core5compat语句,将core5compat模块添加到项目中。
  • 兼容性支持core5compat模块是为了在Qt 6中提供与Qt 5兼容的API。在Qt 6中,一些Qt 5中的类和功能被移除或更改,而core5compat模块包含了这些被移除的Qt Core API,使得在从Qt 5升级到Qt 6时,能够继续使用这些API,从而降低移植难度,方便项目的过渡。

1.2 具体应用场景

  • 使用被移除的类:例如在Qt 5中常用的QTextCodec类,在Qt 6中被移除,但通过添加core5compat模块,就可以继续使用QTextCodec类来进行文本编码转换等操作。
  • 保持代码一致性:当项目中存在大量基于Qt 5编写的代码,且这些代码依赖于Qt 5的特定API时,使用core5compat模块可以避免大规模修改代码,保持代码的一致性和稳定性,同时又能利用Qt 6的新特性和性能优化。

2.TARGET

2.1 指定生成的目标文件名

  • 可执行程序名:当项目类型为应用程序(如使用TEMPLATE = app)时,TARGET用于指定编译生成的可执行文件的名称。例如,如果设置TARGET = MyApplication,那么编译后生成的可执行文件在Windows系统下将是MyApplication.exe,在Linux或macOS系统下将是MyApplication
  • 库文件名:当项目类型为库(如使用TEMPLATE = lib)时,TARGET用于指定生成的库文件的名称。对于动态链接库(DLL或.so文件),设置的TARGET名称将用于生成库文件的基本名称,例如TARGET = MyLibrary,在Windows下可能生成MyLibrary.dll,在Linux下可能生成libMyLibrary.so;对于静态库(.a或.lib文件),同样根据TARGET的值来命名。

2.2 用于构建过程中的引用

  • 依赖关系处理:在多项目构建系统中,当一个项目依赖于另一个项目生成的库时,可以通过TARGET来指定依赖的库项目。例如,项目B依赖于项目A生成的库,可以在项目B的.pro文件中使用类似LIBS += -L$$OUT_PWD/../ProjectA -lProjectA的语句,其中ProjectA就是项目A的TARGET值,这样在构建项目B时,就能正确地链接到项目A生成的库文件。
  • 构建目录组织TARGET还可以与构建目录的组织结构相关联。例如,可以基于TARGET的值来创建专门的输出目录来存放生成的文件,通过设置如TARGET.path = $$OUT_PWD/bin/$$TARGET,将生成的可执行文件或库文件放置到特定的目录下,便于管理和部署。

3.TEMPLATE

3.1 指定项目类型

TEMPLATE宏通过不同的值来指定项目的类型,常见的几种类型及其作用如下:

  • app:表示该项目是一个应用程序。当设置TEMPLATE = app时,qmake会为项目生成一个可执行文件。这是最常见的项目类型,适用于开发各种桌面应用程序、命令行工具等。
  • lib:表示该项目是一个库项目。设置TEMPLATE = lib后,qmake会根据库的类型(静态库或动态库)生成相应的库文件。对于动态库,通常会生成.dll(Windows)或.so(Linux)文件;对于静态库,则会生成.lib(Windows)或.a(Linux)文件。库项目主要用于创建可被其他应用程序或库项目链接和使用的代码模块。
  • subdirs:表示该项目是一个包含多个子项目的项目。使用TEMPLATE = subdirs时,可以在.pro文件中通过SUBDIRS变量来列出子项目,qmake会对每个子项目分别进行构建。这种项目类型非常适合组织大型的多模块项目,便于分别管理各个子模块的构建过程。
  • vcappvclib:这两个值主要用于与Visual Studio的项目进行交互。vcapp用于生成Visual Studio的应用程序项目文件,而vclib用于生成库项目文件。不过,随着qmake和Qt Creator等工具的发展,现在更推荐直接使用applib类型,并通过Qt Creator等集成开发环境来管理Visual Studio项目。

3.2 影响构建过程

TEMPLATE宏的值不仅决定了项目的基本类型,还会影响qmake生成的构建文件的内容和构建过程中的具体行为。例如:

  • 对于app类型项目,qmake会配置构建系统以生成可执行文件,包括设置链接器选项、处理资源文件等,以确保应用程序能够正确编译和运行。
  • 对于lib类型项目,qmake会根据库的类型(通过CONFIG变量中的staticshared选项指定)来生成相应的库文件。如果是动态库,还会处理导出符号等与动态链接相关的设置;如果是静态库,则会将所有对象文件打包成一个静态库文件。
  • 对于subdirs类型项目,qmake会对每个子项目分别执行构建过程,根据子项目的TEMPLATE值来决定如何构建每个子项目。这种分层构建的方式使得大型项目的构建更加灵活和高效。

4.DESTDIR

在Qt的.pro文件中,DESTDIR宏用于指定生成的可执行文件(或库文件)的输出目录。以下是DESTDIR宏的具体作用和使用方法:

4.1 作用

  • 指定输出目录DESTDIR宏允许开发者控制Qt项目编译后生成的可执行文件或库文件的输出目录。默认情况下,DESTDIR的值为空,表示生成的文件将输出到当前项目目录。通过在.pro文件中设置DESTDIR宏,可以将生成的文件输出到指定的目录。

4.2 使用方法

  • 设置输出目录

    :在

    .pro
    

    文件中,可以通过以下方式设置

    DESTDIR
    

    的值:

    pro

    DESTDIR = /path/to/your/output/directory
    

    这里的

    /path/to/your/output/directory
    

    是你想要将可执行文件放置的目标路径。你可以根据需要修改这个路径。

4.3 示例

假设你有一个Qt应用程序项目,你希望将生成的可执行文件输出到项目的bin目录下,可以在.pro文件中添加以下行:

pro

DESTDIR = $$PWD/bin

这样,编译后的可执行文件将会被放置在项目的bin目录下。

4.4 注意事项

  • 确保目录存在:确保指定的目录存在或具有适当的写入权限,否则编译过程可能会失败。

  • TARGET宏的关系TARGET宏用于指定生成的可执行文件或库文件的名称,而DESTDIR则指定这些文件的输出目录。两者在Qt项目中通常一起使用,以便更好地管理和组织生成的文件。

  • 多配置支持

    :如果你需要根据不同的构建配置(如debug和release)设置不同的输出目录,可以使用条件判断。例如:

    pro

    CONFIG(debug, debug|release) {
        DESTDIR = $$PWD/bin/debug
    } else {
        DESTDIR = $$PWD/bin/release
    }
    

    这样,debug版本的文件将输出到

    bin/debug
    

    目录,release版本的文件将输出到

    bin/release
    

    目录。

4.5 总结

DESTDIR宏是Qt中一个非常有用的宏,它允许开发者灵活地控制生成文件的输出目录。通过正确设置DESTDIR的值,可以确保生成的文件被放置在期望的位置,从而简化项目的构建和部署过程。

5.CONFIG

5.1 作用

  • 编译和链接选项CONFIG宏用于指定编译器和链接器的行为,例如是否启用调试信息、是否生成静态库或动态库、是否启用优化等。
  • 运行时行为:某些配置选项还会影响应用程序的运行时行为,例如是否启用国际化支持、是否使用特定的Qt模块等。

5.2 常见配置选项

以下是一些常用的CONFIG配置选项及其作用:

  • debug

    :启用调试模式,编译器会生成调试信息,便于在调试器中进行调试。通常与

    release
    

    选项互斥。

    pro

    CONFIG += debug
    
  • release

    :启用发布模式,编译器会进行优化,生成的可执行文件或库文件体积更小、运行速度更快。通常与

    debug
    

    选项互斥。

    pro

    CONFIG += release
    
  • static

    :生成静态库。当项目类型为库(

    TEMPLATE = lib
    

    )时,此选项会生成静态库文件(如

    .lib
    

    .a
    

    )。

    pro

    CONFIG += static
    
  • shared

    :生成动态库。当项目类型为库(

    TEMPLATE = lib
    

    )时,此选项会生成动态库文件(如

    .dll
    

    .so
    

    )。

    pro

    CONFIG += shared
    
  • warnings

    :启用所有编译器警告。这有助于发现代码中的潜在问题。

    pro

    CONFIG += warnings
    
  • qt

    :启用Qt模块。通常不需要显式设置,因为通过

    QT +=
    

    指令已经隐式启用了所需的Qt模块。

    pro

    CONFIG += qt
    
  • console

    :在Windows平台上,此选项会生成控制台应用程序。如果应用程序需要在控制台中输出信息,应启用此选项。

    pro

    CONFIG += console
    
  • windows

    :仅在Windows平台上启用特定的配置选项。

    pro

    CONFIG += windows
    
  • unix

    :仅在Unix-like系统(如Linux和macOS)上启用特定的配置选项。

    pro

    CONFIG += unix
    
  • macx

    :仅在macOS平台上启用特定的配置选项。

    pro

    CONFIG += macx
    
  • win32

    :仅在32位Windows平台上启用特定的配置选项。

    pro

    CONFIG += win32
    
  • win64

    :仅在64位Windows平台上启用特定的配置选项。

    pro

    CONFIG += win64
    

5.3 示例

以下是一个示例,展示了如何在.pro文件中使用CONFIG宏来设置项目的配置选项:

pro

TEMPLATE = app
TARGET = MyApplication

QT = core gui

# 启用调试模式
CONFIG += debug

# 生成控制台应用程序(仅在Windows平台上)
CONFIG += console

# 启用所有编译器警告
CONFIG += warnings

# 仅在Windows平台上启用特定的配置选项
win32: CONFIG += win32-specific-option

# 仅在macOS平台上启用特定的配置选项
macx: CONFIG += macx-specific-option

# 仅在Unix-like系统上启用特定的配置选项
unix: CONFIG += unix-specific-option

SOURCES += main.cpp

5.4 注意事项

  • 互斥选项

    :某些配置选项是互斥的,例如

    debug
    

    release
    

    。通常,你可以通过条件判断来选择启用其中一个选项,例如:

    pro

    CONFIG(debug, debug|release) {
        # 调试模式下的配置
    } else {
        # 发布模式下的配置
    }
    
  • 平台特定选项:使用平台特定的配置选项时,确保这些选项仅在相应的平台上生效,避免在不支持的平台上启用这些选项。

5.5 总结

CONFIG宏在Qt项目中扮演着关键角色,通过合理设置CONFIG宏,可以灵活地控制项目的编译、链接和运行时行为,满足不同开发和部署需求。

6.SOURCES

SOURCES宏用于指定项目中需要编译的源文件。

6.1 作用

  • 指定源文件SOURCES宏列出项目中所有需要编译的源文件。这些文件将被编译器编译成对象文件(.o或.obj),然后链接成最终的可执行文件或库文件。
  • 控制编译过程:通过在.pro文件中列出源文件,可以精确控制哪些文件参与编译,哪些文件不参与编译。这有助于管理大型项目中的文件,确保只有必要的文件被编译,从而提高编译效率。

6.2 使用方法

  • 列出源文件

    :在

    .pro
    

    文件中,可以通过以下方式列出源文件:

    pro

    SOURCES += main.cpp \
               mainwindow.cpp \
               calculator.cpp
    

    这里的

    main.cpp
    

    mainwindow.cpp
    

    calculator.cpp
    

    是项目中需要编译的源文件。每个文件名之间用空格或反斜杠(用于换行)分隔。

6.3 示例

假设你有一个简单的Qt应用程序项目,项目结构如下:

MyApplication/
├── main.cpp
├── mainwindow.cpp
├── mainwindow.h
└── calculator.cpp

你可以在.pro文件中这样设置SOURCES宏:

pro

TEMPLATE = app
TARGET = MyApplication

QT = core gui

SOURCES += main.cpp \
           mainwindow.cpp \
           calculator.cpp

HEADERS += mainwindow.h

在这个示例中,SOURCES宏列出了main.cppmainwindow.cppcalculator.cpp这三个源文件,这些文件将被编译器编译。HEADERS宏则列出了mainwindow.h这个头文件,虽然头文件本身不直接编译,但列出头文件有助于qmake生成正确的依赖关系,确保在头文件修改后,相关源文件能够被重新编译。

6.4 注意事项

  • 相对路径

    SOURCES
    

    宏中的文件路径是相对于

    .pro
    

    文件所在的目录的相对路径。如果源文件位于子目录中,需要指定相对路径,例如:

    pro

    SOURCES += src/main.cpp \
               src/mainwindow.cpp \
               src/calculator.cpp
    
  • 文件存在性:确保列出的源文件确实存在于项目目录中,否则编译过程可能会失败,因为编译器找不到指定的文件。

  • 头文件依赖:虽然头文件不直接编译,但列出头文件(通过HEADERS宏)有助于qmake正确处理文件依赖关系,确保在头文件修改后,相关源文件能够被重新编译。

6.5 总结

SOURCES宏是Qt项目中非常重要的一个宏,通过合理使用SOURCES宏,可以精确控制项目的编译过程,确保只有必要的文件被编译,从而提高编译效率和项目的可管理性。

7.HRADERS

7.1 作用

  • 指定头文件HEADERS宏列出项目中所有需要处理的头文件。这些头文件通常包含类定义、函数声明、宏定义等,是源文件(.cpp)中包含的文件。
  • 处理文件依赖:qmake使用HEADERS宏中的信息来生成正确的文件依赖关系。当头文件被修改时,qmake能够确保所有依赖该头文件的源文件都被重新编译。这有助于确保项目的构建过程是正确的,避免因头文件修改而未重新编译相关源文件导致的潜在问题。

7.2 使用方法

  • 列出头文件

    :在

    .pro
    

    文件中,可以通过以下方式列出头文件:

    pro

    HEADERS += mainwindow.h \
               calculator.h
    

    这里的

    mainwindow.h
    

    calculator.h
    

    是项目中需要处理的头文件。每个文件名之间用空格或反斜杠(用于换行)分隔。

7.3 示例

假设你有一个简单的Qt应用程序项目,项目结构如下:

MyApplication/
├── main.cpp
├── mainwindow.cpp
├── mainwindow.h
└── calculator.cpp
    └── calculator.h

你可以在.pro文件中这样设置HEADERS宏:

pro

TEMPLATE = app
TARGET = MyApplication

QT = core gui

SOURCES += main.cpp \
           mainwindow.cpp \
           calculator.cpp

HEADERS += mainwindow.h \
           calculator.h

在这个示例中,HEADERS宏列出了mainwindow.hcalculator.h这两个头文件,这些文件将被qmake处理,以确保在头文件修改后,相关源文件能够被重新编译。

7.4 注意事项

  • 相对路径

    HEADERS
    

    宏中的文件路径是相对于

    .pro
    

    文件所在的目录的相对路径。如果头文件位于子目录中,需要指定相对路径,例如:

    pro

    HEADERS += src/mainwindow.h \
               src/calculator.h
    
  • 文件存在性:确保列出的头文件确实存在于项目目录中,否则qmake可能会生成错误的依赖关系,导致编译过程失败。

  • SOURCES宏的关系:虽然头文件不直接编译,但列出头文件(通过HEADERS宏)有助于qmake正确处理文件依赖关系,确保在头文件修改后,相关源文件能够被重新编译。因此,HEADERS宏和SOURCES宏通常一起使用,以确保项目的构建过程是正确的。

7.5 总结

HEADERS宏在Qt项目中扮演着重要角色,通过合理使用HEADERS宏,可以确保项目的构建过程是正确的,避免因头文件修改而未重新编译相关源文件导致的潜在问题。这有助于提高项目的稳定性和可维护性。

8.FORMS

在Qt的.pro文件中,FORMS宏用于指定项目中需要处理的.ui文件。这些.ui文件是使用Qt Designer创建的用户界面设计文件,通过FORMS宏,qmake会自动调用uic(User Interface Compiler)工具将这些.ui文件转换成C++代码,以便在项目中使用。以下是FORMS宏的具体作用和使用方法:

8.1 作用

  • 指定UI文件FORMS宏列出项目中所有需要处理的.ui文件。这些文件通常包含用户界面的设计信息,如窗口、按钮、文本框等。
  • 生成C++代码:qmake使用FORMS宏中的信息,调用uic工具将.ui文件转换成C++代码。生成的C++代码通常以ui_为前缀,例如ui_mainwindow.h
  • 简化构建过程:通过在.pro文件中列出.ui文件,可以确保这些文件在构建过程中被正确处理,生成的C++代码被包含在项目中,从而简化项目的构建过程。

8.2 使用方法

  • 列出UI文件

    :在

    .pro
    

    文件中,可以通过以下方式列出UI文件:

    pro

    FORMS += mainwindow.ui \
             settingsdialog.ui
    

    这里的

    mainwindow.ui
    

    settingsdialog.ui
    

    是项目中需要处理的UI文件。每个文件名之间用空格或反斜杠(用于换行)分隔。

8.3 示例

假设你有一个简单的Qt应用程序项目,项目结构如下:

MyApplication/
├── main.cpp
├── mainwindow.cpp
├── mainwindow.h
├── mainwindow.ui
└── settingsdialog.ui

你可以在.pro文件中这样设置FORMS宏:

pro

TEMPLATE = app
TARGET = MyApplication

QT = core gui

SOURCES += main.cpp \
           mainwindow.cpp

HEADERS += mainwindow.h

FORMS += mainwindow.ui \
         settingsdialog.ui

在这个示例中,FORMS宏列出了mainwindow.uisettingsdialog.ui这两个UI文件,这些文件将被uic工具转换成C++代码,生成的文件通常会包含在项目的构建目录中,例如ui_mainwindow.hui_settingsdialog.h

8.4 注意事项

  • 相对路径

    FORMS
    

    宏中的文件路径是相对于

    .pro
    

    文件所在的目录的相对路径。如果UI文件位于子目录中,需要指定相对路径,例如:

    pro

    FORMS += ui/mainwindow.ui \
             ui/settingsdialog.ui
    
  • 文件存在性:确保列出的UI文件确实存在于项目目录中,否则qmake可能会生成错误的依赖关系,导致构建过程失败。

  • 生成的C++代码:生成的C++代码文件(如ui_mainwindow.h)通常不需要手动修改,因为它们是由uic工具自动生成的。如果需要修改UI设计,应直接在.ui文件中进行修改,然后重新构建项目。

8.5 总结

FORMS宏在Qt项目中扮演着重要角色,通过合理使用FORMS宏,可以确保项目的UI文件在构建过程中被正确处理,生成的C++代码被包含在项目中,从而简化项目的构建过程,提高开发效率。

9.RESOURCES

在Qt的.pro文件中,RESOURCES宏用于指定项目中需要处理的资源文件(.qrc)。这些资源文件通常包含项目中使用的各种资源,如图标、图片、翻译文件、样式表等。通过RESOURCES宏,qmake会自动调用rcc(Resource Compiler)工具将这些资源文件编译成C++代码,以便在项目中使用。以下是RESOURCES宏的具体作用和使用方法:

9.1 作用

  • 指定资源文件RESOURCES宏列出项目中所有需要处理的资源文件(.qrc)。这些文件通常包含项目中使用的各种资源,如图标、图片、翻译文件、样式表等。
  • 生成C++代码:qmake使用RESOURCES宏中的信息,调用rcc工具将.qrc文件编译成C++代码。生成的C++代码通常以qrc_为前缀,例如qrc_resources.cpp
  • 简化资源管理:通过在.pro文件中列出资源文件,可以确保这些文件在构建过程中被正确处理,生成的C++代码被包含在项目中,从而简化项目的资源管理过程。

9.2 使用方法

  • 列出资源文件

    :在

    .pro
    

    文件中,可以通过以下方式列出资源文件:

    pro

    RESOURCES += resources.qrc
    

    这里的

    resources.qrc
    

    是项目中需要处理的资源文件。可以列出多个资源文件,每个文件名之间用空格或反斜杠(用于换行)分隔。

9.3 示例

假设你有一个简单的Qt应用程序项目,项目结构如下:

MyApplication/
├── main.cpp
├── mainwindow.cpp
├── mainwindow.h
├── resources.qrc
├── icons/
│   ├── icon1.png
│   └── icon2.png
└── styles/
    └── stylesheet.qss

resources.qrc文件的内容可能如下:

xml

<RCC>
    <qresource prefix="/icons">
        <file>icons/icon1.png</file>
        <file>icons/icon2.png</file>
    </qresource>
    <qresource prefix="/styles">
        <file>styles/stylesheet.qss</file>
    </qresource>
</RCC>

你可以在.pro文件中这样设置RESOURCES宏:

pro

TEMPLATE = app
TARGET = MyApplication

QT = core gui

SOURCES += main.cpp \
           mainwindow.cpp

HEADERS += mainwindow.h

RESOURCES += resources.qrc

在这个示例中,RESOURCES宏列出了resources.qrc这个资源文件,rcc工具将resources.qrc文件编译成C++代码,生成的文件通常会包含在项目的构建目录中,例如qrc_resources.cpp

9.4 注意事项

  • 相对路径

    RESOURCES
    

    宏中的文件路径是相对于

    .pro
    

    文件所在的目录的相对路径。如果资源文件位于子目录中,需要指定相对路径,例如:

    pro

    RESOURCES += resources/resources.qrc
    
  • 文件存在性:确保列出的资源文件确实存在于项目目录中,否则qmake可能会生成错误的依赖关系,导致构建过程失败。

  • 生成的C++代码:生成的C++代码文件(如qrc_resources.cpp)通常不需要手动修改,因为它们是由rcc工具自动生成的。如果需要修改资源,应直接在.qrc文件中进行修改,然后重新构建项目。

  • 资源前缀:在.qrc文件中,可以为资源指定前缀(如/icons/styles),这有助于在项目中更方便地访问资源。例如,可以使用":/icons/icon1.png"来访问icons/icon1.png资源。

9.5 总结

RESOURCES宏在Qt项目中扮演着重要角色,通过合理使用RESOURCES宏,可以确保项目的资源文件在构建过程中被正确处理,生成的C++代码被包含在项目中,从而简化项目的资源管理过程,提高开发效率。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Redis | 第6章 事件与客户端《Redis设计与实现》

前言 参考资料&#xff1a;《Redis设计与实现 第二版》&#xff1b; 第二部分为单机数据库的实现&#xff0c;主要由以下模块组成&#xff1a;数据库、持久化、事件、客户端与服务器&#xff1b; 本篇将介绍 Redis 中的事件与客户端&#xff0c;其中事件有两种&#xff1a;文件…

SpringBoot源码解析(七):应用上下文结构体系

SpringBoot源码系列文章 SpringBoot源码解析(一)&#xff1a;SpringApplication构造方法 SpringBoot源码解析(二)&#xff1a;引导上下文DefaultBootstrapContext SpringBoot源码解析(三)&#xff1a;启动开始阶段 SpringBoot源码解析(四)&#xff1a;解析应用参数args Sp…

【Flink系列】4. Flink运行时架构

4. Flink运行时架构 4.1 系统架构 Flink运行时架构——Standalone会话模式为例 1&#xff09;作业管理器&#xff08;JobManager&#xff09; JobManager是一个Flink集群中任务管理和调度的核心&#xff0c;是控制应用执行的主进程。也就是说&#xff0c;每个应用都应该被…

thinkphp6 + redis实现大数据导出excel超时或内存溢出问题解决方案

redis下载安装&#xff08;window版本&#xff09; 参考地址&#xff1a;https://blog.csdn.net/Ci1693840306/article/details/144214215 php安装redis扩展 参考链接&#xff1a;https://blog.csdn.net/jianchenn/article/details/106144313 解决思路&#xff1a;&#xff0…

HTML中最基本的东西

本文内容的标签&#xff0c;将是看懂HTML的最基本之基本 &#xff0c;是跟您在写文章时候一样内容。一般想掌握极其容易&#xff0c;但是也要懂得如何使用&#xff0c;过目不忘&#xff0c;为手熟尔。才是我们学习的最终目的。其实边看边敲都行&#xff0c;或者是边看边复制粘贴…

【大前端】Vue3 工程化项目使用详解

目录 一、前言 二、前置准备 2.1 环境准备 2.1.1 create-vue功能 2.1.2 nodejs环境 2.1.3 配置nodejs的环境变量 2.1.4 更换安装包的源 三、工程化项目创建与启动过程 3.1 创建工程化项目 3.2 项目初始化 3.3 项目启动 3.4 核心文件说明 四、VUE两种不同的API风格 …

-bash: /java: cannot execute binary file

在linux安装jdk报错 -bash: /java: cannot execute binary file 原因是jdk安装包和linux的不一致 程序员的面试宝典&#xff0c;一个免费的刷题平台

业务幂等性技术架构体系之消息幂等深入剖析

在系统中当使用消息队列时&#xff0c;无论做哪种技术选型&#xff0c;有很多问题是无论如何也不能忽视的&#xff0c;如&#xff1a;消息必达、消息幂等等。本文以典型的RabbitMQ为例&#xff0c;讲解如何保证消息幂等的可实施解决方案&#xff0c;其他MQ选型均可参考。 一、…

RustDesk ID更新脚本

RustDesk ID更新脚本 此PowerShell脚本自动更新RustDesk ID和密码&#xff0c;并将信息安全地存储在Bitwarden中。 特点 使用以下选项更新RustDesk ID&#xff1a; 使用系统主机名生成一个随机的9位数输入自定义值 为RustDesk生成新的随机密码将RustDesk ID和密码安全地存储…

QT开发技术 【基于TinyXml2的对类进行序列化和反序列化】一

一、对TinyXml2 进行封装 使用宏 实现序列化和反序列化 思路&#xff1a; 利用宏增加一个类函数&#xff0c;使用序列化器调用函数进行序列化 封装宏示例 #define XML_SERIALIZER_BEGIN(ClassName) \ public: \virtual void ToXml(XMLElement* parentElem, bool bSerialize …

金仓Kingbase客户端KStudio报OOM:Java heap space socketTimeout

找到Kingbase\ES\V8\KESRealPro\V008R006C006B0021\ClientTools\guitools\KStudio\KStudio.ini 修改JVM参数&#xff1a; 默认值&#xff1a; -Xms512m -Xmx1024m 改为&#xff1a; -Xms1024m -Xmx2048m -XX:MaxPermSize512m SQL查询报错&#xff1a;An I/O error occurred …

Redis--21--大Key问题解决方案

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言Redis--20--大Key问题解析 一、如何发现Redis大Key1. 使用Redis命令行工具**MEMORY USAGE****RANDOMKEY****DEBUG OBJECT****SCAN命令****redis-cli 工具&#…

【进程与线程】进程的状态

在操作系统中&#xff0c;进程是执行中的程序实例。进程在其生命周期中会经历不同的状态&#xff0c;操作系统根据进程的执行情况和资源调度&#xff0c;将进程划分为多个状态。 这些状态帮助操作系统更加高效地管理 CPU 和系统资源。 进程的状态&#xff1a;就绪态&#xff0…

K8S开启/关闭审计日志

K8S默认禁用审计 开启/关闭 k8s 审计日志 默认 Kubernetes 集群不会输出审计日志信息。通过以下配置&#xff0c;可以开启 Kubernetes 的审计日志功能。 准备审计日志的 Policy 文件配置 API 服务器&#xff0c;开启审计日志重启并验证 准备审计日志 Policy 文件 apiVersio…

nginx: [emerg] bind() to 0.0.0.0:80 failed 端口被占用

nginx: [emerg] bind() to 0.0.0.0:80 failed (10013: An attempt was made to access a socket in a way forbidden by its access permissions) 查看被占用的端口 被系统占用了 HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/HTTP 然后再进入nginx文件夹目录下…

vue2 web 多标签输入框 elinput是否当前焦点

又来分享一点点工作积累及解决方案 产品中需要用户输入一些文字后按下回车键生成标签来显示在页面上&#xff0c;经过尝试与改造完成如下&#xff1a; <template><div class"tags-view" click"beginInput"><el-tag :key"index" …

vLLM私有化部署大语言模型LLM

目录 一、vLLM介绍 二、安装vLLM 1、安装环境 2、安装步骤 三、运行vLLM 1、运行方式 2、切换模型下载源 3、运行本地已下载模型 四、通过http访问vLLM 一、vLLM介绍 vLLM&#xff08;官方网址&#xff1a;https://www.vllm.ai&#xff09;是一种用于大规模语言模型&#x…

STM32的集成开发环境STM32CubeIDE安装

STM32CubeIDE - STM32的集成开发环境 - 意法半导体STMicroelectronics

硬件学习笔记--31 IEC62053-21相关内容介绍

IEC 62053-21是一项由国际电工委员会&#xff08;International Electrotechnical Commission&#xff0c;简称IEC&#xff09;发布的国际标准&#xff0c;全称为《交流电能测量设备&#xff08;a.c.&#xff09;-特殊要求-第21部分&#xff1a;静止式有功能量计量表&#xff0…

C++类与对象(一)—学习记录

序言&#xff1a;要想开发一款成功的应用程序&#xff0c;其开发者必须充分了解并实现用户的需求。作为一个设计良好的类&#xff0c;既要有直观且易于使用的接口&#xff0c;也必须具备高效的实现过程。 一、类与对象基本概念 面向对象程序设计的主要特点为抽象、封装、继承与…