最近在看linux内核的进程调度算法,也写了不少的内核注释,也参考了鸿哥的单片机框架,代码注释就开源在我的CSDN的git代码库里,有兴趣的可以去瞧瞧。

突发奇想,想到了既然单片机能够实现,那么我用标准C语言同样也可以实现,试了一下,真的可以!!这让我如获至宝!

在UNIX和linux还有window中存在着多线程的机制,其实就是把一个任务分成若干个时间片,这样越分越细,执行的效果就好像是在同步在执行,其实这是调度算法在产生效果。如果我们不调用那个所谓的pthread函数,用标准C模拟这样的效果,完全能够做到,可以做到多任务同时执行,从开始到结束,都是同时开始,同时结束。

废话不多说,我们上代码,看看就知道了:

#include <stdio.h>
#include <stdlib.h>

void  thread_work1(void);
void  thread_work2(void);
void  thread_work3(void);
void  thread_work4(void);
void  thread_work5(void);
void  thread_work6(void);
void  delay(void);

int main(void)
{
	static int i = 5 ;
	static int j ;
	static int k ;
	while(1)
	{
		printf("---------------第%d次调度开始-----------------\n",++j);
		putchar('\n');
		putchar('\n');
		thread_work1();
		thread_work2();
		thread_work3();
		thread_work4();
		thread_work5();
		putchar('\n');
		putchar('\n');
		printf("---------------第%d次调度完成-----------------\n",++k);
		putchar('\n');
		if(i > 0){
			i-- ;
			if(i == 0)
				break;
		}
	}

	return 0 ;
}

void thread_work1(void)
{
	printf("任务一:\n");
	delay();
	static int type = 0;
	static long int i = 5;
	printf("i的值:%d\n",i) ;
	switch(type)
		{
			case 0 :
				   if(i > 0)
				   	   i-- ;
				   printf("type 0 :i=%d\n",i);
				   type = 1 ;
				   break ;
			case 1 :
				   if(i > 0)
			    	i-- ;
			    	printf("type 1 :i=%d\n",i);
				   type = 0 ;
				   break ;
		}
}

void thread_work2(void)
{
	printf("任务二:\n");
	delay();
	static int type = 0 ;
	static long int i = 5 ;
	printf("i的值:%d\n",i) ;
	switch(type)
	{
		case 0 :
				if(i > 0)
					i-- ;
				printf("type 0 :i=%d\n",i);
				type = 1 ;
				break ;
		case 1 :
			    if(i > 0)
			    	i-- ;
			    printf("type 1 :i=%d\n",i);
				type = 0 ;
				break ;
	}
}

void thread_work3(void)
{
	printf("任务三:\n");
	delay();
	static int type = 0 ;
	static long int i = 5 ;
	printf("i的值:%d\n",i) ;
	switch(type)
	{
		case 0 :
				if(i > 0)
					i-- ;
				printf("type 0 :i=%d\n",i);
				type = 1 ;
				break ;
		case 1 :
			    if(i > 0)
			    	i-- ;
			    printf("type 1 :i=%d\n",i);
				type = 0 ;
				break ;
	}
}

void thread_work4(void)
{
	printf("任务四:\n");
	delay();
	static int type = 0 ;
	static long int i = 5;
	printf("i的值:%d\n",i) ;
	switch(type)
	{
		case 0 :
				if(i > 0)
					i-- ;
				printf("type 0 :i=%d\n",i);
				type = 1 ;
				break ;
		case 1 :
			    if(i > 0)
			    	i-- ;
			    printf("type 1 :i=%d\n",i);
				type = 0 ;
				break ;
	}
}

void thread_work5(void)
{
	printf("任务五:\n");
	delay();
	static int type = 0 ;
	static long int i = 5;
	printf("i的值:%d\n",i) ;
	switch(type)
	{
		case 0 :
				if(i > 0)
					i-- ;
				printf("type 0 :i=%d\n",i);
				type = 1 ;
				break ;
		case 1 :
			    if(i > 0)
			    	i-- ;
			    printf("type 1 :i=%d\n",i);
				type = 0 ;
				break ;
	}
}

void delay(void)
{
	long int i = 0xffffff ;
	while(i > 0)
		i-- ;
}

我们看到,上面的5个任务其实是在执行同一个操作,就是将5减到0的操作,一些初学者可能会想,函数不是执行完一个,然后再执行下一个吗?那么我们看看运行结果,这会让你大吃一惊,事实就是这样,不信咱们看看:

看到最后的结果,是否觉得很神奇?其实关键就是每个函数里的static这个关键字,它保留了执行完上一次数值的状态,再者就是每个函数中都有一个switch的分支,这样的分支就实现了轮流切换。在我的代码里,该代码经过5次调度完成后,数值从5变为0,而且每一个任务都是实现单独运行,却没有相互干扰,正是这样的机制,运用到单片机和裸板上,这无非就是一种非常好的框架!!!

用简单的C语言实现多任务轮流切换(模拟操作系统线程机制)的更多相关文章

  1. LANG=C是最早最简单的C语言环境(标准ASCII码)

    LANG=C是最早最简单的C语言环境(标准ASCII码)

  2. 简单的C语言编译器--概述

      在学习了编译原理的相关知识后,逐渐的掌握一个编译器的结构.作用和实现方法.同时,希望自己在不断的努力下写出一个简单的C语言编译器. 实现步骤 词法分析器:将C语言测试代码分解成一个一个的词法单元: ...

  3. 一个简单的C语言程序(详解)

    C Primer Plus之一个简单的C语言程序(详解) #include <stdio.h> int main(void) //一个简单的 C程序 { int num; //定义一个名为 ...

  4. 利用OD破解一个简单的C语言程序

    最近在学习汇编(看的是王爽老师的<汇编语言(第三版)>),然后想尝试使用OD(Ollydbg)软件破解一个简单的C语言程序练练手. 环境: C语言编译环境:VC++6.0 系统:在Wind ...

  5. C++中的虚函数(表)实现机制以及用C语言对其进行的模拟实现

    tfref 前言 C++对象的内存布局 只有数据成员的对象 没有虚函数的对象 拥有仅一个虚函数的对象 拥有多个虚函数的对象 单继承且本身不存在虚函数的继承类的内存布局 本身不存在虚函数(不严谨)但存在 ...

  6. 如何让c语言使用结构体近似模拟c++中的类

    如今统治市场的主流编程语言,如c++,java,大都是面向对象类型的编程语言. 而众所周知,c语言是面向过程的编程语言,但是它拥有一个类似于类的结构,叫做结构体,主要的区别在于结构体无法定义函数. 因 ...

  7. neo4j初次使用学习简单操作-cypher语言使用

    Neo4j 使用cypher语言进行操作 Cypher语言是在学习Neo4j时用到数据库操作语言(DML),涵盖对图数据的增删改查  neo4j数据库简单除暴理解的概念: Neo4j中不存在表的概念, ...

  8. 简单的C语言小学四则运算设计

    题目:设计一个简单的四则运算编辑器 思路:我使用的是C语言编程,看到题目首先要随机出3个随机数,其中两个为100以内的随机数(a,b),一个为0~3的随机数(k). k值的变化使得+ - * /的变化 ...

  9. 从一个新手容易混淆的例子简单分析C语言中函数调用过程

    某天,王尼玛写了段C程序: #include <stdio.h> void input() { int i; ]; ; i < ; i++) { array[i] = i; } } ...

随机推荐

  1. C算法实现:将字符串中的数字返回为整型数

    今天看linux内核驱动的代码,发现一个算法写得挺简单,也有意思. 分享一下我的测试代码: #include <stdio.h> typedef int U32 ; U32 String2 ...

  2. Dynamics CRM2016 Web API之删除

    相比之前的增改查,删除就显得简单的多了. 这里的request的type为delete,删除成功的status为204,404则是要删除的记录不存在 var id = 'BAD90A95-7FEA-E ...

  3. T-SQL中的APPLY用法(半翻译)

    本文接上文:T-SQL 中的CROSS JOIN用法(半翻译) 同样可用于微软认证70-461: Querying Microsoft SQL Server 2012考试的学习中. --------- ...

  4. shell的date日期循环方法:日期格式转时间戳计算,再将时间戳转回日期格式

    1,日期对象转时间戳current_day 2,计算增量的时间戳,即循环每步的增量one_day 3,循环体计算,日期变量加增量后重新赋值自己 4,时间戳转回日期格式后输出 current_day=2 ...

  5. android插件化之路

    概论  插件式开发通俗的讲就是把一个很大的app分成n多个比较小的app,其中有一个app是主app.基本上可以理解为让一个apk不安装也可以被运行.只不过这个运行是有很多限制的运行,所以才叫插件. ...

  6. Spark:大数据的电花火石!

    什么是Spark?可能你很多年前就使用过Spark,反正当年我四六级单词都是用的星火系列,没错,星火系列的洋名就是Spark. 当然这里说的Spark指的是Apache Spark,Apache Sp ...

  7. Dynamics CRM 2015Online Update1 new feature之表单页Tabs切换

    CRM2011的界面相对于CRM4.0进行了比较大的改动,N久没见过4.0的界面了所以忘了表单是什么样子的了,但2011的表单中若含有多个tab的话,是可以通过左侧栏进行切换,话说2013的界面相对2 ...

  8. Docker教程:dokcer machine的概念和安装

    http://blog.csdn.net/pipisorry/article/details/50920982 Docker machine介绍 做为Docker容器集群管理三剑客之一的Docker ...

  9. J2EE Exception:WELD-001408 Unsatisfied dependencies for type [SelectModelFactory] with qualifiers [@

    Issue: When you inject some resources using @Inject, you may encounter following exception after app ...

  10. 精通CSS+DIV网页样式与布局--制作实用菜单

    在上篇博文中,小编中主要的简单总结了一下CSS中关于如何设置页面和浏览器元素,今天小编继续将来介绍CSS的相关基础知识,这篇博文,小编主要简单的总结一下在CSS中如何制作网页中的菜单,这部分的内容包括 ...