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

C语言函数大全-- x 开头的函数(3)

C语言函数大全

本篇介绍C语言函数大全-- x 开头的函数

1. xdr_opaque

1.1 函数说明

函数声明函数功能
bool_t xdr_opaque(XDR *xdrs, char *buf, u_int len);用于编码或解码任意长度的二进制数据

参数:

  • xdrs : 指向 XDR 数据结构的指针,表示要进行编码或解码的数据流
  • buf : 指向待编码或解码的二进制数据的指针
  • len : 待编码或解码的二进制数据的长度(以字节为单位)

返回值:

  • 如果编码或解码成功,则返回值为 TRUE
  • 否则返回值为 FALSE

1.2 演示示例

#include <stdio.h>
#include <stdlib.h>
#include <rpc/xdr.h>int main() 
{// 编码数据char data[] = "hello, world!";XDR xdr;xdrmem_create(&xdr, NULL, 0, XDR_ENCODE);if (!xdr_opaque(&xdr, data, sizeof(data))) {printf("Error: failed to encode data.\n");exit(EXIT_FAILURE);}// 获取编码后的数据并打印char *encoded_data = malloc(xdr_getpos(&xdr));xdrmem_create(&xdr, encoded_data, xdr_getpos(&xdr), XDR_DECODE);printf("Encoded data: ");for (int i = 0; i < xdr_getpos(&xdr); ++i) {printf("%02x ", encoded_data[i]);}printf("\n");// 解码数据char decoded_data[sizeof(data)];if (!xdr_opaque(&xdr, decoded_data, sizeof(decoded_data))) {printf("Error: failed to decode data.\n");exit(EXIT_FAILURE);}printf("Decoded data: %s\n", decoded_data);return 0;
}

在上面的示例代码中,

  • 首先,我们定义了一个字符串 "hello, world!" 作为将要编码的数据,并创建了一个 XDR 结构体;
  • 然后,调用 xdrmem_create() 函数初始化 XDR 结构体,使其可以从内存中读取和写入数据;
  • 接着,使用 xdr_opaque() 函数对字符串进行编码,将其转换为 XDR 格式;
  • 再然后,获取编码后的数据并打印;其中,
    • 我们先使用 xdr_getpos() 函数获取已编码数据的长度;
    • 然后再使用 xdrmem_create() 函数创建一个新的 XDR 结构体来解码它;
    • 最后,利用循环遍历编码后的数据并以十六进制形式打印出来。
  • 再接着,使用 xdr_opaque() 函数对编码后的数据进行解码;
  • 最后,打印解码后的数据。

2. xdr_opaque_auth

2.1 函数说明

函数声明函数功能
bool_t xdr_opaque_auth(XDR *xdrs, struct opaque_auth *ap);用于编码或解码 认证信息

参数:

  • xdrs : 指向 XDR 结构体的指针,用于指定编解码的上下文
  • ap : 指向 opaque_auth 结构体的指针,用于指定认证信息

返回值:

  • 如果编码或解码成功,则返回值为 TRUE
  • 否则返回值为 FALSE

2.2 演示示例

2.2.1 opaque_auth
// 定义在 <rpc/auth.h>
struct opaque_auth {int oa_flavor;   // 认证方式(authentication flavor)caddr_t oa_base; // 不透明数据u_int oa_length; // 数据长度
};
2.2.2 test.c
#include <stdio.h>
#include <stdlib.h>
#include <rpc/xdr.h>
#include <rpc/auth.h>int main() 
{// 编码数据struct opaque_auth auth;auth.oa_flavor = AUTH_NONE;auth.oa_base = NULL;auth.oa_length = 0;XDR xdr;xdrmem_create(&xdr, NULL, 0, XDR_ENCODE);if (!xdr_opaque_auth(&xdr, &auth)) {printf("Error: failed to encode authentication information.\n");exit(EXIT_FAILURE);}// 获取编码后的数据并打印char *encoded_data = malloc(xdr_getpos(&xdr));xdrmem_create(&xdr, encoded_data, xdr_getpos(&xdr), XDR_DECODE);printf("Encoded data: ");for (int i = 0; i < xdr_getpos(&xdr); ++i) {printf("%02x ", encoded_data[i]);}printf("\n");// 解码认证信息struct opaque_auth decoded_auth;xdrmem_create(&xdr, encoded_data, xdr_getpos(&xdr), XDR_DECODE);if (!xdr_opaque_auth(&xdr, &decoded_auth)) {printf("Error: failed to decode authentication information.\n");exit(EXIT_FAILURE);}// 打印解码后的认证信息printf("Decoded authentication information:\n");printf("oa_flavor = %d\n", decoded_auth.oa_flavor);printf("oa_length = %u\n", decoded_auth.oa_length);return 0;
}

在上面的这个示例中,

  • 首先,我们创建一个 opaque_auth 结构体,并将其中的成员变量初始化。

注意: 由于使用的认证方式是 AUTH_NONE,也就是不需要任何认证信息;所以,oa_length 成员变量被设置为 0。在实际开发中,我们可能需要使用其他的认证方式,并相应地设置 opaque_auth 结构体的成员变量。】

  • 然后,使用 xdrmem_create() 函数创建一个 XDR 结构体,并将其指定为编码模式。

  • 接着,调用 xdr_opaque_auth() 函数对认证信息进行编码,并获取编码后的数据并打印出来【这里同 1.2 中,不再赘述】。

  • 再然后,使用 xdrmem_create() 函数创建一个新的 XDR 结构体,并将其指定为解码模式。

  • 再接着,调用 xdr_opaque_auth() 函数对编码后的认证信息进行解码,并通过访问 opaque_auth 结构体的成员变量来获取解码后的认证信息。

  • 最后,打印解码后的认证信息。

3. xdr_pointer

3.1 函数说明

函数声明函数功能
bool_t xdr_pointer(XDR *xdrs, char **objpp, u_int obj_size, xdrproc_t xdr_obj)用于编码和解码指针类型的数据

参数:

  • xdrs : 指向要编码或解码数据的 XDR 结构体的指针
  • objpp : 要编码或解码的数据的地址
  • obj_size : 要编码或解码的数据的大小(以字节为单位)
  • xdr_obj : 用于编码或解码指针所指向的数据

返回值:

  • 如果编码或解码成功,则返回值为 TRUE
  • 否则返回值为 FALSE

关于 xdr_pointer() 函数的使用,参考如下:

  • 对于编码操作,xdr_pointer() 函数将指针 objpp 所指向的数据编码到 XDR 流中。如果 objpp 为 NULL,则写入一个特殊的标志来表示空指针。如果 objpp 不为 NULL,则先写入一个非零值来表示非空指针,然后调用指定的 XDR 编码程序对数据进行编码。

  • 对于解码操作,xdr_pointer() 函数从 XDR 流中读取一些字节,并根据这些字节创建一个新的数据对象。如果读取的字节表示一个空指针,则将 objpp 设置为 NULL。否则,将 objpp 设置为一个指向新对象的指针,并调用指定的 XDR 编码程序对数据进行解码。

3.2 演示示例

#include <stdio.h>
#include <rpc/xdr.h>int main() 
{char buffer[1024];XDR xdrs;xdrmem_create(&xdr, buffer, sizeof(buffer), XDR_ENCODE); // 创建 XDR 流// 将指针编码为 XDR 流中的整数int pointer_value = 42;xdr_pointer(&xdrs, (char **)&pointer_value, sizeof(int), (xdrproc_t)xdr_int);// 打印编码后的值printf("Encoded value: %d\n", pointer_value);// 解码整数,还原指针xdr_setpos(&xdrs, 0);xdr_pointer(&xdrs, (char **)&pointer_value, sizeof(int), (xdrproc_t)xdr_int);// 打印解码后的指针值printf("Decoded value: %d\n", pointer_value);// 关闭流xdr_destroy(&xdrs);return 0;
}

在上面的示例代码中,

  • 首先,我们创建了一个 XDR 流对象 xdrs,并将其绑定到 buffer 数组上;
  • 然后,使用 xdr_pointer() 函数将 整数指针 pointer_value 写入流中;并输出 pointer_value 的值,这是编码后的整数;
  • 再接着,使用 xdr_setpos() 函数将 XDR 流的位置设置为 0
  • 再然后,使用 xdr_pointer() 函数从 XDR 流中解码整数值,并将其存储回 pointer_value 变量中;并输出 pointer_value 的值,这是解码后的整数指针;
  • 最后,使用 xdr_destroy() 函数关闭并释放 XDR 流对象,并结束程序。

4. xdr_replymsg

4.1 函数说明

函数声明函数功能
bool_t xdr_replymsg(XDR *xdrs, struct rpc_msg *msg);用于编码或解码应答消息

参数:

  • xdrs : 指向要编码或解码数据的 XDR 结构体的指针
  • msg : 指向要编码或解码的枚举类型数据的指针

返回值:

  • 如果编码或解码成功,则返回值为 TRUE
  • 否则返回值为 FALSE

在使用 xdr_replymsg() 函数之前,需要设置好 rpc_msg 结构体中的各个字段。rpc_msg 结构体用于表示 RPC 消息,其中包括以下字段:

  • uint32_t xid :表示此消息的标识符。
  • enum msg_type msg_type :表示消息类型,可以是 CALLREPLY
  • union rpc_body :表示 RPC 的主体部分,包括:
    • call_body :表示 CALL 消息的主体部分,包括 RPC 的程序号、版本号和过程号,以及传递给该过程的参数。
    • reply_body :表示 REPLY 消息的主体部分,包括返回值和可能的错误信息。

4.2 演示示例

#include <stdio.h>
#include <stdlib.h>
#include <rpc/xdr.h>int main() 
{// 创建 XDR 流对象char buffer[1024];XDR xdrs;xdrmem_create(&xdrs, buffer, sizeof(buffer), XDR_ENCODE);// 设置 rpc_msg 结构体struct rpc_msg msg = {.xid = 12345, .msg_type = REPLY};msg.acpted_rply.ar_verf = AUTH_NULL;msg.acpted_rply.ar_results.where = (char *)"Success";msg.acpted_rply.ar_results.proc = (xdrproc_t)xdr_string;// 编码应答消息if (!xdr_replymsg(&xdrs, &msg)) {fprintf(stderr, "Failed to encode reply message\n");return 1;}// 打印编码后的结果printf("Encoded message: ");for (int i = 0; i < xdr_getpos(&xdrs); i++) {printf("%02x", buffer[i] & 0xff);}printf("\n");// 解码应答消息struct rpc_msg decoded_msg;if (!xdr_replymsg(&xdrs, &decoded_msg)) {fprintf(stderr, "Failed to decode reply message\n");return 1;}// 打印解码后的结果printf("Decoded message:\n");printf("XID: %d\n", decoded_msg.xid);printf("Message Type: %d\n", decoded_msg.msg_type);printf("Verf Flavor: %d\n", decoded_msg.acpted_rply.ar_verf.oa_flavor);printf("Verf Length: %d\n", decoded_msg.acpted_rply.ar_verf.oa_length);printf("Result:\n");char *result;if (!xdr_string(&xdrs, &result, sizeof(result))) {fprintf(stderr, "Failed to decode result string\n");return 1;}printf("%s\n", result);return 0;
}

在上面的这个示例程序中,

  • 首先,创建一个 XDR 流对象,并设置一个包含所需信息的 rpc_msg 结构体。
  • 接着,使用 xdr_replymsg() 函数将 rpc_msg 结构体编码为 XDR 格式。如果编码失败,则输出错误并退出程序。
  • 然后,打印编码后的结果,以便查看序列化的数据。
  • 再接着,使用 xdr_replymsg() 函数将编码后的数据解码回 rpc_msg 结构体。如果解码失败,则输出错误并退出程序。
  • 再然后,打印解码后的结果,包括事务 ID、消息类型、验证标志、结果等信息;
  • 最后,程序正常退出。

5. xdr_reference

5.1 函数说明

函数声明函数功能
bool_t xdr_reference(XDR *xdrs, char **objp, u_int obj_size, xdrproc_t xdr_func);用于编码或解码一个指向某个对象的引用

参数:

  • xdrs : 指向要编码或解码数据的 XDR 结构体的指针
  • objp : 指向要编码或解码的某个指针对象的引用
  • obj_size : 引用的指针对象的大小
  • xdr_func : 指向 XDR 函数的指针,用于编码或解码 objp 所指向的数据对象

返回值:

  • 如果编码或解码成功,则返回值为 TRUE
  • 否则返回值为 FALSE

5.2 演示示例

#include <stdio.h>
#include <stdlib.h>
#include <rpc/xdr.h>int main() 
{// 创建 XDR 流对象char buffer[1024];XDR xdrs;xdrmem_create(&xdrs, buffer, sizeof(buffer), XDR_ENCODE);// 设置字符串指针char *str = "Hello, world!";// 编码字符串指针if (!xdr_reference(&xdrs, &str, strlen(str) + 1, (xdrproc_t)xdr_string)) {fprintf(stderr, "Failed to encode string reference\n");return EXIT_FAILURE;}// 打印编码后的结果printf("Encoded message: ");for (int i = 0; i < xdr_getpos(&xdrs); i++) {printf("%02x", buffer[i] & 0xff);}printf("\n");// 创建一个新的 XDR 流对象,并反序列化字符串指针XDR new_xdrs;xdrmem_create(&new_xdrs, buffer, sizeof(buffer), XDR_DECODE);char *decoded_str = NULL;if (!xdr_reference(&new_xdrs, &decoded_str, strlen(str) + 1, (xdrproc_t)xdr_string)) {fprintf(stderr, "Failed to decode string reference\n");return EXIT_FAILURE;}// 打印解码后的结果printf("Decoded message: %s\n", decoded_str);return EXIT_SUCCESS;
}

在上面的示例代码中,

  • 首先,我们调用 xdrmem_create() 函数创建了一个 XDR 流对象 xdrs,并和 buffer 绑定;
  • 然后,定义了一个字符串指针 str 并初始化为 "Hello, world!"
  • 接着,调用 xdr_reference() 函数对 str 进行编码,并将结果存储到 buffer 中。如果编码成功,则打印出编码后的消息;
  • 再接着,调用 xdrmem_create() 函数创建了一个新的 XDR 流对象 new_xdrs ,并和 buffer 绑定;
  • 再然后,调用 xdr_reference() 函数解码 decoded_str,并从 new_xdrs 对象中读取编码数据。如果解码成功,则打印出解码后的消息。
  • 最后,程序正常退出。

6. xdr_rpc_gss_data

6.1 函数说明

函数声明函数功能
bool_t xdr_rpc_gss_data(XDR * xdrs, rpc_gss_data * gd);用于编码或解码 RPC GSS 数据

参数:

  • xdrs : 指向要编码或解码数据的 XDR 结构体的指针
  • gd : 指向 rpc_gss_data 结构体的指针

返回值:

  • 如果编码或解码成功,则返回值为 TRUE
  • 否则返回值为 FALSE

6.2 演示示例

#include <stdio.h>
#include <stdlib.h>
#include <rpc/rpc.h>
#include <rpc/auth_gss.h>int main()
{rpc_gss_data gd;XDR xdr;char buffer[1024];bool_t status;memset(&gd, 0, sizeof(gd));memset(&xdr, 0, sizeof(xdr));xdrmem_create(&xdr, buffer, sizeof(buffer), XDR_ENCODE);status = xdr_rpc_gss_data(&xdr, &gd);if (!status) {fprintf(stderr, "Serialization failed.\n");exit(1);}xdrmem_create(&xdr, buffer, sizeof(buffer), XDR_DECODE);status = xdr_rpc_gss_data(&xdr, &gd);if (!status) {fprintf(stderr, "Deserialization failed.\n");exit(1);}return 0;
}

7. xdr_rpcb

7.1 函数说明

函数声明函数功能
bool_t xdr_rpcb(XDR *xdrs, struct rpcb *objp);用于编码和解码 RPCBIND 程序号和版本号,以及程序地址信息

参数:

  • xdrs : 指向要编码或解码数据的 XDR 结构体的指针
  • objp : 指向 rpcb 结构体的指针

返回值:

  • 如果编码或解码成功,则返回值为 TRUE
  • 否则返回值为 FALSE

7.2 演示示例

// RPCBIND 程序号和版本号,以及程序地址
struct rpcb {char *r_progname;u_long r_progvers;struct netbuf r_addr;char *r_netid;
};
// 网络地址信息
struct netbuf {u_int maxlen;u_int len;char *buf;
};
#include <stdio.h>
#include <rpc/rpc.h>int main() 
{struct rpcb rpcb_obj = {"my_program", 1, {0, 0, NULL}, "tcp"};XDR xdr;char buffer[1024];xdrmem_create(&xdr, buffer, sizeof(buffer), XDR_ENCODE);if (xdr_rpcb(&xdr, &rpcb_obj)) {printf("Serialization success!\n");} else {printf("Serialization failed!\n");}return 0;
}

8. xdr_short

8.1 函数说明

函数声明函数功能
bool_t xdr_short(XDR *xdrs, short *sp);用于编码或解码短整型数据

参数:
参数:

  • xdrs : 指向要编码或解码数据的 XDR 结构体的指针
  • sp : 指向要编码或解码的 short 类型数据的指针

返回值:

  • 如果编码或解码成功,则返回值为 TRUE
  • 否则返回值为 FALSE

8.2 演示示例

#include <rpc/xdr.h>
#include <stdio.h>int main() 
{XDR xdr;char buf[256];short num = 42;// 初始化 XDR 流结构体xdrmem_create(&xdr, buf, sizeof(buf), XDR_ENCODE);// 编组 short 类型变量if (!xdr_short(&xdr, &num)) {fprintf(stderr, "编组失败!\n");return 1;}// 重置流位置xdr_setpos(&xdr, 0);// 解组 short 类型变量short decoded_num;if (!xdr_short(&xdr, &decoded_num)) {fprintf(stderr, "解组失败!\n");return 1;}printf("编组的值:%d,解组的值:%d\n", num, decoded_num);return 0;
}

9. xdr_string

9.1 函数说明

函数声明函数功能
bool_t xdr_string(XDR *xdrs, char **cpp, u_int maxsize);用于编码或解码字符串数据

参数:

  • xdrs : 指向要编码或解码数据的 XDR 结构体的指针
  • cpp : 指向要编码或解码的字符串数据的指针
  • maxsize : 最大允许的字符串长度

返回值:

  • 如果编码或解码成功,则返回值为 TRUE
  • 否则返回值为 FALSE

9.2 演示示例

#include <stdio.h>
#include <rpc/xdr.h>int main() 
{char *str = "hello world!";char buf[1024];XDR xdrs;xdrmem_create(&xdrs, buf, sizeof(buf), XDR_ENCODE);if (!xdr_string(&xdrs, &str, strlen(str))) {printf("Serialization failed.\n");} else {printf("Serialized data:\n");for (int i = 0; i < xdr_getpos(&xdrs); i++) {printf("%02x ", buf[i]);}printf("\n");}return 0;
}

10. xdr_string_ptr

10.1 函数说明

函数声明函数功能
bool_t xdr_string_ptr(XDR *xdrs, char **cpp, const uint_t maxsize);用于编码或解码指向字符串的指针

参数:

  • xdrs : 指向要编码或解码数据的 XDR 结构体的指针
  • cpp : 指向要编码或解码的字符串数据的指针
  • maxsize : 最大允许的字符串长度

返回值:

  • 如果编码或解码成功,则返回值为 TRUE
  • 否则返回值为 FALSE

10.2 演示示例

#include <stdio.h>
#include <rpc/xdr.h>int main() 
{char str[50] = "Hello, world!";XDR xdrs;xdrmem_create(&xdrs, str, sizeof(str), XDR_ENCODE);xdr_string_ptr(&xdrs, &str, sizeof(str));printf("Encoded string: %s\n", str);char decoded_str[50];xdrmem_create(&xdrs, str, sizeof(str), XDR_DECODE);xdr_string_ptr(&xdrs, &decoded_str, sizeof(decoded_str));printf("Decoded string: %s\n", decoded_str);return 0;
}

相关文章:

C语言函数大全-- x 开头的函数(3)

C语言函数大全 本篇介绍C语言函数大全-- x 开头的函数 1. xdr_opaque 1.1 函数说明 函数声明函数功能bool_t xdr_opaque(XDR *xdrs, char *buf, u_int len);用于编码或解码任意长度的二进制数据 参数&#xff1a; xdrs &#xff1a; 指向 XDR 数据结构的指针&#xff0c;表…...

计算机图形学-GAMES101-12阴影

Shadow mapping 问题的提出 我们之前在进行着色时&#xff0c;对于每个物体仅考虑自己&#xff0c;而不考虑其他物体对它的影响。限定在光栅化中&#xff0c;如何解决阴影问题呢&#xff1f;阴影能被摄像机看到&#xff0c;但不能被光源所照亮。经典的Shadow mapping只能处理…...

iOS_Swift高阶函数

iOS_Swift高阶函数 #mermaid-svg-NxX1czIESDq47OQw {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-NxX1czIESDq47OQw .error-icon{fill:#552222;}#mermaid-svg-NxX1czIESDq47OQw .error-text{fill:#552222;stroke:#…...

探索Vue的组件世界-组件复用

目录 Mixin【混入】 缺陷 HOC&#xff08;higher order component&#xff09;【高阶组件】 相比较Mixin的优点&#xff1a; 不足&#xff1a; Renderless组件【函数式组件&#xff0c;无渲染组件&#xff0c;Vue社区使用比较多的一种业务复用模式】 优点&#xff1a; M…...

OMA通道-2

1 简介 本文档中指定的 API 使移动应用程序能够访问移动设备中的不同 SE&#xff0c;例如 SIM 或嵌入式 SE。 本规范提供了接口定义和 UML 图&#xff0c;以允许在各种移动平台和不同的编程语言中实现。 如果编程语言支持命名空间&#xff0c;则它应为 org.simalliance.openmob…...

SAP 用CO13冲销工序报工,但是没有产生货物移动(TCODE:CO1P 、 SE38 :CORUPROC,CORUAFWP)

前言 通常情况下&#xff0c;对PPO做GI或GR的时候&#xff0c;出现的异常可以在COGI中间被列出&#xff1b;在这些数据进入COGI之前&#xff0c;系统会把这些数据记录在CO1P中&#xff1b;换句话说&#xff0c;系统有时会出现DB的更新延时&#xff0c;当延时发生的时候&#xf…...

信息收集-服务器信息

服务器上面可以运行大量的系统服务和第三方应用服务&#xff0c;如果操作系统或者第三方软件没有及时升级打补丁&#xff0c;攻击者就有可能直接通过服务器上运行的服务进行攻击。 服务器需要收集的信息包含三个方面&#xff1a; 操作系统信息等识别waf&#xff08;Web应用程…...

连续签到积分兑换试用流量主小程序开发

每日签到积分兑换试用流量主小程序开发 打卡兑奖小程序。用户签到活得积分。积分可以兑换商品。观看激励视频广告可以积分翻倍。 用户可以参加试用商品活动参加试用需要提交信息。可以通过分享方式直接获取试用资格。 以下是流量主小程序的功能列表&#xff1a; 广告位管理&a…...

C语言—自定义类型(结构体、枚举、联合)

自定义类型 结构体结构体的声明特殊的声明结构的自引用结构体变量的定义和初始化结构体内存对齐修改默认对齐数offsetof宏 结构体传参 位段位段的定义&#xff08;声明&#xff09;位段的内存分配位段的跨平台问题位段的应用 枚举枚举类型的定义及使用枚举的优点 联合&#xff…...

Node.js博客项目开发思路笔记

博客项目介绍 1. 目标 开发一个博客系统&#xff0c;具备博客基本功能只开发 server 端&#xff0c;不关心前端 2. 需求 首页、作者页、博客详情页登陆页管理中心、新建页、编辑页 3. 技术方案 数据如何存储 博客 idtitlecontentcreatetimeauthor1标题 1内容 11111112z…...

python 之 shutil 文件的复制、删除、移动文件以及目录,并支持文件的归档、压缩和解压

一、shutil shutil 模块于文件和文件集合的高级操作&#xff0c;包括&#xff1a;复制、删除、移动文件以及目录&#xff0c;并支持文件的归档、压缩和解压等 二、使用例子 复制文件及权限 shutil.copy(src, dst)复制文件及权限&#xff1b;src 和 dst 文件路径。dst 文件名或…...

jface

JFace 是建立在 SWT 之上的 UI 部件&#xff0c;它是 SWT 的扩展并能和SWT交互。 ApplicationWindow和Action org.eclipse.jface.window.ApplicationWindow; JFace为了简化窗口的设计特别设计了类&#xff0c;比如ApplicationWindow这一个类&#xff0c;它里面包含了六个默认…...

六级备考28天|CET-6|听力第一讲|基本做题步骤与方法|13:30~14:30

目录 1. 重点词汇 proofread / ˈpruːfriːd / v.校对&#xff0c;校阅 autonomous adj.独立的 obsession n. 喜好 ample …...

系统设计 - 设计一个速率限制器

实施速率限制器的位置主要取决于我们的应用程序、技术栈、技术团队等因素。通常有三个位置可供选择&#xff1a;客户端、服务器端或中间件。 客户端是不可靠的地方来执行速率限制&#xff0c;因为恶意行为者可以轻易伪造客户端请求。 比将速率限制器放在服务器端更好的方法是使…...

[技术分享]Android平台实时音视频录像模块设计之道

实现背景 录像有什么难的&#xff1f;无非就是数据过来&#xff0c;编码保存mp4而已&#xff0c;这可能是好多开发者在做录像模块的时候的思考输出。是的&#xff0c;确实不难&#xff0c;但是做好&#xff0c;或者和其他模块有非常好的逻辑配合&#xff0c;确实不容易。 好多…...

JDKMissionControl官方用户指南--人工翻译

1. JMC8新增功能 暂时用不到&#xff0c;暂略 2. JDK Mission Control是什么 JMC是一组高级工具&#xff0c;用于管理、监视、分析Java应用程序并排除其故障。JMC能够对代码性能、内存和延迟等领域进行高效而详细的数据分析&#xff0c;而不会引入通常与分析和监控工具相关的…...

MySql-高级(分库分表问题简析) 学习笔记

文章目录 1. 为什么要分库分表&#xff1f;2. 用过哪些分库分表中间件&#xff1f;不同的分库分表中间件都有什么优点和缺点&#xff1f;3. 你们具体是如何对数据库如何进行垂直拆分或水平拆分的&#xff1f;4. 分库分表时&#xff0c;数据迁移方案5. 如何设计可以动态扩容缩容…...

【5.20】五、安全测试——安全测试工具

目录 5.4 常见的安全测试工具 1. Web漏洞扫描工具——AppScan 2. 端口扫描工具——Nmap 3. 抓包工具——Fiddler 4. Web渗透测试工具——Metasploit 小提示&#xff1a;Kali Linux 5.4 常见的安全测试工具 安全测试是一个非常复杂的过程&#xff0c;测试所使用到的工具也…...

【13900k】i9 核显升级驱动

这里写自定义目录标题 官方的助手不能用显卡控制中心提示最新的更新搜索显卡 intel uhd graphics 770 手动下载安装自定义音频为啥也要卸载&#xff1f;新的改变功能快捷键合理的创建标题&#xff0c;有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片…...

使用Python将绿色转换为红色、红色转换为蓝色的图像处理

使用Python将绿色转换为红色、红色转换为蓝色的图像处理 在图像处理中&#xff0c;我们经常需要对图像进行颜色转换和修改。本篇博客介绍了如何使用Python的Pillow库来读取一个文件夹中的所有图像&#xff0c;并将其中的绿色转换为红色&#xff0c;红色转换为蓝色。我们还展示…...

KubeSphere 容器平台高可用:环境搭建与可视化操作指南

Linux_k8s篇 欢迎来到Linux的世界&#xff0c;看笔记好好学多敲多打&#xff0c;每个人都是大神&#xff01; 题目&#xff1a;KubeSphere 容器平台高可用&#xff1a;环境搭建与可视化操作指南 版本号: 1.0,0 作者: 老王要学习 日期: 2025.06.05 适用环境: Ubuntu22 文档说…...

基于算法竞赛的c++编程(28)结构体的进阶应用

结构体的嵌套与复杂数据组织 在C中&#xff0c;结构体可以嵌套使用&#xff0c;形成更复杂的数据结构。例如&#xff0c;可以通过嵌套结构体描述多层级数据关系&#xff1a; struct Address {string city;string street;int zipCode; };struct Employee {string name;int id;…...

ES6从入门到精通:前言

ES6简介 ES6&#xff08;ECMAScript 2015&#xff09;是JavaScript语言的重大更新&#xff0c;引入了许多新特性&#xff0c;包括语法糖、新数据类型、模块化支持等&#xff0c;显著提升了开发效率和代码可维护性。 核心知识点概览 变量声明 let 和 const 取代 var&#xf…...

2025年能源电力系统与流体力学国际会议 (EPSFD 2025)

2025年能源电力系统与流体力学国际会议&#xff08;EPSFD 2025&#xff09;将于本年度在美丽的杭州盛大召开。作为全球能源、电力系统以及流体力学领域的顶级盛会&#xff0c;EPSFD 2025旨在为来自世界各地的科学家、工程师和研究人员提供一个展示最新研究成果、分享实践经验及…...

Oracle查询表空间大小

1 查询数据库中所有的表空间以及表空间所占空间的大小 SELECTtablespace_name,sum( bytes ) / 1024 / 1024 FROMdba_data_files GROUP BYtablespace_name; 2 Oracle查询表空间大小及每个表所占空间的大小 SELECTtablespace_name,file_id,file_name,round( bytes / ( 1024 …...

FFmpeg 低延迟同屏方案

引言 在实时互动需求激增的当下&#xff0c;无论是在线教育中的师生同屏演示、远程办公的屏幕共享协作&#xff0c;还是游戏直播的画面实时传输&#xff0c;低延迟同屏已成为保障用户体验的核心指标。FFmpeg 作为一款功能强大的多媒体框架&#xff0c;凭借其灵活的编解码、数据…...

Vue2 第一节_Vue2上手_插值表达式{{}}_访问数据和修改数据_Vue开发者工具

文章目录 1.Vue2上手-如何创建一个Vue实例,进行初始化渲染2. 插值表达式{{}}3. 访问数据和修改数据4. vue响应式5. Vue开发者工具--方便调试 1.Vue2上手-如何创建一个Vue实例,进行初始化渲染 准备容器引包创建Vue实例 new Vue()指定配置项 ->渲染数据 准备一个容器,例如: …...

初学 pytest 记录

安装 pip install pytest用例可以是函数也可以是类中的方法 def test_func():print()class TestAdd: # def __init__(self): 在 pytest 中不可以使用__init__方法 # self.cc 12345 pytest.mark.api def test_str(self):res add(1, 2)assert res 12def test_int(self):r…...

使用Spring AI和MCP协议构建图片搜索服务

目录 使用Spring AI和MCP协议构建图片搜索服务 引言 技术栈概览 项目架构设计 架构图 服务端开发 1. 创建Spring Boot项目 2. 实现图片搜索工具 3. 配置传输模式 Stdio模式&#xff08;本地调用&#xff09; SSE模式&#xff08;远程调用&#xff09; 4. 注册工具提…...

STM32HAL库USART源代码解析及应用

STM32HAL库USART源代码解析 前言STM32CubeIDE配置串口USART和UART的选择使用模式参数设置GPIO配置DMA配置中断配置硬件流控制使能生成代码解析和使用方法串口初始化__UART_HandleTypeDef结构体浅析HAL库代码实际使用方法使用轮询方式发送使用轮询方式接收使用中断方式发送使用中…...