【CPP】CPP经典面试题

文章目录

    • 引言
    • 1. C++ 基础
      • 1.1 C++ 中的 `const` 关键字
      • 1.2 C++ 中的 `static` 关键字
    • 2. 内存管理
      • 2.1 C++ 中的 `new` 和 `delete`
      • 2.2 内存泄漏
    • 3. 面向对象编程
      • 3.1 继承和多态
      • 3.2 多重继承
    • 4. 模板和泛型编程
      • 4.1 函数模板
      • 4.2 类模板
    • 5. STL 和标准库
      • 5.1 容器
      • 5.2 迭代器
    • 6. 高级特性
      • 6.1 移动语义和右值引用
      • 6.2 Lambda 表达式
    • 7. 设计模式
      • 7.1 单例模式
      • 7.2 工厂模式
    • 8. 性能优化
      • 8.1 内联函数
      • 8.2 缓存友好性
    • 9. 并发编程
      • 9.1 线程
      • 9.2 条件变量
    • 10. 异常处理
      • 10.1 异常机制
    • 11. C++17 和 C++20 新特性
      • 11.1 C++17 新特性
      • 11.2 C++20 新特性
    • 12. 实际应用
      • 12.1 智能指针
      • 12.2 RAII 原则
    • 13. 调试和测试
      • 13.1 调试技巧
      • 13.2 单元测试
      • 13.3 性能分析
    • 14. C++ 编码规范
      • 14.1 命名规范
      • 14.2 代码格式化
    • 15. C++ 项目构建
      • 15.1 Makefile
      • 15.2 CMake
    • 16. C++ 未来发展趋势
      • 16.1 C++23 新特性
      • 16.2 C++ 的未来
    • 结语

在这里插入图片描述

引言

C++ 是一门强大且复杂的编程语言,广泛应用于系统编程、游戏开发、嵌入式系统和高性能计算等领域。由于其灵活性和性能优势,C++ 程序员在面试中常常会遇到各种深入的问题。本文将探讨一些经典的 C++ 面试题,涵盖从基础语法到高级特性的多个方面,帮助读者更好地准备面试。

1. C++ 基础

1.1 C++ 中的 const 关键字

const 是 C++ 中用于定义常量的关键字。它可以用于修饰变量、函数参数、函数返回值以及成员函数。

问题: const#define 有什么区别?

答案:

  • const 是类型安全的,编译器会进行类型检查,而 #define 是宏定义,只是简单的文本替换。
  • const 定义的常量在编译时分配内存,而 #define 不分配内存。
  • const 可以用于修饰类的成员函数,表示该函数不会修改类的成员变量。

问题: const 成员函数的作用是什么?

答案:
const 成员函数表示该函数不会修改类的成员变量。它可以被 const 对象调用,而非 const 对象既可以调用 const 成员函数,也可以调用非 const 成员函数。

1.2 C++ 中的 static 关键字

static 关键字在 C++ 中有多种用途,包括修饰局部变量、全局变量、类成员变量和类成员函数。

问题: static 局部变量和普通局部变量有什么区别?

答案:

  • static 局部变量的生命周期贯穿整个程序运行期间,即使函数调用结束,static 局部变量也不会被销毁。
  • 普通局部变量的生命周期仅限于函数调用期间,函数调用结束后,局部变量会被销毁。

问题: static 成员函数和普通成员函数有什么区别?

答案:

  • static 成员函数不依赖于类的实例,可以直接通过类名调用。
  • static 成员函数不能访问类的非静态成员变量和非静态成员函数,因为它们没有 this 指针。

2. 内存管理

2.1 C++ 中的 newdelete

newdelete 是 C++ 中用于动态内存分配和释放的操作符。

问题: newmalloc 有什么区别?

答案:

  • new 是 C++ 的操作符,而 malloc 是 C 标准库函数。
  • new 会自动调用对象的构造函数,malloc 不会。
  • new 返回的是对象类型的指针,malloc 返回的是 void*,需要显式类型转换。
  • new 分配内存失败时会抛出 std::bad_alloc 异常,malloc 失败时返回 NULL

问题: deletefree 有什么区别?

答案:

  • delete 是 C++ 的操作符,而 free 是 C 标准库函数。
  • delete 会自动调用对象的析构函数,free 不会。
  • delete 用于释放 new 分配的内存,free 用于释放 malloc 分配的内存。

2.2 内存泄漏

内存泄漏是指程序在动态分配内存后,未能正确释放该内存,导致内存占用不断增加。

问题: 如何避免内存泄漏?

答案:

  • 使用智能指针(如 std::unique_ptrstd::shared_ptr)来管理动态内存。
  • 确保每次 new 操作都有对应的 delete 操作。
  • 使用 RAII(Resource Acquisition Is Initialization)原则,将资源的生命周期与对象的生命周期绑定。

3. 面向对象编程

3.1 继承和多态

继承和多态是面向对象编程中的核心概念。

问题: 什么是虚函数?为什么需要虚函数?

答案:
虚函数是用于实现多态的机制。通过在基类中声明虚函数,派生类可以重写该函数,从而实现运行时多态。当通过基类指针或引用调用虚函数时,实际调用的是派生类的重写函数。

问题: 虚函数表(vtable)是什么?

答案:
虚函数表是编译器为每个包含虚函数的类生成的一个表,表中存储了虚函数的地址。每个对象在内存中都有一个指向虚函数表的指针(vptr),通过这个指针可以在运行时确定调用哪个虚函数。

3.2 多重继承

多重继承是指一个类可以从多个基类继承。

问题: 多重继承会带来什么问题?如何解决?

答案:
多重继承可能导致菱形继承问题(Diamond Problem),即一个类从两个基类继承,而这两个基类又共同继承自同一个基类,导致派生类中包含多个相同的基类子对象。可以通过虚继承(virtual inheritance)来解决这个问题。

4. 模板和泛型编程

4.1 函数模板

函数模板允许编写通用的函数,可以处理不同类型的参数。

问题: 函数模板和函数重载有什么区别?

答案:

  • 函数模板通过参数类型推导生成具体的函数实例,适用于不同类型的数据。
  • 函数重载是通过定义多个同名函数,每个函数处理不同类型的参数。

问题: 如何特化一个函数模板?

答案:
可以通过显式特化或部分特化来为特定类型提供特殊的实现。显式特化是为特定类型提供完全不同的实现,而部分特化是为特定类型的一部分提供不同的实现。

4.2 类模板

类模板允许编写通用的类,可以处理不同类型的数据。

问题: 类模板和模板类的区别是什么?

答案:

  • 类模板是模板的定义,尚未实例化。
  • 模板类是类模板实例化后的具体类。

问题: 如何特化一个类模板?

答案:
可以通过显式特化或部分特化来为特定类型提供特殊的实现。显式特化是为特定类型提供完全不同的实现,而部分特化是为特定类型的一部分提供不同的实现。

5. STL 和标准库

5.1 容器

STL 提供了多种容器,如 vectorlistmap 等。

问题: vectorlist 有什么区别?

答案:

  • vector 是动态数组,支持随机访问,插入和删除操作在尾部高效,但在中间或头部效率较低。
  • list 是双向链表,不支持随机访问,插入和删除操作在任何位置都高效。

问题: mapunordered_map 有什么区别?

答案:

  • map 是基于红黑树实现的,元素按键值有序存储,查找、插入和删除操作的时间复杂度为 O(log n)。
  • unordered_map 是基于哈希表实现的,元素无序存储,查找、插入和删除操作的平均时间复杂度为 O(1)。

5.2 迭代器

迭代器是用于遍历容器中元素的对象。

问题: 迭代器的种类有哪些?

答案:

  • 输入迭代器:只能读取元素,单向移动。
  • 输出迭代器:只能写入元素,单向移动。
  • 前向迭代器:可以读取和写入元素,单向移动。
  • 双向迭代器:可以读取和写入元素,双向移动。
  • 随机访问迭代器:可以读取和写入元素,支持随机访问。

6. 高级特性

6.1 移动语义和右值引用

移动语义和右值引用是 C++11 引入的重要特性,用于提高性能。

问题: 什么是右值引用?为什么需要右值引用?

答案:
右值引用是用于绑定临时对象(右值)的引用类型,通过 && 表示。右值引用允许将资源(如动态内存)从一个对象“移动”到另一个对象,避免不必要的拷贝操作,从而提高性能。

问题: 什么是移动构造函数和移动赋值运算符?

答案:
移动构造函数和移动赋值运算符是用于实现移动语义的特殊成员函数。移动构造函数接受一个右值引用参数,将资源从源对象移动到目标对象。移动赋值运算符也接受一个右值引用参数,将资源从源对象移动到目标对象,并释放目标对象原有的资源。

6.2 Lambda 表达式

Lambda 表达式是 C++11 引入的匿名函数,可以方便地定义和使用函数对象。

问题: Lambda 表达式的语法是什么?

答案:
Lambda 表达式的语法为:

[捕获列表](参数列表) -> 返回类型 { 函数体 }

捕获列表用于指定 Lambda 表达式可以访问的外部变量,参数列表和返回类型与普通函数类似。

问题: Lambda 表达式的捕获列表有哪些方式?

答案:

  • [&]:以引用方式捕获所有外部变量。
  • [=]:以值方式捕获所有外部变量。
  • [&x, =y]:以引用方式捕获 x,以值方式捕获 y
  • [this]:捕获当前对象的 this 指针。

7. 设计模式

7.1 单例模式

单例模式是一种创建型设计模式,确保一个类只有一个实例,并提供全局访问点。

问题: 如何实现线程安全的单例模式?

答案:
可以通过双重检查锁定(Double-Checked Locking)或使用局部静态变量来实现线程安全的单例模式。

class Singleton {
public:static Singleton& getInstance() {static Singleton instance;return instance;}private:Singleton() {}Singleton(const Singleton&) = delete;Singleton& operator=(const Singleton&) = delete;
};

7.2 工厂模式

工厂模式是一种创建型设计模式,用于创建对象而不指定具体的类。

问题: 工厂模式和抽象工厂模式有什么区别?

答案:

  • 工厂模式定义一个创建对象的接口,但由子类决定实例化哪个类。
  • 抽象工厂模式提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。

8. 性能优化

8.1 内联函数

内联函数是一种优化技术,通过在调用点展开函数体来减少函数调用的开销。

问题: 内联函数有什么优缺点?

答案:

  • 优点:减少函数调用的开销,提高执行效率。
  • 缺点:增加代码体积,可能导致缓存不命中,影响性能。

问题: 如何定义内联函数?

答案:
可以通过 inline 关键字定义内联函数,或者在类定义中直接定义成员函数。

inline int add(int a, int b) {return a + b;
}

8.2 缓存友好性

缓存友好性是指程序在访问内存时能够充分利用 CPU 缓存,减少缓存未命中的次数。

问题: 如何编写缓存友好的代码?

答案:

  • 尽量使用连续内存访问模式,如数组遍历。
  • 避免频繁的内存分配和释放,减少内存碎片。
  • 使用适当的数据结构和算法,减少不必要的内存访问。

9. 并发编程

9.1 线程

C++11 引入了多线程支持,提供了 std::thread 类。

问题: 如何创建和启动一个线程?

答案:
可以通过 std::thread 类创建和启动一个线程,线程函数可以是普通函数、Lambda 表达式或成员函数。

#include <iostream>
#include <thread>void threadFunc() {std::cout << "Hello from thread!" << std::endl;
}int main() {std::thread t(threadFunc);t.join();return 0;
}

问题: 如何避免数据竞争?

答案:
可以通过互斥锁(std::mutex)、原子操作(std::atomic)或其他同步机制来避免数据竞争。

9.2 条件变量

条件变量是用于线程间同步的机制,允许线程等待某个条件成立。

问题: 如何使用条件变量?

答案:
可以通过 std::condition_variablestd::mutex 来实现线程间的条件等待和通知。

#include <iostream>
#include <thread>
#include <mutex>
#include <condition_variable>std::mutex mtx;
std::condition_variable cv;
bool ready = false;void waitForReady() {std::unique_lock<std::mutex> lock(mtx);cv.wait(lock, []{ return ready; });std::cout << "Ready!" << std::endl;
}void setReady() {std::this_thread::sleep_for(std::chrono::seconds(1));{std::lock_guard<std::mutex> lock(mtx);ready = true;}cv.notify_all();
}int main() {std::thread t1(waitForReady);std::thread t2(setReady);t1.join();t2.join();return 0;
}

10. 异常处理

10.1 异常机制

C++ 提供了异常处理机制,允许程序在运行时处理错误。

问题: trycatchthrow 的作用是什么?

答案:

  • try 块用于包含可能抛出异常的代码。
  • catch 块用于捕获并处理异常。
  • throw 用于抛出异常。

问题: 如何自定义异常类?

答案:
可以通过继承 std::exception 类来定义自定义异常类,并重写 what() 方法以提供异常描述。

#include <exception>
#include <string>class MyException : public std::exception {
public:MyException(const std::string& msg) : msg(msg) {}const char* what() const noexcept override {return msg.c_str();}private:std::string msg;
};

11. C++17 和 C++20 新特性

11.1 C++17 新特性

C++17 引入了许多新特性,如结构化绑定、std::optionalstd::variant 等。

问题: 什么是结构化绑定?

答案:
结构化绑定允许将结构体或数组的元素绑定到变量上,简化代码。

#include <iostream>
#include <tuple>int main() {std::tuple<int, double, std::string> t(1, 2.0, "hello");auto [a, b, c] = t;std::cout << a << ", " << b << ", " << c << std::endl;return 0;
}

11.2 C++20 新特性

C++20 引入了更多新特性,如概念(Concepts)、范围(Ranges)、协程(Coroutines)等。

问题: 什么是概念(Concepts)?

答案:
概念是用于约束模板参数的机制,可以在编译时检查模板参数是否满足特定要求。

#include <concepts>
#include <iostream>template<typename T>
requires std::integral<T>
void print(T value) {std::cout << value << std::endl;
}int main() {print(42);  // OK// print(3.14);  // Error: does not satisfy std::integralreturn 0;
}

12. 实际应用

12.1 智能指针

智能指针是 C++11 引入的用于自动管理动态内存的工具。

问题: std::unique_ptrstd::shared_ptr 有什么区别?

答案:

  • std::unique_ptr 是独占所有权的智能指针,不能复制,只能移动。
  • std::shared_ptr 是共享所有权的智能指针,通过引用计数管理资源,可以复制和移动。

问题: 如何使用 std::make_shared

答案:
std::make_shared 是用于创建 std::shared_ptr 的工厂函数,可以一次性分配内存并创建对象。

#include <memory>
#include <iostream>int main() {auto ptr = std::make_shared<int>(42);std::cout << *ptr << std::endl;return 0;
}

12.2 RAII 原则

RAII(Resource Acquisition Is Initialization)是 C++ 中的重要原则,用于管理资源。

问题: 什么是 RAII 原则?

答案:
RAII 原则是指将资源的生命周期与对象的生命周期绑定,通过对象的构造函数获取资源,通过析构函数释放资源,确保资源在对象销毁时自动释放。

问题: 如何实现 RAII?

答案:
可以通过类的构造函数和析构函数来实现 RAII。例如,使用智能指针管理动态内存,使用 std::fstream 管理文件资源等。

#include <fstream>
#include <iostream>class FileHandler {
public:FileHandler(const std::string& filename) : file(filename) {if (!file.is_open()) {throw std::runtime_error("Failed to open file");}}~FileHandler() {file.close();}void write(const std::string& data) {file << data;}private:std::ofstream file;
};int main() {try {FileHandler fh("test.txt");fh.write("Hello, RAII!");} catch (const std::exception& e) {std::cerr << e.what() << std::endl;}return 0;
}

13. 调试和测试

13.1 调试技巧

调试是程序开发中的重要环节,掌握调试技巧可以提高开发效率。

问题: 如何使用 GDB 调试 C++ 程序?

答案:

  • 编译时添加 -g 选项生成调试信息。
  • 使用 gdb 启动程序,设置断点,单步执行,查看变量值等。
g++ -g -o my_program my_program.cpp
gdb ./my_program

问题: 如何使用 assert 进行调试?

答案:
assert 是用于检查条件的宏,如果条件为假,程序会终止并输出错误信息。

#include <cassert>
#include <iostream>int main() {int x = 5;assert(x == 5);std::cout << "Assertion passed" << std::endl;return 0;
}

13.2 单元测试

单元测试是软件开发中的重要实践,用于验证代码的各个单元(如函数、类)是否按预期工作。

问题: 什么是单元测试?为什么需要单元测试?

答案:

  • 单元测试是对代码的最小可测试单元(如函数、方法)进行测试的过程。
  • 单元测试可以帮助开发者尽早发现代码中的错误,提高代码质量,减少回归问题的发生。

问题: 如何使用 Google Test 进行单元测试?

答案:
Google Test 是一个流行的 C++ 单元测试框架。以下是一个简单的示例:

#include <gtest/gtest.h>int add(int a, int b) {return a + b;
}TEST(AddTest, HandlesPositiveInput) {EXPECT_EQ(add(1, 2), 3);EXPECT_EQ(add(10, 20), 30);
}TEST(AddTest, HandlesNegativeInput) {EXPECT_EQ(add(-1, -2), -3);EXPECT_EQ(add(-10, -20), -30);
}int main(int argc, char **argv) {::testing::InitGoogleTest(&argc, argv);return RUN_ALL_TESTS();
}

编译并运行测试:

g++ -std=c++11 -isystem /path/to/gtest/include -pthread test.cpp /path/to/gtest/libgtest.a /path/to/gtest/libgtest_main.a -o test
./test

13.3 性能分析

性能分析是优化代码性能的关键步骤,帮助开发者找到代码中的性能瓶颈。

问题: 如何使用 gprof 进行性能分析?

答案:
gprof 是一个常用的性能分析工具,可以生成函数调用图和执行时间统计。

  1. 编译时添加 -pg 选项:

    g++ -pg -o my_program my_program.cpp
    
  2. 运行程序生成性能数据:

    ./my_program
    
  3. 使用 gprof 分析性能数据:

    gprof my_program gmon.out > analysis.txt
    

问题: 如何使用 valgrind 进行内存分析?

答案:
valgrind 是一个强大的工具,用于检测内存泄漏和内存错误。

  1. 安装 valgrind

    sudo apt-get install valgrind
    
  2. 使用 valgrind 运行程序:

    valgrind --leak-check=full ./my_program
    
  3. 查看输出,分析内存泄漏和错误。


14. C++ 编码规范

14.1 命名规范

良好的命名规范可以提高代码的可读性和可维护性。

问题: C++ 中常见的命名规范有哪些?

答案:

  • 变量和函数名使用小写字母和下划线分隔(snake_case)。
  • 类名使用大写字母开头的驼峰命名法(PascalCase)。
  • 常量名使用全大写字母和下划线分隔(UPPER_CASE)。

问题: 为什么命名规范很重要?

答案:
命名规范可以提高代码的可读性,使其他开发者更容易理解代码的意图,减少沟通成本。

14.2 代码格式化

代码格式化是保持代码风格一致的重要手段。

问题: 如何使用 clang-format 格式化代码?

答案:
clang-format 是一个自动格式化 C++ 代码的工具。

  1. 安装 clang-format

    sudo apt-get install clang-format
    
  2. 创建配置文件 .clang-format

    clang-format -style=llvm -dump-config > .clang-format
    
  3. 格式化代码:

    clang-format -i my_program.cpp
    

15. C++ 项目构建

15.1 Makefile

Makefile 是用于自动化构建 C++ 项目的工具。

问题: 如何编写一个简单的 Makefile

答案:
以下是一个简单的 Makefile 示例:

CXX = g++
CXXFLAGS = -std=c++11 -Wall
TARGET = my_program
SRCS = main.cpp utils.cpp
OBJS = $(SRCS:.cpp=.o)all: $(TARGET)$(TARGET): $(OBJS)$(CXX) $(CXXFLAGS) -o $(TARGET) $(OBJS)%.o: %.cpp$(CXX) $(CXXFLAGS) -c $< -o $@clean:rm -f $(OBJS) $(TARGET)

问题: 如何使用 make 构建项目?

答案:
在项目根目录下运行以下命令:

make

15.2 CMake

CMake 是一个跨平台的构建工具,可以生成 Makefile 或其他构建系统的配置文件。

问题: 如何编写一个简单的 CMakeLists.txt

答案:
以下是一个简单的 CMakeLists.txt 示例:

cmake_minimum_required(VERSION 3.10)
project(MyProgram)set(CMAKE_CXX_STANDARD 11)add_executable(my_program main.cpp utils.cpp)

问题: 如何使用 CMake 构建项目?

答案:

  1. 创建构建目录并进入:

    mkdir build
    cd build
    
  2. 运行 cmake 生成构建文件:

    cmake ..
    
  3. 使用 make 构建项目:

    make
    

16. C++ 未来发展趋势

16.1 C++23 新特性

C++23 是 C++ 的下一个版本,预计将引入更多新特性。

问题: C++23 可能引入哪些新特性?

答案:

  • 模块化标准库(Modular Standard Library)。
  • 协程改进(Coroutine Improvements)。
  • 更强大的概念支持(Enhanced Concepts)。

16.2 C++ 的未来

C++ 作为一门历史悠久的语言,仍在不断进化。

问题: C++ 的未来发展方向是什么?

答案:

  • 更加注重性能和安全性。
  • 引入更多现代编程范式,如函数式编程。
  • 提高开发效率,减少语言复杂性。

结语

C++ 是一门强大且复杂的语言,掌握其核心概念和高级特性对于成为一名优秀的 C++ 开发者至关重要。本文涵盖了许多经典的 C++ 面试题,希望能够帮助读者更好地准备面试,并在实际开发中运用这些知识。无论是初学者还是经验丰富的开发者,持续学习和实践都是提升技能的关键。

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

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

相关文章

安卓开发,打开PDF文件

1、把PDF文件复制到raw目录下 &#xff08;1&#xff09;新建一个Android Resource Directory (2)Resource type 改成 raw (3) 把PDF文件复制到raw目录下 2、activity_main.xml <?xml version"1.0" encoding"utf-8"?> <LinearLayoutxmlns:and…

渗透测试之文件包含漏洞 超详细的文件包含漏洞文章

目录 说明 通常分为两种类型&#xff1a; 本地文件包含 典型的攻击方式1&#xff1a; 影响&#xff1a; 典型的攻击方式2&#xff1a; 包含路径解释&#xff1a; 日志包含漏洞&#xff1a; 操作原理 包含漏洞读取文件 文件包含漏洞远程代码执行漏洞: 远程文件包含…

Git--使用教程

Git的框架讲解 Git 是一个分布式版本控制系统&#xff0c;其架构设计旨在高效地管理代码版本&#xff0c;支持分布式协作&#xff0c;并确保数据的完整性和安全性。 Git 的核心组件&#xff1a; 工作区&#xff08;Working Directory&#xff09;&#xff1a; 工作区是你在本…

Deepseek 接入Word处理对话框(隐藏密钥)

硅基流动邀请码&#xff1a;1zNe93Cp 邀请链接&#xff1a;网页链接 亲测deepseek接入word&#xff0c;自由调用对话&#xff0c;看截图有兴趣的复用代码&#xff08;当然也可以自己向deepseek提问&#xff0c;帮助你完成接入&#xff0c;但是提问逻辑不一样给出的答案是千差万…

Redis存储⑤Redis五大数据类型之 List 和 Set。

目录 1. List 列表 1.1 List 列表常见命令 1.2 阻塞版本命令 1.3 List命令总结和内部编码 1.4 List典型使用场景 1.4.1 消息队列 1.4.2 分频道的消息队列 1.4.3 微博 Timeline 2. Set 集合 2.1 Set 集合常见命令 2.2 Set 集合间命令 2.3 Set命令小结和内部编码 2.…

DeepSeek 的含金量还在上升

大家好啊&#xff0c;我是董董灿。 最近 DeepSeek 越来越火了。 网上有很多针对 DeepSeek 的推理测评&#xff0c;除此之外&#xff0c;也有很多人从技术的角度来探讨 DeepSeek 带给行业的影响。 比如今天就看到了一篇文章&#xff0c;探讨 DeepSeek 在使用 GPU 进行模型训练…

深入剖析 Bitmap 数据结构:原理、应用与优化策略

深入理解 Bitmap 数据结构 一、引言 在计算机科学领域&#xff0c;数据的高效存储和快速处理一直是核心问题。随着数据量的不断增长&#xff0c;如何用最少的空间和最快的速度来表示和操作数据变得至关重要。Bitmap&#xff08;位图&#xff09;作为一种简洁而强大的数据结构…

【后端开发】系统设计101——通信协议,数据库与缓存,架构模式,微服务架构,支付系统(36张图详解)

【后端开发】系统设计101——通信协议&#xff0c;数据库与缓存&#xff0c;架构模式&#xff0c;微服务架构&#xff0c;支付系统&#xff08;36张图&#xff09; 文章目录 1、通信协议通信协议REST API 对比 GraphQL&#xff08;前端-web服务&#xff09;grpc如何工作&#x…

DS图(中)(19)

文章目录 前言一、图的遍历广度优先遍历深度优先遍历 二、最小生成树Kruskal算法Prim算法两种方法对比 总结 前言 承上启下&#xff0c;我们来学习下图的中篇&#xff01;&#xff01;&#xff01; 一、图的遍历 图的遍历指的是遍历图中的顶点&#xff0c;主要有 广度优先遍历 …

DeepSeek 发布多模态 Janus-Pro

DeepSeek在接连发布大语言模型V3&#xff0c;推理模型R1之后&#xff0c;DeepSeek随后又发布两款多模态框架&#xff1a;Janus-Pro 与 JanusFlow &#xff0c;引领多模态模型新时代&#xff01; 而且依然是保持了一贯的风格&#xff0c;保持了完全开源&#xff0c;今天我们来看…

【QT笔记】使用QScrollArea实现多行文本样式显示

目录 一、QScrollArea 的基本概念 二、demo代码 三、实现效果 1、页面空间足够&#xff0c;无滚动条时显示效果 2、有滚动条时显示效果 一、QScrollArea 的基本概念 QScrollArea 是 Qt 框架中用于提供一个滚动条区域&#xff0c;允许用户滚动查看比当前可视区域更大的内容…

达梦数据库从单主模式转换为主备模式

目录标题 达梦数据库单主转主备配置笔记前期准备服务器环境数据库安装磁盘空间 流程流程图说明 详细步骤1. 检查主库归档模式2. 配置主库配置文件dm.ini 文件dmmal.ini 文件dmarch.ini 文件 3. 备份主库数据库4. 备库配置新建备库数据库配置备库配置文件dm.ini 文件复制主库的 …

使用C#开发一款通用数据库管理工具

由于经常使用各种数据库&#xff0c;笔者自己动手丰衣足食&#xff0c;使用C#开发了一款通用数据库管理工具&#xff0c;支持Mysql、Oracle、Sqlite、SQL Server等数据库的表、视图、存储过程、函数管理功能&#xff0c;并支持导入导出、数据字典生成、拖拽式跨机器跨库数据一键…

w193基于Spring Boot的秒杀系统设计与实现

&#x1f64a;作者简介&#xff1a;多年一线开发工作经验&#xff0c;原创团队&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339;赠送计算机毕业设计600个选题excel文…

DeepSeek各版本说明与优缺点分析

DeepSeek各版本说明与优缺点分析 DeepSeek是最近人工智能领域备受瞩目的一个语言模型系列&#xff0c;其在不同版本的发布过程中&#xff0c;逐步加强了对多种任务的处理能力。本文将详细介绍DeepSeek的各版本&#xff0c;从版本的发布时间、特点、优势以及不足之处&#xff0…

OpenCV:特征检测总结

目录 一、什么是特征检测&#xff1f; 二、OpenCV 中的常见特征检测方法 1. Harris 角点检测 2. Shi-Tomasi 角点检测 3. Canny 边缘检测 4. SIFT&#xff08;尺度不变特征变换&#xff09; 5. ORB 三、特征检测的应用场景 1. 图像匹配 2. 运动检测 3. 自动驾驶 4.…

windows版的docker如何使用宿主机的GPU

windows版的docker使用宿主机的GPU的命令 命令如下 docker run -it --nethost --gpus all --name 容器名 -e NVIDIA_DRIVER_CAPABILITIEScompute,utility -e NVIDIA_VISIBLE_DEVICESall 镜像名效果 (transformer) rootdocker-desktop:/# python Python 3.9.0 (default, Nov 15 …

neo4j-在Linux中安装neo4j

目录 切换jdk 安装neo4j 配置neo4j以便其他电脑可以访问 切换jdk 因为我安装的jdk是1.8版本的&#xff0c;而我安装的neo4j版本为5.15,Neo4j Community 5.15.0 不支持 Java 1.8&#xff0c;它要求 Java 17 或更高版本。 所以我需要升级Java到17 安装 OpenJDK 17 sudo yu…

8.PPT:小李-第二次世界大战【21】

目录 NO123 ​ NO4567 ​ NO8\9\10\11​ 图片→格式→大小对话框→锁定纵横比✔动画→飞入→效果选项&#xff1a;方向/序列→开始→持续时间→延迟时间持续时间&#xff1a;1s延迟&#xff1a;0.5s音频剪切时间&#xff1a;0.5s&#xff1a;00:00.500自动换片时间设置&…

GAN(生成对抗网络,Generative Adversarial Network)

https://www.bilibili.com/video/BV1mp4y187dm/?spm_id_from333.788.recommend_more_video.2&vd_source35b06c13f470dff84c947fa3045bafc3