microPython的源码解析之 objenumerate.c

MicroPython 是一种适用于微控制器和其他受限环境的 Python 编程语言的实现。它旨在提供与 Python 3 语言的紧密兼容,同时考虑到内存和计算资源的限制。MicroPython 库是这门语言的核心组成部分,提供了一系列的模块和函数,使得开发者能够在硬件上执行各种任务。
下面将通过系列文章,逐一解读microPython,以便让读者了解掌握microPython的整个核心逻辑.,以便读者可以透过这个Python的最小内核,掌握Python解析器的核心实现逻辑,学习世界上最优秀的源码设计之一.

microPython Python最小内核源码解析

#include <stdlib.h> // 引入标准库,提供内存分配等函数
#include <assert.h> // 引入断言宏,用于调试时检查条件是否为真

#include "py/runtime.h" // 引入MicroPython运行时环境的头文件

// 定义enumerate对象的结构体
typedef struct _mp_obj_enumerate_t {
   
    mp_obj_base_t base; // 继承自基础对象
    mp_obj_t iter; // 保存迭代器对象
    mp_int_t cur; // 当前索引
} mp_obj_enumerate_t;

// 定义iterate方法,用于在enumerate对象上获取下一个元素
static mp_obj_t enumerate_iternext(mp_obj_t self_in);

// 定义enumerate对象的构造函数
static mp_obj_t enumerate_make_new(const mp_obj_type_t *type, size_t n_args, size_t n_kw, const mp_obj_t *args) {
   
    #if MICROPY_CPYTHON_COMPAT
    // 定义参数格式,用于与CPython保持兼容
    static const mp_arg_t allowed_args[] = {
   
        {
    MP_QSTR_iterable, MP_ARG_REQUIRED | MP_ARG_OBJ, {
   .u_obj = MP_OBJ_NULL} }, // 可迭代对象,必须提供
        {
    MP_QSTR_start, MP_ARG_INT, {
   .u_int = 0} }, // 开始索引,默认为0
    };

    // 解析构造函数参数
    struct {
   
        mp_arg_val_t iterable, start;
    } arg_vals;
    mp_arg_parse_all_kw_array(n_args, n_kw, args,
        MP_ARRAY_SIZE(allowed_args), allowed_args, (mp_arg_val_t *)&arg_vals);

    // 创建enumerate对象
    mp_obj_enumerate_t *o = mp_obj_malloc(mp_obj_enumerate_t, type);
    o->iter = mp_getiter(arg_vals.iterable.u_obj, NULL); // 获取迭代器
    o->cur = arg_vals.start.u_int; // 设置当前索引
    #else
    // 检查参数数量
    mp_arg_check_num(n_args, n_kw, 1, 2, false);
    mp_obj_enumerate_t *o = mp_obj_malloc(mp_obj_enumerate_t, type);
    o->iter = mp_getiter(args[0], NULL); // 获取迭代器
    o->cur = n_args > 1 ? mp_obj_get_int(args[1]) : 0; // 如果提供了第二个参数,则设置当前索引
    #endif

    return 
  • 12
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

openwin_top

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值