当前位置: 首页 > news >正文

C中Mysql的基本api接口

    • 一、初始化
      • 参数
      • 返回值
    • 二、链接服务器
    • 三、执行SQL语句
      • 注意事项
    • 四、获取结果集
      • 4.1mysql_affected_rows和mysql_num_rows
      • 4.2mysql_store_result与mysql_free_result
      • 注意事项
      • 注意事项
        • 整体的工作流程
      • 4.3mysql_use_result()
      • 4.4mysql_field_count()
    • 五、关闭MySQL
      • 使用和区别
    • 六、错误处理
      • mysql_errno()` 和 `mysql_error()

一、初始化

创建MYSQL* 对象,使用mysql_init函数

MYSQL * mysql;
mysql_init(mysql);

参数

  • mysql:指向一个 MYSQL 结构的指针。通常传递 NULL,系统将自动为您分配和初始化一个新的 MYSQL 对象。

返回值

  • 成功:返回一个指向 MYSQL 结构的指针。
  • 失败:返回 NULL

二、链接服务器

使用函数mysql_real_connect();

MYSQL *mysql_real_connect(MYSQL *mysql,           // mysql_init() 函数的返回值const char *host,       // mysql服务器的主机地址, 写IP地址即可// localhost, null -> 代表本地连接const char *user,       // 连接mysql服务器的用户名, 默认: root const char *passwd,     // 连接mysql服务器用户对应的密码, root用户的密码const char *db,         // 要使用的数据库的名字unsigned int port,      // 连接的mysql服务器监听的端口// 如果==0, 使用mysql的默认端口3306, !=0, 使用指定的这个端口const char *unix_socket,// 本地套接字, 通常在 Windows 上使用命名管道,而在 Unix/Linux 系统上使用 Unix 套接字。如果不使用这类连接方式,此参数应设为 NULL。unsigned long client_flag); //连接时使用的特定客户端标志 通常指定为0
)

返回值:

  • 成功:返回一个指向 MYSQL 结构的指针(通常是传入的那个指针)。
  • 失败:返回 NULL,并且可以通过 mysql_error 函数来获取错误信息。

三、执行SQL语句

// 执行一个sql语句, 添删查改的sql语句都可以
int mysql_query(MYSQL *mysql, const char *query);
参数:- mysql: mysql_real_connect() 的返回值- query: 一个可以执行的sql语句, 结尾的位置不需要加 ;
返回值: - 如果查询成功,返回0。如果是查询, 结果集在mysql 对象中- 如果出现错误,返回非0值。 

注意事项

  1. 资源管理:使用 mysql_query 后,如果查询是 SELECT 类型的,你通常需要调用 mysql_store_resultmysql_use_result 来处理返回的数据。记得在不需要结果集时使用 mysql_free_result 来释放内存。
  2. 错误处理:在生产环境中,每次调用 mysql_query 后都应检查返回值,并适当处理错误。这样可以避免程序在错误状态下继续执行,导致更复杂的问题。
  3. 安全性:避免将未经验证的用户输入直接用于 SQL 语句,以防止 SQL 注入攻击。考虑使用预处理语句和参数化查询来提高安全性。

这些基本的使用方式和注意事项可以帮助你有效地使用 mysql_query 来执行数据库操作。

值得注意的是在 MySQL 中,SQL 语句的关键字(如 SELECT, INSERT, UPDATE, DELETE 等)通常是不区分大小写的,这意味着 “select” 和 “SELECT” 在 MySQL 解释器看来是相同的。然而,数据库名称、表名、列名的大小写敏感性则取决于操作系统的文件系统和 MySQL 的配置。在 Unix、Linux 系统中,它们默认是大小写敏感的,而在 Windows 系统中默认是不敏感的。

mysql_query 实质上是在客户端和 MySQL 服务器之间进行网络通信的一个接口。在使用 TCP/IP 协议的情况下,客户端通过网络向服务器发送请求,并接收服务器的响应。这个过程涉及到网络数据的发送和接收,是基于客户端-服务器模型的典型应用。

要注意的是标准 SQL 查询:如果你的查询是简单的文本,不包含二进制数据,且不需要在 SQL 语句中嵌入 null 字符,使用 mysql_query 就足够了。

而当数据中有二进制数据就需要使用mysql_real_query

int mysql_real_query(MYSQL *mysql, const char *query, unsigned long length);
  • 灵活性:可以执行包含 null 字符的查询,因为它要求用户明确提供查询的长度。
  • 手动指定长度:用户必须指定查询字符串的长度,这允许函数处理二进制数据或包含 null 字符的数据。
  • 适用场景:非常适合执行包含 BLOB 类型数据的 SQL 语句。

四、获取结果集

4.1mysql_affected_rows和mysql_num_rows

uint64_t mysql_affected_rows(MYSQL *mysql)

mysql_affected_rows() 可能是 在使用 mysql_real_query() 或 mysql_query() 执行语句后立即调用。它返回 上一个更改、删除或插入的行数 语句(如果是 UPDATE、DELETE 或 INSERT)。对于 SELECT 语mysql_affected_rows() 有效 像 mysql_num_rows()。

对于 UPDATE 语句, 默认情况下,affected-rows 值是实际的行数 改变。如果在以下情况下指定 mysql_real_connect() 的标志 连接到 mysqld,受影响的行 value 是“找到”的行数;那是 与子句匹配。CLIENT_FOUND_ROWSWHERE

对于 REPLACE 语句, 如果新行替换了旧行,则 affected-rows 值为 2, 因为在这种情况下,在重复项之后插入了一行 已删除。

uint64_t mysql_num_rows(MYSQL_RES *result)

返回结果集中的行数。

4.2mysql_store_result与mysql_free_result

MYSQL_RES *mysql_store_result(MYSQL *mysql);
参数说明
mysql: 指向 MYSQL 结构的指针,该结构体应已通过 mysql_real_connect 函数建立了与 MySQL 服务器的连接,并已成功执行了一个查询(如通过 mysql_query)。
返回值
成功: 返回一个指向 MYSQL_RES 结构的指针,这个结构包含了从服务器返回的所有结果数据。
失败 或 查询没有产生结果集(例如执行的是 UPDATE 或 DELETE 语句): 返回 NULL。
如何将行和列的数据从结果集中取出, 需要使用其他函数

注:mysql_store_result 函数只会返回与最近一次通过 mysql_query (或其他发送 SQL 语句的函数)执行的查询相关的结果。它不会存储或回溯到之前的查询结果,而是专注于最后执行的查询。

注意事项

  1. 内存管理:使用 mysql_store_result 后,必须在不再需要结果集时调用 mysql_free_result 来释放内存。
  2. 性能考量:由于 mysql_store_result 会将所有结果数据存储在客户端内存中,对于返回大量数据的查询,这可能会消耗大量内存和网络资源。如果处理大型数据集,可能需要考虑使用 mysql_use_result,该函数允许逐行检索数据,从而减少内存占用。
  3. 错误处理:始终检查 mysql_store_result 的返回值,并使用 mysql_error 函数来诊断错误。

通过 mysql_store_result,你可以方便地在客户端处理来自 MySQL 服务器的数据,但务必注意资源管理和错误处理,以确保应用程序的稳定性和效率。

void mysql_free_result(MYSQL_RES *result);
参数说明
result: 指向 MYSQL_RES 结构的指针,该结构包含了之前查询的结果集。

mysql_free_result 函数是 MySQL C API 中用来释放由 mysql_store_resultmysql_use_result 函数分配的结果集内存的函数。这是清理和资源管理的重要一步,确保在查询处理完成后不会造成内存泄漏。

当使用 mysql_store_resultmysql_use_result 从 MySQL 服务器获取查询结果后,相关的数据会被存储在 MYSQL_RES 结构中。这个结构占用一定的内存空间,当数据处理完毕后,应该使用 mysql_free_result 来释放这些内存。如果不这样做,每次查询后未释放的内存会累积,最终可能导致内存不足或程序崩溃。

实际使用

#include <mysql.h>
#include <iostream>int main() {MYSQL *conn;MYSQL_RES *res;MYSQL_ROW row;conn = mysql_init(NULL);if (!conn) {std::cerr << "MySQL initialization failed." << std::endl;return 1;}if (!mysql_real_connect(conn, "localhost", "user", "password", "database", 0, NULL, 0)) {std::cerr << "Failed to connect to database: " << mysql_error(conn) << std::endl;mysql_close(conn);return 1;}if (mysql_query(conn, "SELECT id, name FROM users")) {std::cerr << "Query failed: " << mysql_error(conn) << std::endl;mysql_close(conn);return 1;}res = mysql_store_result(conn);if (!res) {std::cerr << "Failed to retrieve result set: " << mysql_error(conn) << std::endl;mysql_close(conn);return 1;}while ((row = mysql_fetch_row(res))) {std::cout << "ID: " << row[0] << ", Name: " << row[1] << std::endl;}// After processing the results, free the memory.mysql_free_result(res);mysql_close(conn);return 0;
}

注意事项

  1. 只释放一次:确保对每个 MYSQL_RES 结构只调用一次 mysql_free_result。重复释放可能会导致未定义行为或程序崩溃。
  2. 适时释放:尽可能在数据处理完毕后立即释放结果集,特别是在处理多个查询的情况下,避免不必要的内存占用。
  3. 检查 NULL:如果 mysql_store_resultmysql_use_result 返回 NULL,表明没有结果集需要处理,因此不应该调用 mysql_free_result
整体的工作流程
  1. 执行查询:首先使用 mysql_query 执行一个 SQL 查询。
  2. 检索结果:使用 mysql_store_result 检索查询结果并存储在 MYSQL_RES * 结构中。
  3. 处理数据:通过循环等方式处理这些结果。
  4. 释放资源:使用 mysql_free_result 释放 MYSQL_RES * 结构占用的内存。
  5. 重复操作:如果需要再次查询,回到第一步,执行新的 mysql_query,然后使用 mysql_store_result 检索新的结果。

值得注意的是如果你在调用 mysql_store_result 之后没有使用 mysql_free_result 来释放结果集的内存,然后再次进行查询并调用 mysql_store_result,这将导致内存泄漏。这是因为每次调用 mysql_store_result 都会从 MySQL 服务器获取新的结果数据,并在客户端为这些数据分配新的内存。如果旧的结果集没有被适当释放,那么这部分内存仍然被占用,尽管你已经无法再访问到这部分数据。

4.3mysql_use_result()

MYSQL_RES *mysql_use_result(MYSQL *mysql)
参数说明
mysql: 指向 MYSQL 结构的指针,该结构表示一个已连接的 MySQL 数据库。
返回值
成功:返回一个指向 MYSQL_RES 结构的指针,该结构代表结果集。
失败:返回 NULL,并且可以通过 mysql_error 函数获取错误信息。
while ((row = mysql_fetch_row(res))) {std::cout << "ID: " << row[0] << ", Name: " << row[1] << std::endl;
}
  1. 逐行处理mysql_use_result 逐行读取结果集,这意味着你不能在获取完整结果集之前执行其他查询,否则会导致未定义行为。
  2. 资源释放:使用 mysql_use_result 后,一定要调用 mysql_free_result 释放结果集,确保内存资源被适当管理。
  3. 网络延迟:因为 mysql_use_result 逐行读取数据,受网络延迟的影响可能会比 mysql_store_result 慢,但对于大结果集它能显著降低内存占用。

mysql_use_resultmysql_store_result 都是用来处理查询结果集的函数,但它们在处理方式上有以下区别:

  • mysql_store_result:一次性将整个结果集从服务器读取到客户端内存中,适用于结果集较小的情况,因为它会在客户端占用较多内存。
  • mysql_use_result:逐行从服务器读取结果集,适用于结果集较大的情况,因为它不会将整个结果集一次性加载到内存中,节省了内存占用。

4.4mysql_field_count()

在第三部分我们看到mysql_query不仅可以使用SELECT SQL语句还可以使用INSERT语句,我们对于查询语句的列数和是否是查询语句是有一定的判断需求的

unsigned int mysql_field_count(MYSQL *mysql)
  • 返回一个 unsigned int 值,表示最近执行的查询返回的列数。如果没有活动的查询或查询没有返回任何结果,则返回 0。

注意事项

  1. 正确的上下文mysql_field_count 应该在成功执行查询之后调用,以确保它返回正确的列数。如果在没有活动查询的情况下调用它,返回值将是 0。
  2. 结果集处理:当你使用 mysql_store_resultmysql_use_result 来获取结果集时,使用 mysql_field_count 可以帮助你动态地处理结果集中的数据。
  3. 查询类型:对于不返回结果集的查询(如 INSERTUPDATEDELETE),mysql_field_count 返回 0。

五、关闭MySQL

void mysql_close(MYSQL *mysql)

当你完成了数据库操作并不再需要与数据库的连接时,应该调用 mysql_close 来关闭连接。这个调用确保所有的客户端资源被适当清理,包括内部缓冲区和连接句柄。如果不关闭连接,可能会导致资源泄漏。

void mysql_library_end(void);

在所有数据库连接都已通过 mysql_close 关闭后,应调用 mysql_library_end 来清理 MySQL 客户端库使用的所有资源。这个函数主要用于多线程环境中,在所有线程都完成数据库操作并关闭连接后,由主线程调用以确保所有的客户端库资源被正确释放。

使用和区别

使用场景mysql_close 用于关闭单个数据库连接;mysql_library_end 用于在程序结束前清理客户端库。

调用时机

mysql_close:每个数据库连接在不再需要时应该被关闭。

mysql_library_end:在程序结束,所有数据库连接都已关闭后调用。

值得注意的是即使在单线程应用程序中,依然推荐在程序结束时调用 mysql_library_end。这个函数的作用不仅限于多线程环境,它负责清理 MySQL 客户端库使用的全局资源,确保所有初始化时分配的资源被适当释放,这包括内部数据结构、缓冲区等。

六、错误处理

mysql_errno()mysql_error()

mysql_errno() 返回最近一次 MySQL 函数调用所产生的错误代码。这个错误代码是一个整数值,表示特定类型的错误。

unsigned int mysql_errno(MYSQL *mysql);
返回一个 `unsigned int` 类型的错误代码。如果没有错误发生,返回值为 `0`。

mysql_error() 返回最近一次 MySQL 函数调用所产生的错误信息字符串。这个字符串描述了具体的错误情况,通常比错误代码更易读和理解。

const char *mysql_error(MYSQL *mysql);
返回一个指向描述错误的字符串的指针。如果没有错误发生,返回一个空字符串。

通过使用 mysql_errno()mysql_error(),你可以更详细地了解数据库操作中的错误,帮助调试和改进程序的错误处理能力。这两个函数在处理复杂数据库交互时尤为重要,因为它们可以提供具体的错误信息和错误代码,有助于定位和解决问题。

相关文章:

C中Mysql的基本api接口

一、初始化参数返回值 二、链接服务器三、执行SQL语句注意事项 四、获取结果集4.1mysql_affected_rows和mysql_num_rows4.2mysql_store_result与mysql_free_result注意事项注意事项整体的工作流程 4.3mysql_use_result&#xff08;&#xff09;4.4mysql_field_count&#xff08…...

grafana10.x报错 Failed to upgrade legacy queries Datasource x was not found

问题 grafana 从6.x升级到10.x后&#xff0c;导入json文件后报错&#xff0c;数据源x查询不到&#xff0c;grafana不显示数据&#xff1b; Templating Failed to upgrade legacy queries Datasource x was not found解决方法 可能grafana升级后数据源找不到&#xff0c;在面板…...

项目管理-案例重点知识(干系人管理)

项目管理&#xff1a;每天进步一点点~ 活到老&#xff0c;学到老 ヾ(◍∇◍)&#xff89;&#xff9e; 何时学习都不晚&#xff0c;加油 四、干系人管理 案例重点知识 干系人管理 案例 重点内容&#xff1a; &#xff08;1&#xff09;权力利益方格、权力影响方格&#xff…...

微信小程序踩坑,skyline模式下,scroll-view下面的一级元素设置margin中的auto无效,具体数据有效

开发工具版本 基础库 开启skyline渲染调试 问题描述 skyline模式下,scroll-view下面的一级元素的margin写auto的值是没有效果的(二级元素margin写auto是有效果的),关闭这个模式就正常显示 演示效果图 父元素的宽度和高度效果(宽度是750rpx,宽度占满的) 一级元素宽度和css效果…...

jspXMl标记语言基础

1.打开命令框进入数据库 打开eclipse创建需要连接的项目 粘贴驱动程序 查看驱动器 使用sql的包 int代表个 conlm代表列名 <%page import"java.sql.ResultSet"%> <%page import"java.sql.Statement"%> <%page import"java.sql.Connect…...

【DevOps】Linux 与虚拟局域网 (VLAN) 详解

目录 一、什么是VLAN&#xff1f; 二、VLAN的工作原理 三、Linux中的VLAN支持 四、内核模块 五、用户空间工具 六、创建VLAN 七、配置VLAN 八、管理VLAN 九、VLAN的应用 1、 网络隔离 2、网络管理 3、网络扩展 十、VLAN的优点和限制 十一、结论 虚拟局域网&#…...

《表格新视界:从罗列到洞察的飞跃》

在信息爆炸的当下&#xff0c;表格宛如一位低调的英雄&#xff0c;默默支撑着无数的数据世界。 曾经&#xff0c;我们只把表格当作简单的记录工具&#xff0c;一行行、一列列地填着数字与文字。但如今&#xff0c;表格已华丽转身&#xff0c;成为了展现数据魅力的舞台。 它不…...

风电功率预测 | 基于GRU门控循环单元的风电功率预测(附matlab完整源码)

风电功率预测 风电功率预测 | 基于GRU门控循环单元的风电功率预测(附matlab完整源码)完整代码风电功率预测 | 基于GRU门控循环单元的风电功率预测(附matlab完整源码) 完整代码 clc; clear close allX = xlsread(风电场预测.xlsx)...

0基础安装 composer

解决&#xff1a; composer 不是内部或外部命令&#xff0c;也不是可运行的程序 或批处理文件。 php composer.phar可以运行 安装环境&#xff1a;系统w11 官网地址&#xff1a;Composer 1.安装composer 1.1打开命令行窗口 在命令行窗口里&#xff0c;右键是粘贴&#xff0…...

MYSQL-9.问题排查

问题排查的思路与方向 问题排查思路 分析问题&#xff1a;根据理论知识经验分析问题&#xff0c;判断问题可能出现的位置或可能引起问题的原因&#xff0c;将目标缩小到一定范围&#xff1b;排查问题&#xff1a;基于上一步的结果&#xff0c;从引发问题的“可疑性”角度出发…...

制造企业数据管理:从数据到价值的转化

在数字化浪潮席卷全球的今天&#xff0c;制造企业面临着前所未有的机遇与挑战。如何从海量的数据中提取有价值的信息&#xff0c;将其转化为企业的核心竞争力&#xff0c;成为了每一个制造企业必须面对的问题。而数据管理&#xff0c;正是实现这一转化的关键所在。制造企业数据…...

单例模式介绍

【一】为什么要单例模式 单例设计模式&#xff1a; 一个类只允许创建一个对象&#xff08;或者实例&#xff09;&#xff0c;那这个类就是一个单例类&#xff0c;这种设计模式就叫作单例设计模式&#xff0c;简称单例模式。 当一个类的功能比较单一&#xff0c;只需要一个实例…...

Facebook企业户/在Facebook上做推广有什么好处?

想到出海&#xff0c;必会想到Facebook作为世界上最大的社交网络&#xff0c;Facebook拥有难以想象的用户数量&#xff0c;流量大到没朋友。近年来也是独立站卖家获取流量的有力工具之一。独立站卖家在Facebook上做广告的好处&#xff1f; Facebook&#xff0c;Google 开企业广…...

Go GORM实战(二) | 数据库连接的N种方式

连接数据库 使用GORM连接数据库还是比较简单的&#xff0c;概括起来就是以下三个步骤&#xff1a; 引入gorm.io/gorm和对应数据库的驱动库&#xff0c;如gorm.io/driver/sqlite。 调用对应驱动库的Open()或New()函数返回一个实现了gorm.Dialector接口的实例。 调用gorm.Open…...

Cocos Creator 2D Mask与Layout 使用详解

Cocos Creator是一款强大的2D游戏开发引擎&#xff0c;提供了丰富的功能和工具&#xff0c;使开发者可以轻松创建出高质量的游戏。其中&#xff0c;2D Mask和Layout是Cocos Creator中常用的两个组件&#xff0c;它们可以帮助开发者实现更加复杂和精美的游戏界面设计。本文将详细…...

项目-坦克大战

增加功能 我方坦克在发射的子弹消亡后&#xff0c;才能发射新的子弹。同时实现发多颗子弹 1&#xff0c;在按下J键&#xff0c;我们判断当前hero对象的子弹&#xff0c;是否已经销毁2&#xff0c;如果没有销毁&#xff0c;就不去触发shotEnemyTank3&#xff0c;如果已经销毁&…...

代码随想录算法训练营第二十九天| LeetCode491.递增子序列* 、LeetCode46.全排列*、LeetCode47.全排列 II

#LeetCode 491. Non-decreasing Subsequences #LeetCode 491. 视频讲解&#xff1a;回溯算法精讲&#xff0c;树层去重与树枝去重 | LeetCode&#xff1a;491.递增子序列_哔哩哔哩_bilibili 首先&#xff0c;本题不能考虑首先对数组排序&#xff0c;排序会导致数组直接变为一个…...

基于SpringBoot设计模式之开端

文章目录 前言引言开始 前言 为了更好的在项目中&#xff0c;能更加优雅的使用设计模式&#xff0c;比较针对性的解决我们的问题。我将在这个专栏详细的描述23种设计模式&#xff0c;为了与时俱进&#xff0c;我打算通过springboot的形式将23种设计模式全部撸完&#xff01; 引…...

tensorflow实现二分类

# 导入所需库和模块 from tensorflow.keras.layers import Dense, Input, Activation # 导入神经网络层和激活函数模块 from tensorflow.keras.models import Sequential # 导入Keras的Sequential模型 import pandas as pd # 导入Pandas库用于数据处理 import numpy as np …...

简化路径[中等]

优质博文&#xff1a;IT-BLOG-CN 一、题目 给你一个字符串path&#xff0c;表示指向某一文件或目录的Unix风格 绝对路径 &#xff08;以/开头&#xff09;&#xff0c;请你将其转化为更加简洁的规范路径。在Unix风格的文件系统中&#xff0c;一个点.表示当前目录本身&#x…...

eNSP-Cloud(实现本地电脑与eNSP内设备之间通信)

说明&#xff1a; 想象一下&#xff0c;你正在用eNSP搭建一个虚拟的网络世界&#xff0c;里面有虚拟的路由器、交换机、电脑&#xff08;PC&#xff09;等等。这些设备都在你的电脑里面“运行”&#xff0c;它们之间可以互相通信&#xff0c;就像一个封闭的小王国。 但是&#…...

【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)

服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...

P3 QT项目----记事本(3.8)

3.8 记事本项目总结 项目源码 1.main.cpp #include "widget.h" #include <QApplication> int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); } 2.widget.cpp #include "widget.h" #include &q…...

Map相关知识

数据结构 二叉树 二叉树&#xff0c;顾名思义&#xff0c;每个节点最多有两个“叉”&#xff0c;也就是两个子节点&#xff0c;分别是左子 节点和右子节点。不过&#xff0c;二叉树并不要求每个节点都有两个子节点&#xff0c;有的节点只 有左子节点&#xff0c;有的节点只有…...

使用Matplotlib创建炫酷的3D散点图:数据可视化的新维度

文章目录 基础实现代码代码解析进阶技巧1. 自定义点的大小和颜色2. 添加图例和样式美化3. 真实数据应用示例实用技巧与注意事项完整示例(带样式)应用场景在数据科学和可视化领域,三维图形能为我们提供更丰富的数据洞察。本文将手把手教你如何使用Python的Matplotlib库创建引…...

推荐 github 项目:GeminiImageApp(图片生成方向,可以做一定的素材)

推荐 github 项目:GeminiImageApp(图片生成方向&#xff0c;可以做一定的素材) 这个项目能干嘛? 使用 gemini 2.0 的 api 和 google 其他的 api 来做衍生处理 简化和优化了文生图和图生图的行为(我的最主要) 并且有一些目标检测和切割(我用不到) 视频和 imagefx 因为没 a…...

Webpack性能优化:构建速度与体积优化策略

一、构建速度优化 1、​​升级Webpack和Node.js​​ ​​优化效果​​&#xff1a;Webpack 4比Webpack 3构建时间降低60%-98%。​​原因​​&#xff1a; V8引擎优化&#xff08;for of替代forEach、Map/Set替代Object&#xff09;。默认使用更快的md4哈希算法。AST直接从Loa…...

day36-多路IO复用

一、基本概念 &#xff08;服务器多客户端模型&#xff09; 定义&#xff1a;单线程或单进程同时监测若干个文件描述符是否可以执行IO操作的能力 作用&#xff1a;应用程序通常需要处理来自多条事件流中的事件&#xff0c;比如我现在用的电脑&#xff0c;需要同时处理键盘鼠标…...

自然语言处理——文本分类

文本分类 传统机器学习方法文本表示向量空间模型 特征选择文档频率互信息信息增益&#xff08;IG&#xff09; 分类器设计贝叶斯理论&#xff1a;线性判别函数 文本分类性能评估P-R曲线ROC曲线 将文本文档或句子分类为预定义的类或类别&#xff0c; 有单标签多类别文本分类和多…...

C++_哈希表

本篇文章是对C学习的哈希表部分的学习分享 相信一定会对你有所帮助~ 那咱们废话不多说&#xff0c;直接开始吧&#xff01; 一、基础概念 1. 哈希核心思想&#xff1a; 哈希函数的作用&#xff1a;通过此函数建立一个Key与存储位置之间的映射关系。理想目标&#xff1a;实现…...