microPython的源码解析之 modio.c

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

microPython Python最小内核源码解析
这段代码是MicroPython中io模块的一部分,主要实现了IOBase和BufferedWriter两个类。IOBase是一个抽象基类,定义了所有IO流应该遵循的基本方法。BufferedWriter是一个缓冲写入器,它将数据写入内部缓冲区,然后在适当的时候将数据刷新到底层的IO流中。

#include <assert.h> // 断言宏
#include <string.h> // 字符串操作函数

#include "py/runtime.h" // MicroPython运行时相关定义
#include "py/builtin.h" // 内置对象和函数
#include "py/stream.h" // 流操作相关的结构和函数
#include "py/binary.h" // 二进制数据操作
#include "py/objarray.h" // 数组对象
#include "py/objstringio.h" // StringIO模块实现
#include "py/frozenmod.h" // 冻结模块

#if MICROPY_PY_IO // 如果MicroPython配置了IO模块

#if MICROPY_PY_IO_IOBASE // 如果配置了IO_BASE模块

// IOBase类型的定义
static const mp_obj_type_t mp_type_iobase;

// IOBase单例对象
static const mp_obj_base_t iobase_singleton = {
   &mp_type_iobase};

// IOBase对象的构造函数
static mp_obj_t iobase_make_new(const mp_obj_type_t *type, size_t n_args, size_t n_kw, const mp_obj_t *args) {
   
    (void)type; // 类型参数未使用
    (void)n_args; // 参数数量未使用
    (void)n_kw; // 关键字参数数量未使用
    (void)args; // 参数值未使用
    // 返回IOBase单例对象
    return MP_OBJ_FROM_PTR(&iobase_singleton);
}

// IOBase的读操作实现
static mp_uint_t iobase_read(mp_obj_t obj, void *buf, mp_uint_t size, int *errcode) {
   
    return iobase_read_write(obj, buf, size, errcode, MP_QSTR_readinto);
}

// IOBase的写操作实现
static mp_uint_t iobase_write(mp_obj_t obj, const void *buf, mp_uint_t size, int *errcode) {
   
    return iobase_read_write(obj, (void *)buf, size, errcode, MP_QSTR_write);
}

// IOBase的ioctl操作实现
static mp_uint_t iobase_ioctl(mp_obj_t obj, mp_uint_t request, uintptr_t arg, int *errcode) {
   
    // 调用对象的ioctl方法并返回结果
    // ...
}

// IOBase的流协议实现
static const mp_stream_p_t iobase_p = {
   
    .read = iobase_read,
    .write = iobase_write,
    .ioctl = iobase_ioctl,
};

// IOBase类型的定义
static MP_DEFINE_CONST_OBJ_TYPE(
    mp_type_iobase,
    MP_QSTR_IOBase,
    MP_TYPE_FLAG_NONE,
    make_new, iobase_make_new,
    protocol, &iobase_p
);

#endif // MICROPY_PY_IO_IOBASE

#if MICROPY_PY_IO_BUFFEREDWRITER // 如果配置了BUFFEREDWRITER模块

// BufferedWriter类型的定义
typedef struct _mp_obj_bufwriter_t {
   
    mp_obj_base_t base;
    mp_obj_t stream;
    size_t alloc;
    size_t len;
    byte buf[0]; // 灵活数组成员,其大小由alloc决定
} mp_obj_bufwriter_t;

// BufferedWriter对象的构造函数
static mp_obj_t bufwriter_make_new(const mp_obj_type_t *type, size_t n_args, size_t n_kw, const mp_obj_t *args) {
   
    // 检查参数数量
    // ...
    // 创建BufferedWriter对象并初始化
    // ...
}

// BufferedWriter的写操作实现
static mp_uint_t bufwriter_write(mp_obj_t self_in, const void *buf, mp_uint_t size, int *errcode) {
   
    // 将数据写入内部缓冲区,并在缓冲区满时刷新到流中
    // ...
}

// BufferedWriter的刷新方法
static mp_obj_t bufwriter_flush(mp_obj_t self_in) {
   
    // 将缓冲区内的数据刷新到流中
    // ...
}

// BufferedWriter的本地方法字典
static const mp_rom_map_elem_t bufwriter_locals_dict_table[] = {
   
    {
    MP_ROM_QSTR(MP_QSTR_write), MP_ROM_PTR(&mp_stream_write_obj) },
    {
    MP_ROM_QSTR(MP_QSTR_flush), MP_ROM_PTR(&bufwriter_flush_obj) },
};
static MP_DEFINE_CONST_DICT(bufwriter_locals_dict, bufwriter_locals_dict_table);

// BufferedWriter的流协议实现
static const mp_stream_p_t bufwriter_stream_p = {
   
    .write = bufwriter_write,
};

// BufferedWriter类型的定义
static MP_DEFINE_CONST_OBJ_TYPE(
    mp_type_bufwriter,
    MP_QSTR_BufferedWriter,
    MP_TYPE_FLAG_NONE,
    make_new, bufwriter_make_new,
    protocol, &bufwriter_stream_p,
    locals_dict, &bufwriter_locals_dict
);

#endif // MICROPY_PY_IO_BUFFEREDWRITER

// io模块的全局字典
static const mp_rom_map_elem_t mp_module_io_globals_table[] = 
  • 17
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

openwin_top

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

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

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

打赏作者

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

抵扣说明:

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

余额充值