yield函数c语言,利用Duff's device在C/C++中模拟Python中的yield

本文探讨了如何将Python中的生成器函数gen()转换为C和C++代码,通过实例解析四种不同实现方式,包括使用switch/case结构、宏定义和Boost.Coroutine库。展示了从Python生成器原理到C/C++代码的迁移过程。
摘要由CSDN通过智能技术生成

考虑一个简单的Python函数:

def gen():

for i in range(10):

yield i

是否有可能在C或者C++中实现呢?

在Coroutines in C一文中详细的介绍了在C语言中实现的可能性。

现在简单介绍下:

版本1:

int gen(void) {

static int i, state = 0;

switch (state) {

case 0: goto LABEL0;

case 1: goto LABEL1;

}

LABEL0: /* start of function */

for (i = 0; i < 10; i++) {

state = 1; /* so we will come back to LABEL1 */

return i;

LABEL1:; /* resume control straight after the return */

}

}

版本2:

int gen(void) {

static int i, state = 0;

switch (state) {

case 0: /* start of function */

for (i = 0; i < 10; i++) {

state = 1; /* so we will come back to "case 1" */

return i;

case 1:; /* resume control straight after the return */

}

}

}

版本3:

#define crBegin static int state=0; switch(state) { case 0:

#define crReturn(i,x) do { state=i; return x; case i:; } while (0)

#define crFinish }

int gen(void) {

static int i;

crBegin;

for (i = 0; i < 10; i++)

crReturn(1, i);

crFinish;

}

版本4:

#define crBegin static int state=0; switch(state) { case 0:

#define crReturn(x) do { state=__LINE__; return x; \

case __LINE__:; } while (0)

#define crFinish }

int gen(void) {

static int i;

crBegin;

for (i = 0; i < 10; i++)

crReturn(i);

crFinish;

}

对于C++,在boost库中,有专门的实现:

Boost.Coroutine

该库的部分实现使用了汇编语言。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值