Solana开发之Anchor框架

文章目录

  • Solana开发之Anchor框架
    • 一、什么是Anchor
    • 二、安装和使用
      • 1. 安装rust
      • 2. 安装Solana
        • 下载预构建的二进制文件
      • 3. 使用 Anchor 版本管理器 (avm) 进行安装(推荐)
    • 四、Anchor 核心原理
      • Anchor 程序由三部分组成
      • 程序的 ID 从哪里来
    • 五、初始化项目、build项目、运行测试用例
      • 初始化项目
      • build项目
      • 测试用例编写
        • 用例demo
      • 运行测试用例
    • 六、本地构建和部署
    • 七、使用Anchor与 Solana 区块链进行交互
      • 使用场景
      • Anchor on the front-end
      • 【推荐】如何使用 Kinobi 创建 Anchor 程序客户端
    • 参考

Solana开发之Anchor框架

大多数 Rust 开发使用的是 Anchor 框架。Anchor 文档指出,开发人员只需要熟悉 Rust 的基础知识(即 Rust Book 的前九章)。

一、什么是Anchor

官网:https://www.anchor-lang.com/

Anchor 是一个功能强大的框架,旨在快速构建安全的 Solana 程序。它通过减少诸如账户(反)序列化和指令数据等领域的样板文件、进行必要的安全检查、自动生成客户端库以及提供广泛的测试环境来简化开发流程。

Anchor 是 Solana 的 Sealevel 运行时的框架,提供了几种方便的开发人员工具来编写智能合约。

二、安装和使用

1. 安装rust

https://www.rust-lang.org/tools/install

在 Rust 开发环境中,所有工具都安装在 ~/.cargo/bin 目录中,您可以在这里找到包括 rustccargorustup 在内的 Rust 工具链。

Rust 开发者通常会将该目录加入 PATH 环境变量中。在安装过程中,rustup 会尝试配置 PATH。 由于不同平台、命令行 Shell 之间存在差异,rustup 中也可能存在 Bug,因此在终端重启或用户重新登录之前,rustup 对 PATH 的修改可能不会生效,甚至完全无效。

如果安装后在终端尝试执行 rustc --version 失败,那么,以上内容就是最可能的原因。

2. 安装Solana

https://docs.solanalabs.com/cli/install

linux、macos:

sh -c "$(curl -sSfL https://release.solana.com/v1.18.17/install)"

Windows:

cmd /c "curl https://release.solana.com/v1.18.17/solana-install-init-x86_64-pc-windows-msvc.exe --output C:\solana-install-tmp\solana-install-init.exe --create-dirs"

复制并粘贴以下命令,然后按 Enter 键安装最新版本的 Solana。如果您看到系统弹出安全窗口,请选择允许程序运行。

C:\solana-install-tmp\solana-install-init.exe v1.18.17

通过运行以下命令确认 solana 您已安装所需的版本:

	solana --version

After a successful install, solana-install update may be used to easily update the Solana software to a newer version at any time.
安装成功后, solana-install update 可用于随时轻松地将 Solana 软件更新到更新版本。

安装使用稳定版本:

sh -c "$(curl -sSfL https://release.solana.com/stable/install)"

使用官方安装命令安装 Solana CLI 工具套件:您可以 stable 替换为与所需版本的软件版本匹配的版本标记(即 v1.18.1 ),或使用以下三个符号通道名称之一: stable 、 beta 或 edge 。

报错:# solana-test-validator
Aborted (core dumped)

尝试运行 solana-test-validator --log 以查看此类输出。您的错误可能依赖于您没有的 CPU AVX2 指令。

# solana-test-validator --log
[2024-07-09T15:55:05.254090404Z INFO  solana_test_validator] solana-validator 1.17.25 (src:d0ed878d; feat:3580551090, client:SolanaLabs)
[2024-07-09T15:55:05.254140535Z INFO  solana_test_validator] Starting validator with: ArgsOs {inner: ["solana-test-validator","--log",],}
[2024-07-09T15:55:05.254172296Z WARN  solana_perf] CUDA is disabled
[2024-07-09T15:55:05.254196077Z INFO  solana_perf] AVX detected
[2024-07-09T15:55:05.254203279Z ERROR solana_perf] Incompatible CPU detected: missing AVX2 support. Please build from source on the target
Aborted (core dumped)
下载预构建的二进制文件

如果您不想使用 solana-install 来管理安装,可以手动下载并安装二进制文件。

通过导航到 https://github.com/solana-labs/solana/releases/latest 下载二进制文件,下载 solana-release-x86_64-unknown-linux-gnu.tar.bz2

tar jxf solana-release-x86_64-unknown-linux-gnu.tar.bz2
cd solana-release/
export PATH=$PWD/bin:$PATH

因为release.solana.com 不太好访问,这里我直接git上自己下载,解压安装。

3. 使用 Anchor 版本管理器 (avm) 进行安装(推荐)

Anchor 版本管理器是用于使用 anchor-cli 多个版本的工具。它需要与从源代码构建相同的依赖关系。如果已安装 NPM 包,建议您卸载它。

使用 Cargo 安装 avm 。请注意,如果您安装了二进制文件,这将替换您的 anchor 二进制文件。

#sudo apt-get install build-essential
cargo install --git https://github.com/coral-xyz/anchor avm --locked --force

使用 avm 安装最新版本的 CLI,然后将其设置为要使用的版本。

avm install latest
avm use latest

验证安装。

anchor --version

最新的默认是0.30.1,我暂时安装使用用anchor 0.29.0,

avm install 0.29.0
avm use 0.29.0

添加 你的安装到bin中

export PATH=/root/.avm/bin:$PATH

四、Anchor 核心原理

Anchor 程序由三部分组成

Anchor 程序由三部分组成: program 模块、标有 #[derive(Accounts)]Accounts 结构和 declare_id 宏。

declare_id! 宏的作用是在 Rust 代码中声明 Solana 程序的唯一标识符(ID)。
这个 ID 在 Solana 网络中是唯一的,用于标识和定位这个程序。它类似于在以太坊中合约的地址

启动新的 Anchor 项目时,你将看到以下内容:

// use this import to gain access to common anchor features
use anchor_lang::prelude::*;// declare an id for your program
declare_id!("Fg6PaFpoGXkYsidMpWTK6W2BeZ7FEfcYkg476zPFsLnS");// write your business logic here
#[program]
mod hello_anchor {use super::*;pub fn initialize(_ctx: Context<Initialize>) -> Result<()> {Ok(())}
}// validate incoming accounts here
#[derive(Accounts)]
pub struct Initialize {}
  • use anchor_lang::prelude:😗;
    这个导入语句引入了 Anchor 框架中常用的特性和类型,例如 Context、Accounts 等。

  • declare_id!("Fg6PaFpoGXkYsidMpWTK6W2BeZ7FEfcYkg476zPFsLnS");
    这个宏声明了当前 Solana 程序的唯一标识符(ID)。
    这个 ID 在 Solana 网络中是唯一的,用于标识和定位这个程序。

  • #[program]
    这个属性宏标记了一个 Rust 模块作为 Solana 程序的入口点。

  • mod hello_anchor { … }
    这个模块包含了程序的业务逻辑实现。

  • #[derive(Accounts)]
    这个属性宏自动为 Initialize 结构体生成一些样板代码,用于验证账户。

这段代码定义了一个基本的 Solana 程序,包含了程序 ID 的声明和一个简单的初始化函数。Anchor 框架通过提供各种宏和结构体,大大简化了 Solana 程序的开发过程,使开发者能够更专注于业务逻辑的实现。

程序的 ID 从哪里来

declare_id! 宏的作用是在 Rust 代码中声明 Solana 程序的唯一标识符(ID)。

这个 ID 在 Solana 网络中是唯一的,用于标识和定位这个程序。它类似于在以太坊中合约的地址。

那么这个 ID 是从哪里来的呢?有几种方式可以获得程序的 ID:

  1. 手动生成:

你可以手动生成一个 32 字节的随机 Pubkey 作为程序的 ID。这种方式适用于开发和测试阶段。
在示例代码中,“Fg6PaFpoGXkYsidMpWTK6W2BeZ7FEfcYkg476zPFsLnS” 就是一个手动生成的 Pubkey 字符串。

  1. 使用 Anchor 的 CLI 工具生成:
    Anchor 提供了一个命令行工具,可以帮助你在部署程序时自动生成程序 ID。
    当你运行 anchor build 命令时,Anchor 会为你的程序生成一个唯一的 ID,并将其写入到 Anchor 项目的配置文件中。

  2. 从 Anchor 项目的配置文件读取:
    如果你的 Solana 程序是使用 Anchor 框架开发的,那么在项目的配置文件(如 Cargo.toml 或 anchor.toml)中会有程序 ID 的定义。
    你可以直接从这个配置文件中读取程序 ID,并在代码中使用 declare_id! 宏进行声明。

程序 ID 的作用都是为了在 Solana 网络中唯一标识你的 Solana 程序。在部署和调用程序时,需要使用这个 ID 来定位和执行程序。

declare_id!宏设置了程序的公钥。对于本地开发,使用anchor init命令设置程序将在target/deploy目录中生成一个密钥对,并填充此宏。

五、初始化项目、build项目、运行测试用例

初始化项目

要初始化一个新项目,只需运行:

anchor init <new-workspace-name>

这将创建一个新的Anchor工作区,以下是文件夹中的一些重要文件:

  • .anchor 文件夹:它包括最新的程序日志和用于测试的本地账本
  • 文件夹 app :一个空文件夹,则可用于保存前端
  • programs 文件夹:此文件夹包含您的程序。它可以包含多个,但最初只包含与 同名的程序。该程序已包含一个 lib.rs 包含一些示例代码的文件。
    programs 文件夹下,你将看到一个src目录。它包含lib.rs
  • 文件夹 tests :包含 E2E 测试的文件夹。它已经包含一个文件,用于测试 中的示例代码。 programs/
  • migrations 文件夹:在此文件夹中,可以保存程序的部署和迁移脚本。
  • 文件 Anchor.toml :此文件为程序配置工作区范围的设置。
    • 您的程序在 localnet 上的地址 ( [programs.localnet] )
    • 一个注册表,你的程序可以被推送到 ( [registry] )
    • 可用于测试的提供程序 ( [provider] )
    • Anchor 执行脚本 ( [scripts] )。 test 脚本在运行 anchor test 时运行。您可以使用 anchor run <script_name> 运行自己的脚本。

build项目

要编译这个程序,我们可以运行 Anchor build 命令:

anchor build

生成完成后,您应该会看到一个名为 target 的新文件夹。

IDL 位于 target/idl/xxx.json , IDL 与 Solidity 中的 ABI(或 GraphQL 中的查询定义)非常相似,我们将在 JavaScript 测试和前端以类似的方式使用它们,通过 RPC 与我们的 Solana 程序进行通信。

测试用例编写

使用 Anchor 调用 Solana 程序, 我们通常需要两件主要事情:

  1. Provider - 是 Provider 与 Solana 网络连接的抽象,通常由 Connection, Wallet, and a preflight commitment组成。

在测试中,Anchor 框架将基于环境 ( anchor.Provider.env() ) 为我们创建提供者,但在客户端上,我们需要使用用户的 Solana 钱包自己构建提供者

  1. program - 这是一个 program 抽象,它结合了 Provider 、 idl 和 ( programID 在构建程序时生成),并允许我们针对我们的程序调用 RPC 方法。

同样,与 Provider 一样,Anchor 提供了一种方便的访问方式 program ,但是在构建前端时,我们需要自己构建它 provider 。

一旦我们有了这两样东西,我们就可以开始在程序中调用函数了。例如,在我们的程序中,我们有一个 initialize 函数。在我们的测试中,您将看到我们可以直接使用以下方法 program.rpc.functionName 调用该函数:

const tx = await program.rpc.initialize();

这是一种非常常见的模式,您在使用 Anchor 时会经常使用,一旦您掌握了了解其工作原理的窍门,就可以非常轻松地连接到 Solana 程序并与之交互。

用例demo

测试用例:

  • 定义了一个名为 “Test mint” 的测试用例。
  • 为一个新的 wallet 账户进行空投,获得 1 SOL。
  • 创建一个新的 asset 账户。
  • 调用 MyNFT 合约的 mint 指令,传入相关的账户信息。
  • 使用 fetchAssetV1fetchCollectionV1 获取刚刚创建的资产和集合信息,并打印出来。

实战demo:

import * as anchor from "@coral-xyz/anchor";
import { Program } from "@coral-xyz/anchor";
import { Mynft } from "../target/types/mynft";
import { createUmi } from "@metaplex-foundation/umi-bundle-defaults";
import {defaultPublicKey,generateSigner,signerIdentity,sol,publicKey,
} from "@metaplex-foundation/umi";
import { toWeb3JsKeypair } from "@metaplex-foundation/umi-web3js-adapters";
import {createCollectionV1,fetchAssetV1,fetchCollectionV1,MPL_CORE_PROGRAM_ID,
} from "@metaplex-foundation/mpl-core";const beneficiary = publicKey("4k7LBNMW3J6gMvEZMy77vZar8h3h3a9Moc8F4xxxxx");describe("mynft", () => {// Configure the client to use the local cluster.anchor.setProvider(anchor.AnchorProvider.env());const program = anchor.workspace.Mynft as Program<Mynft>;const umi = createUmi(anchor.AnchorProvider.env().connection);const payer = generateSigner(umi);umi.use(signerIdentity(payer));const collection = generateSigner(umi);const authority = generateSigner(umi);before(async () => {await umi.rpc.airdrop(payer.publicKey, sol(1));createCollectionV1(umi, {collection,name: "Mynft",uri: "http://mynft.org",updateAuthority: authority.publicKey,}).sendAndConfirm(umi);});it("Test mint", async () => {const wallet = generateSigner(umi);await umi.rpc.airdrop(wallet.publicKey, sol(1.0));const asset = generateSigner(umi);const tx = await program.methods.mint().accounts({coreAsset: asset.publicKey,coreCollection: collection.publicKey,authoriy: authority.publicKey,wallet: wallet.publicKey,beneficiary,mplCore: MPL_CORE_PROGRAM_ID,systemProgram: defaultPublicKey(),}).signers([toWeb3JsKeypair(wallet),toWeb3JsKeypair(asset),toWeb3JsKeypair(authority),]).rpc();const assetInfo = await fetchAssetV1(umi, asset.publicKey);console.log(assetInfo);const collectionInfo = await fetchCollectionV1(umi, collection.publicKey);console.log(collectionInfo);});
});

其中: …/target/types/mynft 为anchor build时候根据idl自动为你生成的typescript文件方便您调用合约方法。

在项目根目录下,运行 anchor test 命令。这会执行 tests 目录下所有的测试用例,包括这个 “Test mint” 用例。
如果你只想运行这个特定的测试用例,可以在 anchor test 命令后添加 -f "Test mint" 参数,这样只会运行名为 “Test mint” 的测试用例。

运行测试用例

现在,我们可以通过运行 test 来测试程序:

anchor test

六、本地构建和部署

官方文档:https://solana.com/developers/guides/getstarted/setup-local-development
参考URL: https://guides.quicknode.com/guides/solana-development/getting-started/start-a-solana-local-validator
参考URL: https://dev.to/edge-and-node/the-complete-guide-to-full-stack-solana-development-with-react-anchor-rust-and-phantom-3291

本地开发环境可以为开发人员提供更受控和高效的开发环境。

首先,我们要确保 Solana 工具套件正确配置为本地开发(Local development)。
运行solana config set --url localhost命令,确保所有配置指向本地主机 URL。

还要确保你有一个本地密钥对(key pair)以与 Solana 进行交互。你必须拥有一个带有 SOL 余额的 Solana 钱包才能使用 Solana CLI 部署程序。

运行solana address命令检查是否已经有本地密钥对。

如果遇到错误,请运行命令:

solana-keygen new -o /root/.config/solana/id.json
solana config set --keypair /root/.config/solana/id.json
solana config get

将在默认情况下在~/.config/solana/id.json路径创建一个新的文件系统钱包。它还会提供一个可用于恢复公钥和私钥的恢复短语。建议保存此密钥对,即使它是在本地使用。

还要注意,如果你已经在默认位置保存了文件系统钱包,solana-keygen new命令将不覆盖它,除非使用**–force**命令指定。

接下来,我们要确保我们的 Anchor.toml 文件正确指向本地主机。

...
[programs.localnet]
hello-world = "EJTW6qsbfya86xeLRQpKLM8qhn11cJXmU35QbJwE11R8"
...
[provider]
cluster = "Localnet"
wallet = '~config/solana/id.json'

配置项目的程序id,如这里的"EJTW6qsbfya86xeLRQpKLM8qhn11cJXmU35QbJwE11R8"
程序 ID 是公开的。但它的密钥对存储在 target/deploy 文件夹中。它遵循基于程序名称的特定命名约定。例如,如果程序名为 hello_world,Anchor 将在 target/deploy/hello-world-keypair.json 中寻找密钥对。

如果在部署过程中找不到该文件,Anchor 将生成一个新的密钥对,这将生成新的程序 ID。

因此,在第一次部署后更新程序 ID 至关重要。hello-world-keypair.json 文件用作程序所有权的证明。如果密钥对泄露,恶意行为者可以对程序进行未经授权的更改。

通过 [provider],我们告诉 Anchor 使用 本地主机 和指定的钱包来支付存储和交易费用

确保 [provider] 部分的 cluster 参数设置为 “Localnet”。这表示你是在本地运行 Solana 节点进行部署和测试。

Solana CLI 自带一个测试验证器 。运行 solana-test-validator 命令 将在你的工作站上启动一个功能齐全的单节点集群。这对许多原因都很有益,例如没有 RPC 速率限制、没有空投限制、直接在链上部署程序、从文件加载账户以及从公共集群克隆账户。测试验证器必须在单独的打开的终端窗口中运行,并保持运行,以使本地主机集群保持在线并可供交互。

在启动 solana-test-validator 时,你可以使用参数来指定 RPC 服务监听的 IP 地址。
例如,如果你想让 RPC 服务监听在 0.0.0.0 上,而不是默认的 127.0.0.1,可以使用以下命令:

solana-test-validator --bind-address 0.0.0.0 --rpc-port 8899

现在,我们可以成功运行 anchor deploy 来将程序部署到我们的本地ledger。传输到本地 ledger 的任何数据都将保存在当前工作目录中生成的 test-ledger 文件夹中。建议将此文件夹添加到你的 .gitignore 文件中,以避免将此文件夹提交到你的存储库中。此外,退出本地 ledger(即在终端中按下 Ctrl + C)不会删除发送到集群的任何数据。您可以

solana-test-validator --reset

这将清空本地数据目录并重新初始化节点。

Solana Explorer
开发者还可以将 Solana Explorer 配置为他们的本地ledger。转到 Solana Explorer。在导航栏中,单击当前集群状态的绿色按钮:

这将打开一个侧边栏,允许你选择一个集群。单击 Custom RPC URL。这应该自动填充为 http://localhost:8899 。如果没有,请填写,以便将区块浏览器指向你的机器的 8899 端口:

配置本地区块链浏览器有几个非常重要原因:

  • 它允许开发者实时检查本地ledger上的交易,就像他们通常在分析 devnet 或 mainnet 的区块浏览器上所具有的功能
  • 更容易可视化账户、代币和程序的状态,就像它们在实时集群上运行一样
  • 它提供了有关错误和交易失败的详细信息
  • 它提供了一致的开发体验,因为它是一个熟悉的界面
solana balance
solana address
solana airdrop 100

从你提供的 solana config get 输出结果来看,你的 Solana 客户端配置指向的是 Solana 主网,而不是本地测试网。

使用 solana config set --url http://localhost:8899 命令将 RPC URL 设置为本地测试节点的地址。

使用 solana config get 命令再次检查配置,确认 RPC URL 已经正确设置。

netstat -an |findstr 8899
TCP 127.0.0.1:54115 127.0.0.1:8899 TIME_WAIT

七、使用Anchor与 Solana 区块链进行交互

使用场景

在 Node.js 环境下使用 Anchor 来与 Solana 区块链进行交互是非常常见的场景。

  • 测试环境
    在开发和测试阶段,你可以使用 anchor.setProvider(anchor.AnchorProvider.env()) 来连接到本地的 Solana 开发集群。这样可以快速进行开发和测试。

  • 生产环境
    当你准备将应用部署到生产环境时,你可以配置 Anchor 客户端连接到 Solana 主网。

如果你的项目中涉及到通过 IDL 和合约进行交互,我建议你优先考虑使用 Anchor,它可以为你提供更加完整和高效的开发体验。

Anchor on the front-end

官方ts文档:https://coral-xyz.github.io/anchor/ts/index.html
参考原文链接:https://creatorsdao.github.io/solana-co-learn/Solana-Co-Learn/module5/anchor-on-the-front-end/anchor-into-typescript/

Program 对象提供了一个自定义的 API,通过结合程序 IDL 和 Provider 来与特定程序进行交互。

创建 Program 对象,我们需要以下内容:

  • Connection - 集群连接
  • Wallet - 用于支付和签署交易的默认密钥对
  • Provider - 将 Connection 和 Wallet 封装到一个 Solana 集群中
  • IDL - 表示程序结构的文件

Provider 对象代表了两个主要部分的结合:

  • Connection - 连接到 Solana 集群(例如 localhost、devnet、mainnet)
  • Wallet - 用于支付和签署交易的指定地址
    Provider 就能够代表 Wallet 向 Solana 区块链发送交易,并在发送的交易中加入钱包的签名。

创建一个 Program 对象,代表了以下两个事物的组合:

  • IDL:展示了程序的结构。
  • Provider:负责与集群建立连接并签署 Wallet 的 Connection。

你需要导入程序的 IDL,并明确指定programId,这个programId通常会包含在IDL中,当然也可以单独声明。

【推荐】如何使用 Kinobi 创建 Anchor 程序客户端

原文链接: https://learnblockchain.cn/article/8639

为测试验证,暂时不需要。

参考

[推荐]指南:用 Anchor 构建 Solana 程序
参考URL: https://learnblockchain.cn/article/7386

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

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

相关文章

基于java+springboot+vue实现的大学城水电管理系统(文末源码+Lw)106

基于SpringBootVue的实现的大学城水电管理系统&#xff08;源码数据库万字Lun文流程图ER图结构图演示视频软件包&#xff09; 系统功能&#xff1a; 本大学城水电管理系统 管理员功能有个人中心&#xff0c;用户管理&#xff0c;领用设备管理&#xff0c;消耗设备管理&#x…

AV1编码标准中块分区技术详细说明

libaom 开放媒体联盟视频1&#xff08;AV1&#xff09;编解码器的框架基于一种混合视频编码结构&#xff0c;由几个主要的功能模块组成&#xff0c;如预测、变换、量化、熵编码和环路滤波。每个功能模块使用特定类型的视频编码技术处理输入数据&#xff0c;其输出被送入另一个功…

科研绘图系列:R语言金字塔图(pyramid plot)

介绍 金字塔图(Pyramid chart)是一种用于展示人口统计数据的图表,特别是用于展示不同年龄段的人口数量。这种图表通常用于展示人口结构,比如性别和年龄的分布。 特点: 年龄分层:金字塔图按年龄分层,每一层代表一个年龄组。性别区分:通常,男性和女性的数据会被分别展…

FiddlerScript Rules修改-更改发包中的cookie

直接在fiddler script editor中增加如下处理代码即可 推荐文档oSession -- 参数说明 测试笔记 看云

fork的理解

一. 注意点 1.进程是并发的&#xff0c;主进程和子进程同时进行&#xff0c;效率高2.子进程产生时是完全复制主进程的状态的&#xff0c;只有在产生修改的时候才会单独分配资源。 二. 下面程序一共应该为8个进程&#xff0c;但code的终端看到只有7个进程号的原因。因为fork返…

FastAPI 学习之路(四十一)定制返回Response

接口中返回xml格式内容 from fastapi import FastAPI, Responseapp FastAPI()# ① xml app.get("/legacy") def get_legacy_data():data """<?xml version"1.0"?><shampoo><Header>Apply shampoo here.</Header&…

【Linux】管道命令

命令执行的时候有时会输出数据&#xff0c;有的命令输出的数据太繁杂了。 那么我们怎么去筛选这些信息来得到我们所想要的格式&#xff1f; 这就牵涉到管道命令的问题了&#xff08;pipe&#xff09;&#xff0c;管道命令使用的是【|】这个界定符号。另外&#xff0c;管道命令与…

centos 安装ffmpeg

这个错误表明在你的 CentOS 系统的默认仓库中没有 ffmpeg 包。CentOS 的默认仓库通常不包含 ffmpeg&#xff0c;因为它涉及一些许可证问题。但是&#xff0c;你可以通过添加第三方仓库来安装 ffmpeg。 使用 EPEL 和 RPM Fusion 仓库 # 安装 EPEL 仓库 sudo yum install epel-…

编程师适合看什么书:深入探索编程领域的知识宝库

编程师适合看什么书&#xff1a;深入探索编程领域的知识宝库 在编程领域&#xff0c;不断学习是提升技能的关键。选择合适的书籍&#xff0c;对于编程师来说&#xff0c;不仅能够拓宽视野&#xff0c;还能深入掌握各种技术细节。那么&#xff0c;编程师适合看什么书呢&#xf…

引用常用用法

1. 通过传递引用&#xff0c;修改原始变量的值 struct UpdateItem { std::string id; // Unique identifier for the record std::string userId; // Users ID std::string userName; // Users name std::string userDept; // Users department }; int getmessade() { std::ve…

ES6 async 函数详解 (十)

async 函数是什么&#xff1f;一句话&#xff0c;它就是 Generator 函数的语法糖。 const gen function* () {const f1 yield readFile(/etc/fstab);const f2 yield readFile(/etc/shells);console.log(f1.toString());console.log(f2.toString()); };const asyncReadFile …

项目管理工具评测:2024年国内外最顶级的10款项目管理工具排行

国内外涌现出众多优秀的项目管理工具&#xff0c;它们各自在功能、易用性、集成能力等方面展现出独特优势。以下是国内外顶级的10款项目管理工具&#xff1a; 一、进度猫 推荐理由&#xff1a;进度猫以其直观的任务管理和进度跟踪功能&#xff0c;成为许多团队和项目的首选…

MybatisPlus 使用教程

MyBatisPlus使用教程 文章目录 MyBatisPlus使用教程1、使用方式1.1 引入依赖1.2 构建mapper接口 2、常用注解2.1 TableName2.2 TableId2.3 TableField MyBatisPlus顾名思义便是对MyBatis的加强版&#xff0c;但两者本身并不冲突(只做增强不做改变)&#xff1a; 引入它并不会对原…

老年实训室的技能大赛介绍

在当今老龄化社会的背景下&#xff0c;老年护理和服务的质量愈发受到关注。为了提升相关人员的专业技能和服务水平&#xff0c;老年实训室的技能大赛应运而生。 老年实训室的技能大赛通常涵盖了多个方面的考核内容&#xff0c;旨在全面检验参赛者在老年护理与服务领域的综合能力…

ES6 Iterator 与 for...of 循环(五)

Iterator 特性&#xff1a; 统一的接口&#xff1a;无论是数组、字符串还是自定义对象&#xff0c;只要它们有默认的迭代器&#xff0c;就可以使用 for…of 循环进行遍历。可迭代对象&#xff1a;具有 [Symbol.iterator] 属性的对象被认为是可迭代的。[Symbol.iterator] 是一个…

FastAPI 学习之路(三十九)对开发接口进行测试

概况 对于开发好的接口需要进行测试之后才能发布。当我们在开发的时候&#xff0c;没有提前测试&#xff0c;我们也要对我们自己的接口进行测试&#xff0c;那么FastApi自身也带有针对开发的接口进行测试的功能。我们看下FastApi官方给我们提供了什么样的支持。 接口还是基于…

笔记本硬盘数据恢复的6种方法!简单易懂

可以从笔记本电脑硬盘恢复已删除的数据吗&#xff1f; “我不小心删除了笔记本电脑硬盘上的重要数据。请问我可以在笔记本电脑硬盘上恢复已删除的数据吗&#xff1f;如果可以&#xff0c;我应该怎么做才能恢复数据呢&#xff1f;” 很多笔记本电脑用户可能会不小心地从电脑中…

线程冲突案例演示

我们以银行取款经典案例来演示线程冲突现象。 银行取款的基本流程可以分为如下几个步骤。 &#xff08;1&#xff09;用户输入账户、密码&#xff0c;系统判断用户的账户、密码是否匹配。 &#xff08;2&#xff09;用户输入取款金额。 &#xff08;3&#xff09;系统判断账…

JavaSE 面向对象程序设计进阶 IO 练习读取多个对象

练习读取多个对象 用序列化流将对象写入文件 import java.io.*; import java.nio.charset.Charset;public class Main {public static void main(String[] args) throws IOException, ClassNotFoundException {//序列化多个对象Person p1new Person("多多", 男,20)…

梧桐数据库:数据库产品中的自然语言语义分析技术

数据库产品中的自然语言语义分析技术是一项重要的自然语言处理技术&#xff0c;它涉及对自然语言文本进行深度理解和分析&#xff0c;从而识别文本中的实体、关系、情感等语义信息&#xff0c;并将这些信息转化为计算机可以理解和处理的形式。 一、自然语言语义分析技术的定义…