C vs C++: 一场编程语言的演变与对比

引言

C 和 C++ 是两种广泛使用的编程语言,它们有着深厚的渊源和各自独特的特点。C 语言是 C++ 的前身,而 C++ 则是在 C 语言的基础上进行了扩展和改进。本文将从多个角度对这两种语言进行比较,帮助读者更好地理解它们之间的异同。全文将涵盖历史背景、语法与特性、应用场景、性能与效率、社区与生态以及未来展望等多个方面,力求全面深入地探讨这两门语言。


1. 历史背景

C 语言

  • 诞生时间:1972 年,由 Dennis Ritchie 在贝尔实验室开发。
  • 设计初衷:为了编写 Unix 操作系统,C 语言被设计成一种高效、灵活且接近硬件的语言。
  • 特点:简洁、高效、可移植性强,适合系统级编程。
  • 标准化进程:C 语言的第一个标准版本(ANSI C)于 1989 年发布,随后又发布了 C99 和 C11 等新标准,不断引入新的特性和改进。

C++ 语言

  • 诞生时间:1985 年,由 Bjarne Stroustrup 在贝尔实验室开发。
  • 设计初衷:在保留 C 语言优点的基础上,引入面向对象编程(OOP)和其他高级特性。
  • 特点:支持多种编程范式(如过程化、面向对象、泛型编程),功能强大,适用于复杂应用开发。
  • 标准化进程:C++ 标准委员会定期发布新版本,如 C++98, C++03, C++11, C++14, C++17, C++20 等,每个版本都引入了大量现代化特性,使 C++ 不断进化。

2. 语法与特性

C 语言

  • 基本结构:函数、变量、控制语句等。
  • 数据类型:基本数据类型(int, float, char 等)、指针、数组、结构体等。
  • 内存管理:手动管理内存,使用 malloc 和 free 函数分配和释放内存。
  • 标准库:提供基本的输入输出、字符串处理、数学运算等功能。
  • 预处理器指令:如 #define#include 等,用于宏定义和文件包含。
  • 编译模型:基于文件的编译模型,每个 .c 文件独立编译为 .o 文件,再链接生成可执行文件。

C++ 语言

  • 继承 C 语言:完全兼容 C 语言的语法和特性。
  • 面向对象编程:引入类、对象、继承、多态等概念,支持封装、继承和多态性。
  • 标准模板库(STL):提供了丰富的容器(vector, list, map 等)、算法(sort, find 等)和迭代器。
  • 自动内存管理:引入智能指针(如 std::unique_ptrstd::shared_ptr),减少内存泄漏的风险。
  • 异常处理:支持 try-catch 结构,用于捕获和处理程序中的异常情况。
  • 模板:支持泛型编程,允许编写通用的函数和类。
  • 命名空间:通过 namespace 关键字避免全局命名冲突。
  • 重载运算符:可以自定义运算符的行为,增强代码的表达力。
  • 引用:提供了一种更安全的指针替代方案。
  • 内联函数:通过 inline 关键字提高函数调用的效率。
  • 多重继承:支持一个类从多个基类派生,增加代码复用性。
  • 虚函数:实现运行时多态性,支持动态绑定。
  • 构造函数和析构函数:用于对象的初始化和清理工作。
  • 模板元编程:利用模板机制在编译期进行计算和优化。

3. 应用场景

C 语言

  • 系统编程:操作系统、驱动程序、嵌入式系统等。
  • 性能要求高的应用:实时系统、游戏引擎的核心部分等。
  • 跨平台开发:由于其高效的编译和运行时性能,C 语言在不同平台上都能表现出色。
  • 网络编程:许多网络协议栈和通信库都是用 C 语言编写的。
  • 数据库管理系统:如 MySQL、PostgreSQL 等数据库的核心部分使用 C 语言实现。
  • 科学计算:高性能计算、数值分析等领域中,C 语言因其高效性而备受青睐。

C++ 语言

  • 大型软件项目:企业级应用、金融系统、图形用户界面(GUI)等。
  • 游戏开发:许多现代游戏引擎(如 Unreal Engine, Unity)都使用 C++ 进行开发。
  • 科学计算:高性能计算、机器学习框架(如 TensorFlow 的核心部分)等。
  • Web 开发:服务器端开发(如 Node.js 使用 C++ 编写的 V8 引擎)。
  • 嵌入式系统:虽然 C 语言更为常见,但 C++ 也逐渐在嵌入式领域得到应用,特别是在需要复杂逻辑和高可靠性的情况下。
  • 移动开发:iOS 和 Android 平台上的原生开发工具链(如 Xcode 和 NDK)支持 C++。
  • 人工智能:深度学习框架(如 PyTorch、TensorFlow)的核心部分通常使用 C++ 实现,以确保高性能和低延迟。

4. 性能与效率

C 语言

  • 优势

    • 极致性能:由于其简洁性和直接操作硬件的能力,C 语言通常具有更高的执行效率。
    • 低层次控制:可以直接访问内存地址、寄存器等底层资源,适合编写对性能要求极高的应用程序。
    • 编译优化:现代编译器对 C 语言的优化非常成熟,能够生成高效的机器码。
  • 劣势

    • 缺乏高级抽象:编写复杂程序时代码量较大,容易出错。
    • 手动内存管理:容易出现内存泄漏和悬空指针等问题,增加了开发难度。

C++ 语言

  • 优势

    • 编译优化:通过编译优化和高效的 STL 实现,C++ 在大多数情况下也能达到与 C 相当的性能。
    • 高级抽象:利用面向对象和泛型编程等特性,可以简化复杂系统的开发。
    • 自动内存管理:智能指针和 RAII(Resource Acquisition Is Initialization)机制减少了内存管理的负担。
  • 劣势

    • 编译时间和代码复杂度:由于引入了更多高级特性,编译时间和代码复杂度可能增加。
    • 学习曲线:C++ 的语法和特性较为复杂,初学者可能需要更多时间来掌握。

5. 社区与生态

C 语言

  • 社区活跃度:虽然不如 C++ 活跃,但仍然拥有庞大的开发者群体,特别是在嵌入式和系统编程领域。
  • 资源丰富度:有大量的书籍、教程和开源项目可供学习和参考。
  • 工具链:成熟的编译器(如 GCC, Clang)和调试工具(如 GDB)为开发者提供了强大的支持。
  • 标准库:虽然相对简单,但足够满足大多数系统级编程的需求。

C++ 语言

  • 社区活跃度:非常活跃,拥有大量的开发者和贡献者,不断推动语言的发展和改进。
  • 资源丰富度:除了丰富的学习资源外,还有强大的 IDE 支持(如 Visual Studio, CLion)和成熟的构建工具(如 CMake)。
  • 第三方库:丰富的第三方库和框架(如 Boost, Qt)极大地扩展了 C++ 的功能。
  • 标准库:C++ 标准库(如 STL)提供了丰富的容器、算法和工具,使得开发更加高效。

6. 未来展望

C 语言

  • 持续发展:尽管 C++ 不断进化,C 语言依然在特定领域保持其不可替代的地位,特别是在需要极致性能和低层次控制的场景中。
  • 标准化进程:C 语言的标准委员会继续发布新版本,以适应现代编程需求和技术进步。
  • 新兴领域:随着物联网(IoT)、边缘计算等新兴技术的发展,C 语言在这些领域的应用前景广阔。
  • 教育普及:作为计算机科学的基础课程之一,C 语言将继续在高校和培训机构中占据重要地位。

C++ 语言

  • 不断创新:C++ 标准委员会定期发布新版本(如 C++20, C++23),引入更多现代化特性,如协程、模块化等。
  • 广泛应用:随着计算机技术的发展,C++ 将继续在高性能计算、人工智能等领域发挥重要作用。
  • 跨平台支持:C++ 的跨平台能力不断增强,使得它在不同操作系统和硬件架构上都能表现出色。
  • 社区驱动:活跃的开发者社区将继续推动 C++ 的发展,带来更多创新和改进。

结论

C 和 C++ 各有千秋,选择哪种语言取决于具体的项目需求和个人偏好。如果你追求极致的性能和对硬件的精细控制,C 语言可能是更好的选择;而如果你希望利用更高级的抽象和丰富的库来简化开发过程,C++ 则更为合适。无论选择哪种语言,掌握它们都将为你的编程生涯打下坚实的基础。


作者:w(゚Д゚)w吓洗宝宝了
日期:2023年12月21日


感谢阅读!如果你觉得这篇文章对你有帮助,请点赞并分享给更多的朋友吧!


参考文献

  1. Kernighan, B. W., & Ritchie, D. M. (1988). The C Programming Language (2nd ed.). Prentice Hall.
  2. Stroustrup, B. (2013). The C++ Programming Language (4th ed.). Addison-Wesley Professional.
  3. ISO/IEC 9899:2011 - Information technology -- Programming languages -- C.
  4. ISO/IEC 14882:2020 - Information technology -- Programming languages -- C++.

希望这篇博客能够帮助你更好地理解 C 和 C++ 之间的区别和联系。如果你有任何问题或建议,欢迎在评论区留言讨论!


附录

C 语言经典代码示例
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define MAX_STUDENTS 100

// 定义一个学生结构体
typedef struct {
    char name[50];
    int id;
    float score;
} Student;

// 全局变量,用于存储学生信息
Student students[MAX_STUDENTS];
int student_count = 0;

// 函数声明
void add_student();
float calculate_average();
void save_to_file(const char *filename);
void load_from_file(const char *filename);

int main() {
    int choice;
    char filename[] = "students.dat";

    // 加载已有的学生数据
    load_from_file(filename);

    while (1) {
        printf("\n学生管理系统\n");
        printf("1. 添加学生\n");
        printf("2. 计算平均分\n");
        printf("3. 保存并退出\n");
        printf("请选择: ");
        scanf("%d", &choice);

        switch (choice) {
            case 1:
                add_student();
                break;
            case 2:
                printf("学生的平均分是: %.2f\n", calculate_average());
                break;
            case 3:
                save_to_file(filename);
                printf("数据已保存,程序退出。\n");
                return 0;
            default:
                printf("无效选择,请重新输入。\n");
        }
    }

    return 0;
}

// 添加学生信息
void add_student() {
    if (student_count >= MAX_STUDENTS) {
        printf("学生数量已达上限。\n");
        return;
    }

    Student *new_student = &students[student_count++];
    printf("请输入学生姓名: ");
    scanf("%s", new_student->name);
    printf("请输入学生ID: ");
    scanf("%d", &new_student->id);
    printf("请输入学生成绩: ");
    scanf("%f", &new_student->score);

    printf("学生信息添加成功。\n");
}

// 计算所有学生的平均分
float calculate_average() {
    if (student_count == 0) {
        return 0.0f;
    }

    float sum = 0.0f;
    for (int i = 0; i < student_count; i++) {
        sum += students[i].score;
    }

    return sum / student_count;
}

// 将学生信息保存到文件
void save_to_file(const char *filename) {
    FILE *file = fopen(filename, "wb");
    if (file == NULL) {
        perror("无法打开文件");
        return;
    }

    fwrite(&student_count, sizeof(int), 1, file);
    fwrite(students, sizeof(Student), student_count, file);

    fclose(file);
    printf("学生信息已保存到文件 %s。\n", filename);
}

// 从文件加载学生信息
void load_from_file(const char *filename) {
    FILE *file = fopen(filename, "rb");
    if (file == NULL) {
        printf("文件 %s 不存在或无法打开。\n", filename);
        return;
    }

    fread(&student_count, sizeof(int), 1, file);
    fread(students, sizeof(Student), student_count, file);

    fclose(file);
    printf("学生信息已从文件 %s 加载。\n", filename);
}
代码说明
  1. 结构体定义Student 结构体用于存储学生的姓名、ID 和成绩。
  2. 全局变量students 数组用于存储所有学生的信息,student_count 记录当前学生数量。
  3. 函数实现
    • add_student():提示用户输入学生信息并将其添加到数组中。
    • calculate_average():遍历所有学生,计算并返回他们的平均分。
    • save_to_file():将学生信息写入二进制文件。
    • load_from_file():从二进制文件读取学生信息。
  4. 主函数:提供一个简单的菜单界面,允许用户进行添加学生、计算平均分和保存数据的操作。
C++ 语言经典代码示例
#include <iostream>
#include <fstream>
#include <vector>
#include <memory>
#include <string>
#include <iomanip>

using namespace std;

// 定义一个图书类
class Book {
protected:
    string title;
    string author;
    float rating;

public:
    Book(const string& title, const string& author, float rating)
        : title(title), author(author), rating(rating) {}

    virtual void display() const {
        cout << "书名: " << title << ", 作者: " << author << ", 评分: " << fixed << setprecision(2) << rating << endl;
    }

    virtual ~Book() {}
};

// 定义一个派生类:电子书
class EBook : public Book {
private:
    string format;

public:
    EBook(const string& title, const string& author, float rating, const string& format)
        : Book(title, author, rating), format(format) {}

    void display() const override {
        cout << "电子书 - ";
        Book::display();
        cout << "格式: " << format << endl;
    }
};

// 定义一个图书管理类
class Library {
private:
    vector<shared_ptr<Book>> books;

public:
    void add_book(shared_ptr<Book> book) {
        books.push_back(book);
    }

    float calculate_average_rating() const {
        if (books.empty()) return 0.0f;

        float sum = 0.0f;
        for (const auto& book : books) {
            sum += book->rating;
        }
        return sum / books.size();
    }

    void save_to_file(const string& filename) const {
        ofstream file(filename, ios::binary);
        if (!file.is_open()) {
            cerr << "无法打开文件" << endl;
            return;
        }

        int size = books.size();
        file.write(reinterpret_cast<const char*>(&size), sizeof(int));

        for (const auto& book : books) {
            int type = dynamic_cast<EBook*>(book.get()) ? 1 : 0;
            file.write(reinterpret_cast<const char*>(&type), sizeof(int));

            if (type == 0) {
                file.write(reinterpret_cast<const char*>(&(book->title)), sizeof(string));
                file.write(reinterpret_cast<const char*>(&(book->author)), sizeof(string));
                file.write(reinterpret_cast<const char*>(&book->rating), sizeof(float));
            } else {
                EBook* ebook = dynamic_cast<EBook*>(book.get());
                file.write(reinterpret_cast<const char*>(&(ebook->title)), sizeof(string));
                file.write(reinterpret_cast<const char*>(&(ebook->author)), sizeof(string));
                file.write(reinterpret_cast<const char*>(&ebook->rating), sizeof(float));
                file.write(reinterpret_cast<const char*>(&(ebook->format)), sizeof(string));
            }
        }

        file.close();
        cout << "图书信息已保存到文件 " << filename << "。\n";
    }

    void load_from_file(const string& filename) {
        ifstream file(filename, ios::binary);
        if (!file.is_open()) {
            cout << "文件 " << filename << " 不存在或无法打开。\n";
            return;
        }

        int size;
        file.read(reinterpret_cast<char*>(&size), sizeof(int));

        books.clear();
        for (int i = 0; i < size; ++i) {
            int type;
            file.read(reinterpret_cast<char*>(&type), sizeof(int));

            string title, author, format;
            float rating;

            if (type == 0) {
                file.read(reinterpret_cast<char*>(&title), sizeof(string));
                file.read(reinterpret_cast<char*>(&author), sizeof(string));
                file.read(reinterpret_cast<char*>(&rating), sizeof(float));
                books.push_back(make_shared<Book>(title, author, rating));
            } else {
                file.read(reinterpret_cast<char*>(&title), sizeof(string));
                file.read(reinterpret_cast<char*>(&author), sizeof(string));
                file.read(reinterpret_cast<char*>(&rating), sizeof(float));
                file.read(reinterpret_cast<char*>(&format), sizeof(string));
                books.push_back(make_shared<EBook>(title, author, rating, format));
            }
        }

        file.close();
        cout << "图书信息已从文件 " << filename << " 加载。\n";
    }

    void display_books() const {
        for (const auto& book : books) {
            book->display();
        }
    }
};

int main() {
    Library library;
    string filename = "library.dat";

    // 加载已有的图书数据
    library.load_from_file(filename);

    while (true) {
        cout << "\n图书管理系统\n";
        cout << "1. 添加图书\n";
        cout << "2. 计算平均评分\n";
        cout << "3. 显示所有图书\n";
        cout << "4. 保存并退出\n";
        cout << "请选择: ";

        int choice;
        cin >> choice;

        switch (choice) {
            case 1: {
                cout << "请输入书名: ";
                string title;
                cin.ignore();
                getline(cin, title);

                cout << "请输入作者: ";
                string author;
                getline(cin, author);

                cout << "请输入评分: ";
                float rating;
                cin >> rating;

                cout << "是否为电子书?(y/n): ";
                char is_ebook;
                cin >> is_ebook;

                if (is_ebook == 'y') {
                    cout << "请输入格式: ";
                    string format;
                    cin >> format;
                    library.add_book(make_shared<EBook>(title, author, rating, format));
                } else {
                    library.add_book(make_shared<Book>(title, author, rating));
                }

                cout << "图书信息添加成功。\n";
                break;
            }
            case 2:
                cout << "图书的平均评分是: " << fixed << setprecision(2) << library.calculate_average_rating() << endl;
                break;
            case 3:
                library.display_books();
                break;
            case 4:
                library.save_to_file(filename);
                cout << "数据已保存,程序退出。\n";
                return 0;
            default:
                cout << "无效选择,请重新输入。\n";
        }
    }

    return 0;
}
代码说明
  1. 结构体定义Student 结构体用于存储学生的姓名、ID 和成绩。
  2. 全局变量students 数组用于存储所有学生的信息,student_count 记录当前学生数量。
  3. 函数实现
    • add_student():提示用户输入学生信息并将其添加到数组中。
    • calculate_average():遍历所有学生,计算并返回他们的平均分。
    • save_to_file():将学生信息写入二进制文件。
    • load_from_file():从二进制文件读取学生信息。
  4. 主函数:提供一个简单的菜单界面,允许用户进行添加学生、计算平均分和保存数据的操作。


再次感谢你的阅读和支持!如果你喜欢这篇文章,请关注我的博客,获取更多编程知识和技术分享。

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

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

相关文章

C++简明教程(文章要求学过一点C语言)(3)

一、编程工具大揭秘——IDE 当我们准备踏入 C 编程的奇妙世界时&#xff0c;首先要认识一个重要的“魔法盒子”——集成开发环境&#xff08;IDE&#xff09;。IDE 就像是一个全能的编程工作室&#xff0c;它把我们写代码所需要的各种工具都整合到了一起&#xff0c;让编程这件…

STM32-笔记5-按键点灯(中断方法)

1、复制03-流水灯项目&#xff0c;重命名06-按键点灯&#xff08;中断法&#xff09; 在\Drivers\BSP目录下创建一个文件夹exti&#xff0c;在该文件夹下&#xff0c;创建两个文件exti.c和exti.h文件&#xff0c;并且把这两个文件加载到项目中&#xff0c;打开项目工程文件 加载…

实现 WebSocket 接入文心一言

目录 什么是 WebSocket&#xff1f; 为什么需要 WebSocket&#xff1f; HTTP 的局限性 WebSocket 的优势 总结&#xff1a;HTTP 和 WebSocket 的区别 WebSocket 的劣势 WebSocket 常见应用场景 WebSocket 握手过程 WebSocket 事件处理和生命周期 WebSocket 心跳机制 …

leetcode-80.删除有序数组的重复项II-day12

总结&#xff1a;不必过于死磕一道题目&#xff0c;二十分钟没做出来就可参考题解

RTOS之邮箱

邮箱 邮箱 (Mailbox) 服务是实时操作系统中一种常用的线程间通信机制。它提供了一种高效、低开销的消息传递方式&#xff0c;允许线程之间交换固定大小的数据。 1. 邮箱的应用场景 考虑一个简单的示例&#xff1a;线程 1 负责检测按键状态并将状态信息发送出去&#xff0c;线程…

凯酷全科技抖音电商服务的卓越践行者

在数字经济蓬勃发展的今天&#xff0c;电子商务已成为企业增长的新引擎。随着短视频平台的崛起&#xff0c;抖音作为全球领先的短视频社交平台&#xff0c;不仅改变了人们的娱乐方式&#xff0c;也为品牌和商家提供了全新的营销渠道。厦门凯酷全科技有限公司&#xff08;以下简…

AI的进阶之路:从机器学习到深度学习的演变(三)

&#xff08;承接上集&#xff1a;AI的进阶之路&#xff1a;从机器学习到深度学习的演变&#xff08;二&#xff09;&#xff09; 四、深度学习&#xff08;DL&#xff09;&#xff1a;机器学习的革命性突破 深度学习&#xff08;DL&#xff09;作为机器学习的一个重要分支&am…

数据集-目标检测系列 车牌检测识别 数据集 CCPD2019

车牌检测&识别 数据集 CCPD2019 DataBall 助力快速掌握数据集的信息和使用方式&#xff0c;会员享有 百种数据集&#xff0c;持续增加中。 需要更多数据资源和技术解决方案&#xff0c;知识星球&#xff1a; “DataBall - X 数据球(free)” 贵在坚持&#xff01; 数据样…

安全算法基础(一)

安全算法是算法的分支之一&#xff0c;还的依靠大量的数学基础进行计算&#xff0c;本文参照兜哥的AI安全样本对抗&#xff0c;做一个简单的算法安全概括&#xff0c;从零学习。 最新的安全算法对于我们常规的攻击样本检测&#xff0c;效果是不理想的&#xff0c;为了探究其原…

[SZ901]JTAG高速下载设置(53Mhz)

SZ901最高支持JTAG 53MHz的时钟频率&#xff0c;下载bit文件和固化程序的速度提升非常明显。 首先设置参数 1&#xff0c;将JTAG0 分频系数修改为3 2&#xff0c;设置参数&#xff0c;更新参数。&#xff08;完成&#xff09; 打开VIVADO VIVADO 正常识别FPGA&#xff0c;速…

图漾相机-ROS1_SDK_ubuntu版本编译(新版本)

文章目录 官网编译文档链接官网SDK下载链接1、下载 Camport ROS1 SDK1.下载git2、下载链接 2、准备编译工作1、安装 catkin2、配置环境变量3. 将Camport3中的linux库文件拷贝到 user/lib目录下4、修改lunch文件制定相机&#xff08;可以放在最后可以参考在线文档&#xff09;**…

openbmc hwmon与sensor监控

1.说明 参考文档: https://github.com/openbmc/entity-manager/blob/master/docs/entity_manager_dbus_api.mdhttps://github.com/openbmc/entity-manager/blob/master/docs/my_first_sensors.md 1.1 简单介绍 注意: 本节是快速浏览整个sensor框架&#xff0c;了解大致open…

Java --- 多线程

目录 前言&#xff1a; 一.线程的创建&#xff1a; 1.通过继承 Thread 类来创建线程&#xff1a; 2.通过Runnable接口创建线程&#xff1a; 3.通过Java8引入的lambda语法&#xff1a; 线程的优先级&#xff1a; 二.线程的生命周期&#xff1a; 三. 中断线程&#xff1a…

使用 acme.sh 申请域名 SSL/TLS 证书完整指南

使用 acme.sh 申请域名 SSL/TLS 证书完整指南 简介为什么选择 acme.sh 和 ZeroSSL&#xff1f;前置要求安装过程 步骤一&#xff1a;安装 acme.sh步骤二&#xff1a;配置 ZeroSSL 证书申请 方法一&#xff1a;手动 DNS 验证&#xff08;推荐新手使用&#xff09;方法二&#xf…

Flutter组件————Scaffold

Scaffold Scaffold 是一个基础的可视化界面结构组件&#xff0c;它实现了基本的Material Design布局结构。使用 Scaffold 可以快速地搭建起包含应用栏&#xff08;AppBar&#xff09;、内容区域&#xff08;body&#xff09;、抽屉菜单&#xff08;Drawer&#xff09;、底部导…

YOLOv8目标检测(七)_AB压力测试

YOLOv8目标检测(一)_检测流程梳理&#xff1a;YOLOv8目标检测(一)_检测流程梳理_yolo检测流程-CSDN博客 YOLOv8目标检测(二)_准备数据集&#xff1a;YOLOv8目标检测(二)_准备数据集_yolov8 数据集准备-CSDN博客 YOLOv8目标检测(三)_训练模型&#xff1a;YOLOv8目标检测(三)_训…

SpringBoot的创建方式

SpringBoot创建的五种方式 1.通过Springboot官网链接下载 注意SpringBoot项目的封装方式默认为Jar 需要查看一下&#xff0c;自己的Maven版本是否正确 创建成功 2.通过 aliyun官网链接下载 修改服务路径为阿里云链接 创建成功 3.通过Springboot官网下载 点击&#xff0c;拉到最…

批处理理解

初识批处理 如何批处理&#xff1a; 命名&#xff1a;.bat 方法&#xff1a;创建一个记事本文件&#xff0c;然后将其扩展改为.bat 批处理作用&#xff1a;自上而下成批处理每一条DOS命令&#xff0c;直到执行到最后一条。运行环境&#xff1a;当然是我们cmd了 回归我学过的…

概率论得学习和整理29: 用EXCEL 描述二项分布

目录 1 关于二项分布的基本内容 2 二项分布的概率 2.1 核心要素 2.2 成功K次的概率&#xff0c;二项分布公式 2.3 期望和方差 2.4 具体试验 2.5 概率质量函数pmf 和cdf 3 二项分布的pmf图的改进 3.1 改进折线图 3.2 如何生成这种竖线图呢 4 不同的二项分布 4.1 p0.…

全志H618 Android12修改doucmentsui功能菜单项

背景: 由于当前的文件管理器在我们的产品定义当中,某些界面有改动的需求,所以需要在Android12 rom中进行定制以符合当前产品定义。 需求: 在进入File文件管理器后,查看...功能菜单时,有不需要的功能菜单,需要隐藏,如:新建窗口、不显示的文件夹、故代码分析以及客制…