先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Golang全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip1024b (备注go)
正文
还有一个我也要推荐一下,是最近发现的,算得上是真正的裸机架构,叫microLite,
他有个公众号microlite裸机系统,有个简介,我摘在下面 你看一下就知道多么强大了,
- 内核调度子系统。microLite所谓的内核即软件定时器,主要为应用层的任务提供调度(以及其他定时场景的应用,如变量自增等)。软件定时器组件API接口设计简洁,使用方便灵活。
- 文件系统。microLite设计了精简的虚拟文件系统Vfs,采用fatfs文件系统模块。虚拟文件系统Vfs将fatfs文件系统抽象为统一的API接口进行访问,极大的简化了开发流程。支持日志存储组件、多路并发循环文件记录组件。
- 网络子系统。microLite以lwip协议栈为基础,实现了一组极简版udp socket裸机API接口。 另外microLite还提供了一些应用协议,如nctp、mqtt、telnet、tftp、sntp等。支持UART、CAN通信组件。
- 启动引导子系统。microLite的启动引导Bootloader支持RS232、TCPIP、CAN三种通信方式进行更新程序,其中TCPIP和CAN支持多站点组网。PC端操作界面简洁易用。
- CPU库和驱动子系统。microLite支持的 CPU IP 核架构,当前主要支持 ARM Cortex 3/4。驱动包括BSP和硬件抽象等。
- 轻量级lua脚本引擎。lua脚本语言接口建立在其他子系统API接口之上。主要用于配置、硬件测试等场合。
这个公众号可能是刚弄不久 目前文章不算多,不过你可以看一看思路
他那bootloader还拍个视频 我觉得挺牛逼的
还有一个叫傻孩子的 叫裸机思维的公众号 有介绍状态机,写的挺详细的,尽管我还没用上 不过你可以研究一下。里面有挺多介绍其他方面挺细的
首先,优先使用操作系统,这个和代码量,工程复杂度没有关系,用操作系统能很好的切割代码,而且安全可靠,如果用rtthread的话,很多组建都不需要自己移植,
裸机的话,尽量把硬件和软件分割开来,尽量模块化,降低耦合性。
架构啥的,能用中断就不用poll,能异步就不同步,再就是一个函数尽量不要超过100行。超过了就分割,切成多个函数,封装起来
作者:DaLin
链接:https://www.zhihu.com/question/438340661/answer/2448238096
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
(2022-5-20)最近在做单片机的软件架构,整改了多个版本,这里放一个初版本的软件架构图吧,仅供参考
系统软件架构-v0.1
我也来毛遂自荐一下自己写的一个系统吧,源代码的注释还是挺详细的
GitHub - DaLinYYY/LinRTOS: 之前写的一个简易RTOS系统,基于MDK平台,工程自动适配Cortex M0/M3/M4github.com/DaLinYYY/LinRTOS
Pandas/LinRTOSgitee.com/daliny/lin-rtos
本项目为2021年自己从零到一写出来的简易RTOS系统,目的是为了能更加深入的学习RTOS系统及底层运行的逻辑,项目命名为"LinRTOS",为什么会取这个名字呢?
LinRTOS开发基于MDK平台,目前工程工程自动适配Cortex M0/M3/M4,通过软件验证过所有的功能模块均正常工作
参考说明
写该系统主要参考的有两个知名的RTOS框架:为FreeRTOS和RT-Thread,FreeRTOS从远源码角度进行学习的,RT-Thread从Api的命名及系统框架结构上进行了一定借鉴。
这里想对国内的RT-Thread做定义说明,都知道老牌FreeRTOS是免费商业使用,其实RT-Thread也是可免费商业使用,只是RT-Thread有扩展的增值服务才需要进行收费,RT-Thread相对FreeRTOS来说有一个很好的有点,就是有大量的官方中文文档可以进行学习和参考。
- github master代码仓上你能看到的都是开源、免费的,可以免费商用
LinRTOS命名
函数命名规则主要参照FreeRTOS:
变量名
定义变量的时候往往会把变量的类型当作前缀加在变量上,这样的好处是让用户一看到这个变量就知道该变量的类型:
- c : char 型变量.
- s : short 型变量.
- l : long型变量.
- x : portBASE_TYPE类型变量,数据结构,任务句柄,队列句柄等定义的变量名.
- u : 无符号型的前面.
- p : 指针变量的前面.
例:当我们定义一个无符号的 char 型变量的时候会加一个 uc 前缀,当定义一个char 型的指针变量的时候会有一个 pc 前缀。
函数名
函数名包含了函数返回值的类型、函数所在的文件名和函数的功能,如果是私有的函数则会加一个 prv(private)的前缀。
在函数名中加入了函数所在的文件名,这大大的帮助了用户提高寻找函数定义的效率和了解函数作用的目的,具体的举例如下:
- vTaskPrioritySet()函数的返回值为 void 型,在 task.c这个文件中定义。
- xQueueReceive()函数的返回值为 portBASE_TYPE 型,在 queue.c 这个文件中定义。
- vSemaphoreCreateBinary()函数的返回值为 void 型,在 semphr.h 这个文件中定义。
LinRTOS系统框架
这里称系统架构其实也不是很合理的,因为LinRTOS只提供了在ARM的架构之上的内核层面的任务调度和消息处理和对硬件进行一定的抽象,内核层上面的组件框架和在上层的业务逻辑层是没有去实现的。
虽然目前只实现了内核层部分,想要这个系统更加的完善,还需要添加部分必要的组件和安全的框架进去,这里先给自己埋一个坑吧,后面有机会在来进行进一步的完善。
LinRTOS Kernel
工程文件结构
Kernel框架
对RTOS来说,任务调度是最核心的东西,这里面涉及到优先级调度算法,调度逻辑,及系统运行在硬件平台的一些基础知识点,上面说的所有的东西都是在Task.c和Task.h中来实现的。所以,Task也是RTOS中最重要的文件之一。
LinRTOS Config: 整个系统的配置文件,可以配置需要使用那些RTOS资源,优先级的个数等。
Task: RTOS最核心的模块,负责具体的任务调度的实现。
Event:事假核心文件,提供给各种类型的消息,信号公用的模块。
- Sem: 信号量: 可用于任务的同步和计数,提供增删改查功能。
- Mutex: 互斥信号量,用于任务的同步,具有互斥属性(用了来防止优先级翻转问题),提供增删改查功能。
- EventGroup: 事件标志组,用了多任务之间的同步,和信号量不同的是,可以实现一对多,多对多的同步。 即一个任务可以等待多个事件的发生:可以是任意一个事件发生时唤醒任务进行事件处理;也可以是几个事件都发生后才唤醒任务进行事件处理。同样,也可以是多个任务同步多个事件。
- Mailbox: 邮箱通讯,同于任务间数据信息传输,提供增删改查功能。
Scheduler: 操作硬件相关的任务中断,为任务的切换提供入口。
Mempool:为任务分配空间资源的管理文件。
List: 提供最基础的双向通用列表,可以进行增删改查。
Bitmap: 优先级调度算法的数组遍历映射文件。
Timer: 给真个RTOS计数的模块。
裸机还真没考虑过什么架构,就像楼上说的main里面while到底。
说到底应该还是对rtos不太了解导致的死机吧。
先查下是整个板子死机还是某几个线程死了。
额外开个优先级最高的线程,间隔1秒print一些调试信息。在死机时查查print信息是否还有在输出,可以确认这个线程挂了没。
如果线程全挂,重点查下每个线程的stack size是不是太小,默认值在函数嵌套比较深时是不太够用的,还有子函数是否有声明较大的局部变量,另外查查野指针之类的问题。
如果最高优先级线程活着,查查是否信号量互锁的问题,以及多线程之间的协作设计有误。
遇到问题需要先查出原因而不是逃避,就算逃到裸机也会遇到其它问题的。
F4这么好的性能不上rtos可惜了,裸机编程折腾死你
作者:追风筝的人
链接:https://www.zhihu.com/question/438340661/answer/2443068345
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
可以参考我的开源项目:基于循环时间的跨平台多任务管理系统(可用于MCS51,STM32等单片机)
1. 简介
1.1 系统简介
基于循环时间的跨平台任务管理系统(可用于MCS51,STM32等单片机)
1.2 文件目录说明
- TaskManager_c:c语言实现的任务管理系统
- TaskManager_cpp:c++实现的任务管理系统
- Demo:提供多种示例,涵盖电脑模拟器(MSVC),STM32,8081等多种运行环境
2. 用法(C语言版)
2.1 API用法
系统配置(TaskManager_config.h):
- MAX_TASK_NUM:最大任务数量,默认为10个,根据自己的需要修改
- SYS_CYCLE_TIME:系统的循环时间(单位为ms),默认为 1,表示1ms 【注】在MSVC下,SYS_CYCLE_TIME 只能为1,系统循环时间为1s
- 编译器:目前支持的编译器为 ARM_KILL (AC5和AV6均可) 和 WIN_MSVC
API接口(TaskManager_c):
- TaskMsg:【结构体】任务信息,结构体成员为 任务函数,开始时间,周期时间,运行次数,PID任务函数:只能是无参数,无返回值的函数,不能是阻塞函数开始时间:任务开始运行的时间,START_NOW 表示立即开始运行 周期时间:任务每周期时间运行一次 运行次数:任务需要运行的次数,RUN_FOREVER 表示无穷次 PID:任务编号号,初始化的时候传入 PID_INIT
- void TM_init():系统初始化
- uint32_t TM_add_task(TaskMsg* new_task_msg):添加任务
- void TM_kill_by_PID(uint32_t PID):通过任务序号删除任务
- void TM_kill_by_taskmsg(TaskMsg* task_msg):通过任务信息删除任务
- void TM_run(void):运行系统
示例代码1:
#include “taskmanager.h”
#include “TaskManager_config.h”
#include “stdio.h”
// 任务1
void task1(void)
{
printf(“task1!\n”);
}
// 任务2
void task2(void)
{
printf(“task2!\n”);
}
void main(void)
{
TM_init();
// 任务1立即启动,每2ms中运行一次,无休无止的运行
TaskMsg tasks_msg1 = { task1,START_NOW,2,RUN_FOREVER,0 };
TM_add_task(&tasks_msg1);
// 任务2在1ms之后启动,每4ms运行一次,运行5次自动结束
TaskMsg tasks_msg2 = { task2,1,4,5,0 };
TM_add_task(&tasks_msg2);
while (1)
{
// 任务管理器启动
TM_run();
}
}
示例代码2 [Demo/MSVC/c_language]
#include “…/TaskManager/taskmanager.h”
#include “…/TaskManager/TaskManager_config.h”
#include “stdio.h”
void task0(void)
{
static i = 1;
printf_s(“\n%d:”, i);
i++;
}
void task1(void)
{
printf_s(“task1!”);
}
void task2(void)
{
printf_s(“task2!”);
}
void main(void)
{
TM_init(1);
TaskMsg tasks_msg0 = { task0,START_NOW,1,RUN_FOREVER,0 };
int PID0 = TM_add_task(&tasks_msg0);
TaskMsg tasks_msg1 = { task1,START_NOW,2,RUN_FOREVER,0 };
int PID1 = TM_add_task(&tasks_msg1);
TaskMsg tasks_msg2 = { task2,START_NOW,4,RUN_FOREVER,0 };
int PID2 = TM_add_task(&tasks_msg2);
while (1)
{
TM_run();
if (get_systime() > 10)
tasks_msg1.period = 1;
if (get_systime() > 20)
TM_kill_by_PID(PID1);
if (get_systime() > 30)
TM_kill_by_taskmsg(&tasks_msg2);
if (get_systime() > 40)
return;
}
}
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Go)
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
e() > 20)
TM_kill_by_PID(PID1);
if (get_systime() > 30)
TM_kill_by_taskmsg(&tasks_msg2);
if (get_systime() > 40)
return;
}
}
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Go)
[外链图片转存中…(img-sdx81i2J-1713201601579)]
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!