首页 > 其他分享 >什么是Sparse by default for crates.io

什么是Sparse by default for crates.io

时间:2023-06-13 20:56:57浏览次数:49  
标签:serde 依赖 default crate 开启 crates json io

当 Rust crate 发布到 crates.io 上时,可以启用“Sparse by default”特性,这意味着默认情况下,crate 不会包含所有依赖项在上传到 crates.io 的最终包中。相反,它只会包含必要的直接依赖项来使 crate 正常运行。

这个特性对于减少 crate 的大小和用户需要下载和安装的依赖项数量非常有用。然而,如果 crate 依赖于未包含的间接依赖项,或者间接依赖项具有冲突的版本,则可能会出现问题。

为了减轻这些问题,启用“Sparse by default”特性的 crate 通常会包含一个 Cargo.toml 文件,该文件指定了 crate 每个可选特性所需的依赖项。 crate 的用户可以启用这些特性来包含所需的依赖项,或者手动将所需的依赖项添加到其项目的 Cargo.toml 文件中。

总之,“Sparse by default”特性是 Rust crate 中的一个有用的优化,但需要仔细管理依赖项,以确保 crate 保持功能和易用性。

当一个 crate 启用了 "sparse by default" 特性时,使用这个 crate 的开发者需要注意以下几点:

  1. 需要查看 crate 的 Cargo.toml 文件,看看哪些功能需要手动开启依赖项。一些功能可能需要开启多个依赖项,所以需要仔细阅读说明文档。

  2. 如果使用了不开启依赖项的功能,将会出现编译错误或者运行时错误。这时需要回到第一步,查看哪些依赖项需要开启。

  3. 如果使用了一个依赖项的不同版本,可能会出现冲突。这时需要手动指定正确的版本号,或者尝试升级或降级依赖项的版本。

下面是一个具体的例子:假设一个 crate 需要使用 serde_json 库来解析 JSON 数据。在 crate 的 Cargo.toml 文件中,可以看到以下代码:

[dependencies]
serde_json = { version = "1.0", optional = true }

这里指定 serde_json 为可选依赖项,如果需要解析 JSON 数据,则需要手动开启该依赖项。在使用 crate 的代码中,可以这样来开启依赖项:

// 在代码开头引入依赖项
#[cfg(feature = "serde_json")]
use serde_json;

// 在使用时判断依赖项是否开启
#[cfg(feature = "serde_json")]
{
    let data = "{\"name\": \"Alice\", \"age\": 30}";
    let parsed = serde_json::from_str(data).unwrap();
    // ...
}

在这个例子中,crate 的使用者需要手动开启 serde_json 依赖项,并使用 #[cfg(feature = "serde_json")] 来判断是否开启了该依赖项。如果没有开启该依赖项,则解析 JSON 数据的代码块将会被忽略。

这里的本地仓库有一个参考的例子: https://github.com/DaviRain-Su/all-in-one-rust/tree/main/sparse-by-default-cratesio

Rust crate 中 "sparse by default" 特性的例子:

  1. hyper crate:一个 HTTP 库,在默认情况下仅包含核心库和少量依赖项。如果需要使用 HTTPS 或其他功能,则需要手动开启依赖项,例如:
[dependencies]
hyper = { version = "0.14", features = ["http1", "http2", "openssl"] }

这里开启了 http1http2 和 openssl 依赖项来支持 HTTP/1.1、HTTP/2 和 HTTPS。

  1. reqwest crate:一个 HTTP 客户端库,也是一个 "sparse by default" 的 crate。默认情况下仅包含核心库和少量依赖项。如果需要使用 HTTPS 或其他功能,则需要手动开启依赖项,例如:
[dependencies]
reqwest = { version = "0.11", features = ["blocking", "json", "tls"] }

这里开启了 blockingjson 和 tls 依赖项来支持同步请求、JSON 解析和 HTTPS。

  1. actix-web crate:一个 Web 框架,也是一个 "sparse by default" 的 crate。默认情况下仅包含核心库和少量依赖项。如果需要使用 HTTPS、WebSocket 或其他功能,则需要手动开启依赖项,例如:
[dependencies]
actix-web = { version = "3.3", features = ["ssl", "ws"] }
 

这里开启了 ssl 和 ws 依赖项来支持 HTTPS 和 WebSocket。

总之,"sparse by default" 特性可以让 Rust crate 的核心部分保持轻量级和高效,同时也提供了灵活性来添加需要的功能。但是,使用这些 crate 的开发者需要留意依赖项的管理,以确保 crate 的正确性和可用性。

在Rust的1.70.0版本也有提到这个特性: https://blog.rust-lang.org/2023/06/01/Rust-1.70.0.html

   

标签:serde,依赖,default,crate,开启,crates,json,io
From: https://www.cnblogs.com/Davirain/p/17478697.html

相关文章

  • Java反序列化之Commons-Collection篇05-CC2链
    <1>环境分析jdk:jdk8u65CC:Commons-Collections4.0pom.xml添加<dependency><groupId>org.apache.commons</groupId><artifactId>commons-collections4</artifactId><version>4.0</version></dependency&g......
  • 【Azure 应用服务】Azure Data Factory中调用Function App遇见403 - Forbidden
    问题描述在AzureDataFactory(数据工厂)中,调用同在Azure中的FunctionApp函数,却出现403-Forbidden错误。截图如下:  问题解答访问AzureFunctionApp遇见403-Forbidden错误,这是因为FunctionApp启用了限制访问功能,在其中配置了允许访问的IP地址列表,而从ADF中发出的请求使用的I......
  • Educational Codeforces Round 150 (Rated for Div. 2) 题解
    https://codeforces.com/contest/1841https://codeforces.com/contest/1841/problemsD.PairsofSegmentshttps://codeforces.com/contest/1841/problem/D因为\(n\)只有\(2000\),所以考虑枚举每一对\((i,j)\)满足区间有交集并且\(i\neqj\)。如果有交集,就合并。然后......
  • 【Azure 应用服务】Azure Data Factory中调用Function App遇见403 - Forbidden
    问题描述在AzureDataFactory(数据工厂)中,调用同在Azure中的FunctionApp函数,却出现403-Forbidden错误。截图如下:  问题解答访问AzureFunctionApp遇见403-Forbidden错误,这是因为FunctionApp启用了限制访问功能,在其中配置了允许访问的IP地址列表,而从ADF中发出的请......
  • Java中@Transactional 注解使用注意事项
    隔离级别关键词原子性(Atomicity):事务是数据库的逻辑工作单位,它对数据库的修改要么全部执行,要么全部不执行。一致性(Consistemcy):事务前后,数据库的状态都满足所有的完整性约束。隔离性(Isolation):并发执行的事务是隔离的,一个不影响一个。如果有两个事务,......
  • 解决 This is probably not a problem with npm. There is likely additional logging
    在执行npmrunserve运行项目的时候报错:dengzemiaodeMacBook-Pro:lianshan_vuedengzemiao$npmrunserve......npmERR!codeELIFECYCLEnpmERR!errno1npmERR!lianshan@2.0.0serve:`vue-cli-serviceserve`npmERR!Exitstatus1npmERR!npmERR!Failedatthelia......
  • IO_File_01
    Test01创建importjava.io.File;/*常用构造方法File(Stringpathname)通过将给定的路径名字符串转换为抽象路径名来创建新的File实例。File(Stringparent,Stringchild)从父路径名字符串和子路径名字符串创建新的File实例。File(Fileparent,Str......
  • React Native In Action中的demo的运行
     我用了最新的xcode和新的reactnative。Chapter6: Navigation这一章中的事例跑不起来,应该是程序用了就的版本的reactnavigation("react-navigation":"^2.0.1"),同时关于Navigation的用法也做了不小的改动,因此需要重新看相关文档改写。参考:https://reactnavigation.org/docs......
  • windows下使用minio搭建s3存储,使用laravel和postman进行测试
    1、下载服务端https://dl.min.io/server/minio/release/windows-amd64/minio.exe2、启动服务minio.exeserverd:\data\minio--console-address:9090 可以看到上面有两块ip,分别是9000和9000端口,其中9090是后台管理端地址的端口,9000是前台接口端口3、创建bucket4......
  • go调用minio上传文件
    1packagemain23import(4"context"5"fmt"6"log"7"os"89"github.com/minio/minio-go/v7"10"github.com/minio/minio-go/v7/pkg/credentials"11)1213......