基于python生成taskc语言文件--时间片轮询

目录

前言

utf-8

chinese GB2312

 utf-8 排除task.c

chinese GB2312 排除task.c

运行结果


前言

        建议是把能正常工作的单个功能函数放到一起(就和放while函数里的程序一样),程序会按顺序自动配置。

        不同的格式已经对应给出。

utf-8

import os
import redef extract_functions():func_re = re.compile(r'^void\s+(?!.*Init\b)(\w+)\s*\(void\)\s*{', re.MULTILINE)functions = []for file in os.listdir('.'):if file.endswith('.c'):try:with open(file, 'r', encoding='utf-8') as f:matches = func_re.finditer(f.read())functions.extend(m.group(1) for m in matches)except UnicodeDecodeError:print(f"警告: {file} 非UTF-8编码已跳过")return sorted(set(functions))def generate_files(func_list):# 生成task.hwith open('task.h', 'w', encoding='utf-8') as f:f.write(f"""#ifndef TASK_H
#define TASK_H#include <stdint.h>typedef struct {{void (*task)(void);uint32_t interval;uint32_t counter;
}} Task;#define TASK_COUNT {len(func_list)}
extern Task tasks[TASK_COUNT];void tasks_init(void);
void scheduler(void);#endif
""")# 生成task.cwith open('task.c', 'w', encoding='utf-8') as f:f.write("""#include "task.h"Task tasks[TASK_COUNT];void tasks_init(void) {
""")for i, func in enumerate(func_list):f.write(f'    tasks[{i}] = (Task){{{func}, {10*(i+1)}, 0}};\n')f.write("""}void scheduler(void) {for(uint8_t i=0; i<TASK_COUNT; i++){if(++tasks[i].counter >= tasks[i].interval){tasks[i].task();tasks[i].counter = 0;}}
}
""")if __name__ == "__main__":funcs = extract_functions()generate_files(funcs)print(f"生成成功: 共配置{len(funcs)}个任务")

chinese GB2312

import os
import redef extract_gb2312_functions():pattern = re.compile(r'^void\s+(?!.*Init\b)(\w+)\s*\(void\)\s*{',re.MULTILINE)functions = []for file in os.listdir('.'):if file.endswith('.c'):try:with open(file, 'r', encoding='gb2312') as f:functions += [m.group(1) for m in pattern.finditer(f.read())]except UnicodeDecodeError:print(f"解码失败: {file} 非GB2312编码")return sorted(set(functions))def generate_gb_tasks(func_list):with open('task.h', 'w', encoding='gb2312') as f:f.write("#ifndef TASK_H\n""#define TASK_H\n\n""typedef struct {\n""    void (*run)(void);\n""    unsigned int interval;\n""    unsigned int counter;\n""} Task;\n\n"f"#define TOTAL_TASKS {len(func_list)}\n""extern Task tasks[TOTAL_TASKS];\n""void init_tasks(void);\n""#endif\n")with open('task.c', 'w', encoding='gb2312') as f:f.write('#include "task.h"\n\nTask tasks[TOTAL_TASKS];\n\n')f.write('void init_tasks(void) {\n')for idx, func in enumerate(func_list):f.write(f'    tasks[{idx}] = (Task){{{func}, {10*(idx+1)}, 0}};\n')f.write('}\n\n''void tick_scheduler(void) {\n''    for(int i=0; i<TOTAL_TASKS; i++) {\n''        if(++tasks[i].counter >= tasks[i].interval) {\n''            tasks[i].run();\n''            tasks[i].counter = 0;\n''        }\n''    }\n''}\n')if __name__ == "__main__":valid_funcs = extract_gb2312_functions()generate_gb_tasks(valid_funcs)print(f"生成完成: {len(valid_funcs)}个任务")

         把项目放到python目录下,再在想要生成的位置创建.py文件

         测试验证GB2312的,执行基本没啥大问题,生成的tsak文件仍需要验证,暂时没有时间。

 utf-8 排除task.c

import os
import redef extract_functions():exclude_files = {'task.c'}pattern = re.compile(r'^void\s+(?!.*Init\b)(\w+)\s*\(void\)\s*{', re.MULTILINE)funcs = []for file in os.listdir('.'):if file.endswith('.c') and file not in exclude_files:with open(file, 'r', encoding='utf-8') as f:matches = pattern.finditer(f.read())funcs.extend(m.group(1) for m in matches)return sorted(set(funcs))def generate_task_files(func_list):with open('task.h', 'w', encoding='utf-8') as h:h.write(f'''#ifndef TASK_H
#define TASK_Htypedef struct {{void (*execute)(void);unsigned int interval;unsigned int counter;
}} Task;extern Task tasks[{len(func_list)}];
void init_scheduler(void);
void run_scheduler(void);
#endif''')with open('task.c', 'w', encoding='utf-8') as c:c.write('#include "task.h"\n\nTask tasks[%d];\n\n' % len(func_list))c.write('void init_scheduler() {\n')for idx, name in enumerate(func_list):c.write(f'    tasks[{idx}] = (Task){{{name}, {50*(idx+1)}, 0}};\n')c.write('}\n\nvoid run_scheduler() {\n''    for(int i=0; i<%d; i++) {\n' % len(func_list) +'        if(++tasks[i].counter >= tasks[i].interval) {\n''            tasks[i].execute();\n''            tasks[i].counter = 0;\n''        }\n    }\n}')if __name__ == '__main__':functions = extract_functions()generate_task_files(functions)

chinese GB2312 排除task.c

import os
import redef extract_funcs():exclude_files = {'task.c'}pattern = re.compile(r'^void\s+(?!.*Init\b)(\w+)\s*\(void\)\s*{', re.MULTILINE)funcs = []for f in os.listdir('.'):if f.endswith('.c') and f not in exclude_files:try:with open(f, 'r', encoding='gb2312') as file:content = file.read()funcs += [m.group(1) for m in pattern.finditer(content)]except UnicodeDecodeError:print(f"跳过非GB2312文件: {f}")return sorted(set(funcs))def build_task_files(func_list):# 生成头文件with open('task.h', 'w', encoding='gb2312') as h:h.write(f'''#ifndef _TASK_H
#define _TASK_Htypedef struct {{void (*exec)(void);unsigned int cycle;unsigned int tick;
}} Task;#define TASK_NUM {len(func_list)}
extern Task task_table[TASK_NUM];void task_init(void);
void task_scheduler(void);
#endif''')# 生成源文件with open('task.c', 'w', encoding='gb2312') as c:c.write('''#include "task.h"\n\nTask task_table[TASK_NUM];\n\n''')c.write('void task_init(void) {\n')for i, name in enumerate(func_list):c.write(f'    task_table[{i}] = (Task){{{name}, {20*(i+1)}, 0}};\n')c.write('}\n\nvoid task_scheduler(void) {\n''    for(unsigned char i=0; i<TASK_NUM; i++) {\n''        if(task_table[i].tick++ >= task_table[i].cycle) {\n''            task_table[i].exec();\n''            task_table[i].tick = 0;\n''        }\n''    }\n}')if __name__ == '__main__':valid_func = extract_funcs()build_task_files(valid_func)print(f"生成完成: {len(valid_func)}个任务")

运行结果

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

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

相关文章

Docker手动重构Nginx镜像,融入Lua、Redis功能

核心内容&#xff1a;Docker重构Nginx镜像&#xff0c;融入Lua、Redis功能 文章目录 前言一、准备工作1、说明2、下载模块3、Nginx配置文件3、Dockerfile配置文件3、准备工作全部结束 二、构建镜像三、基于镜像创建容器三、lua脚本的redis功能使用总结 前言 ⁣⁣⁣⁣ ⁣⁣⁣⁣…

DeepSeek+Excel:解锁办公效率新高度

目录 一、引言&#xff1a;Excel 遇上 DeepSeek二、认识 DeepSeek&#xff1a;大模型中的得力助手2.1 DeepSeek 的技术架构与原理2.2 DeepSeek 在办公场景中的独特优势 三、DeepSeek 与 Excel 结合的准备工作3.1 获取 DeepSeek API Key3.2 配置 Excel 环境 四、DeepSeekExcel 实…

解决Vue2------You may use special comments to disable some warnings.问题

问题截图 解决办法 打开项目中.eslintrc.js在rules中&#xff0c;添加以下代码&#xff0c;并extends的 vue/standard注释掉 space-before-function-paren: 0, semi: off, quotes : off, comma-dangle : off, vue/comment-directive: off

数据集-目标检测系列- 牙刷 检测数据集 toothbrush >> DataBall

数据集-目标检测系列- 牙刷 检测数据集 toothbrush >> DataBall DataBall 助力快速掌握数据集的信息和使用方式。 贵在坚持&#xff01; * 相关项目 1&#xff09;数据集可视化项目&#xff1a;gitcode: https://gitcode.com/DataBall/DataBall-detections-100s/over…

解决:前后端跨域请求

目录 关于跨域请求出现的原因 同源策略 示例&#xff08;跨域问题&#xff09; 如何解决跨域请求 方法一&#xff1a;配置后端服务器以允许跨域请求&#xff08;后端&#xff09; 方法二&#xff1a;使用代理服务器&#xff08;前端&#xff09; 一 &#xff0c;使用aja…

AI内容检测的技术优势与应用场景

随着互联网的普及和数字内容的爆发式增长&#xff0c;文本、图片、音频、视频等多样化内容已成为信息传播的主要载体。然而&#xff0c;伴随内容增长的是违法违规信息的泛滥&#xff0c;如涉黄、涉政、虚假广告、恶意引流等&#xff0c;不仅威胁用户体验&#xff0c;还对平台合…

DockerDesktop替换方案

背景 由于DockerDesktop并非开源软件&#xff0c;如果在公司使用&#xff0c;可能就有一些限制&#xff0c;那是不是除了使用DockerDesktop外&#xff0c;就没其它办法了呢&#xff0c;现在咱们来说说替换方案。 WSL WSL是什么&#xff0c;可自行百度&#xff0c;这里引用WS…

『Linux_网络』 基于状态机的Connect断线重连

客户端会面临服务器崩溃的情况&#xff0c; 我们可以试着写一个客户端重连的代码&#xff0c; 模拟并理 解一些客户端行为&#xff0c; 比如游戏客户端等。 客户端部分&#xff0c;我们本次采用状态机的设计模式实现 下面是关于状态机模式的介绍 状态机模式 状态机模式&…

5月6日日记

一点心得是 看通知要仔细认真&#xff0c;自己想问的问题要先看看通知或者文件中说了没有&#xff0c;如果没说再去问相关负责人。 上课的教室一定要看好&#xff0c;看准了再去。别像今天一样先去了科技楼又去了工学馆。 线代开课了。感觉总体还行&#xff0c;并不是很难。…

【算法专题十】哈希表

文章目录 0.哈希表简介1. 两数之和1.1 题目1.2 思路1.3 代码 2.判断是否为字符重排2.1 题目2.2 思路2.3 代码 3. leetcode.217.存在重复元素3.1 题目3.2 思路3.3 代码 4. leetcode.219.存在重复的元素Ⅱ4.1 题目4.2 思路4.3 代码 5. leetcode.49.字母异位词分组5.1 题目5.2 思路…

【前缀和】矩阵区域和

文章目录 1314. 矩阵区域和解题思路1314. 矩阵区域和 1314. 矩阵区域和 ​ 给你一个 m x n 的矩阵 mat 和一个整数 k ,请你返回一个矩阵 answer ,其中每个 answer[i][j] 是所有满足下述条件的元素 mat[r][c] 的和: i - k <= r <= i + k, j - k <= c <= j + k …

MyBatis的SQL映射文件中,`#`和`$`符号的区别

在MyBatis的SQL映射文件中,#和$符号用于处理SQL语句中的参数替换,但它们的工作方式和使用场景有所不同。 #{} 符号 预编译参数:#{} 被用来作为预编译SQL语句的占位符。这意味着MyBatis会将你传入的参数设置为PreparedStatement的参数,从而防止SQL注入攻击,并允许MyBatis对…

Linux中为某个进程临时指定tmp目录

起因&#xff1a; 在linux下编译k8s&#xff0c;由于编译的中间文件太多而系统的/tmp分区设置太小&#xff0c;导致编译失败&#xff0c;但自己不想或不能更改/tmp分区大小&#xff0c;所以只能通过其他方式解决。 现象&#xff1a; tmp分区大小&#xff1a; 解决方法&#x…

Tomcat中Web应用程序停止时为了防止内存泄漏,JDBC驱动程序被强制取消注册出现原因

1.问题描述 本地Windows环境开发的Springboot项目同样的mysql版本&#xff0c;jdk版本&#xff0c;tomcat版本&#xff0c;本地运行没有任何问题&#xff0c;发布到阿里云服务器上时报以下问题&#xff1a; 06-May-2025 20:06:12.842 警告 [main] org.apache.catalina.loader…

主流国产大模型(以华为盘古大模型和腾讯混元大模型为例)API调用接口的具体参数和使用方法,包括Python和C++的示例代码

以下是主流国产大模型&#xff08;以华为盘古大模型和腾讯混元大模型为例&#xff09;API调用接口的具体参数和使用方法&#xff0c;包括Python和C的示例代码。 华为盘古大模型 API参数&#xff1a; - model&#xff1a;模型名称&#xff0c;如pangu-nlp-large。 - messages&…

高效调用京东 API 实战:商品详情页实时数据采集接口开发指南​

在当今数字化商业环境中&#xff0c;电商数据的实时获取与分析对于企业的决策制定和市场竞争力提升至关重要。京东作为国内领先的电商平台&#xff0c;提供了丰富的 API 接口&#xff0c;允许开发者高效地获取商品详情页的实时数据。本文将详细介绍如何通过实战开发&#xff0c…

MFC自定义控件开发与使用指南

MFC自定义控件开发与使用指南 自定义控件、双缓冲 1. 概述 MFC(Microsoft Foundation Classes)框架提供了丰富的内置控件,但在实际开发中,我们常常需要创建自定义控件来满足特定的界面需求。本文将详细介绍如何在MFC中开发自定义控件,并以CCustomTextControl为例,展示自…

第100+40步 ChatGPT学习:R语言实现多轮建模

回顾一下什么叫多轮建模&#xff1a; 要综合判断一个模型好不好&#xff0c;一次随机抽样是不行的&#xff0c;得多次抽样建模&#xff0c;看看整体的性能如何才行&#xff08;特别是对于这种小训练集&#xff09;。 所以我的思路是&#xff0c;随机抽取训练集和验证集2000次…

编码器型与解码器型语言模型的比较

编码器型与解码器型语言模型的比较 1. 引言 自然语言处理&#xff08;NLP&#xff09;领域近年来取得了革命性进展&#xff0c;这在很大程度上归功于基于Transformer架构的语言模型。在这一技术生态中&#xff0c;编码器型&#xff08;Encoder-only&#xff09;和解码器型&am…

python--------修改桌面文件内容

目录 1. 文件的读写1. 写入文件2. 读取文件3. 追加内容到文件 2.file_path 的常见方法1. 绝对路径2. 相对路径3. 使用 os.path 模块构建路径5. 路径操作5. 用户主目录路径 4. 修改文件内容1.将修改后的内容写回文件2. 逐行处理文件内容3. 使用上下文管理器确保文件安全 1. 文件…