Linux多窗口运行多进程,多进程,多窗体 - chenyi1982的个人空间 - OSCHINA - 中文开源技术交流社区...

本文主要是介绍Linux多窗口运行多进程,多进程,多窗体 - chenyi1982的个人空间 - OSCHINA - 中文开源技术交流社区...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

更详细的讲解和代码调试演示过程,请参看视频

Linux kernel Hacker, 从零构建自己的内核

为了让多任务的特性展示的更直观,本节,我们基于多任务的基础上,为系统实现多个窗口特效,每个窗口都运行于一个任务或进程。由于窗口基于各自不同的进程,因此窗口自身的变化更新不会影响到其他窗口。

我们看看相关代码:

void CMain(void) {

initBootInfo(&bootInfo);

unsigned char *buf_win_b;

struct SHEET *sht_win_b[3];

static struct TASK *task_b[3];

....

char taskTitle[6] = {'t','a','s','k', 0, 0};

int i = 0;

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

sht_win_b[i] = sheet_alloc(shtctl);

buf_win_b = (unsigned char*)memman_alloc_4k(memman, 144*52);

char c = 'b' + i;

taskTitle[4] = c;

sheet_setbuf(sht_win_b[i], buf_win_b, 144, 52, -1);

make_window8(shtctl, sht_win_b[i], taskTitle);

task_b[i] = task_alloc();

task_b[i]->tss.ldtr = 0;

task_b[i]->tss.iomap = 0x40000000;

task_b[i]->tss.eip =  (int)(task_b_main - addr_code32);

task_b[i]->tss.es = 0;

task_b[i]->tss.cs = 1*8;//6 * 8;

task_b[i]->tss.ss = 4*8;

task_b[i]->tss.ds = 3*8;

task_b[i]->tss.fs = 0;

task_b[i]->tss.gs = 2*8;

task_b[i]->tss.esp -= 4;

*((int*)(task_b[i]->tss.esp + 4)) = (int)sht_win_b[i];

task_run(task_b[i]);

}

sheet_slide(shtctl,sht_win_b[0], 16, 28);

sheet_updown(shtctl, sht_win_b[0], 1);

sheet_slide(shtctl, sht_win_b[1], 160, 28);

sheet_updown(shtctl, sht_win_b[1], 1);

//switch task

....

}

在上面的主入口函数中,我们先定义一个窗口数组对象sht_win_b, 已经任务数组对象task_b, 每一个任务对象对应一个窗口对象。接着在for循环中,启动两个进程,这两个进程运行的函数都是task_b_main, 这里需要特别注意的是,如何把窗口对象传递给进程:

task_b[i]->tss.esp -= 8;

((int)(task_b[i]->tss.esp + 4)) = (int)sht_win_b[i];

esp 对应进程的堆栈,要想把数据传递给进程,我们可以把数据压到进程的堆栈上,我们像把esp 减8,这样就可以空出8个字节,从中拿出4个字节用于存储对应的窗口对象。

然后通过调用sheet_slide 和 sheet_updown 将窗口挪到桌面合适位置。

我们看task_b_main函数的相关实现:

void task_b_main(struct SHEET *sht_win_b) {

showString(shtctl, sht_back, 0, 160, COL8_FFFFFF, "enter task b");

struct FIFO8 timerinfo_b;

char timerbuf_b[8];

struct TIMER *timer_b = 0;

int i = 0;

fifo8_init(&timerinfo_b, 8, timerbuf_b, 0);

timer_b = timer_alloc();

timer_init(timer_b, &timerinfo_b, 123);

timer_settime(timer_b, 100);

int count = 0;

int pos = 0;

for(;;) {

count++;

io_cli();

if (fifo8_status(&timerinfo_b) == 0) {

io_sti();

} else {

i = fifo8_get(&timerinfo_b);

io_sti();

if (i == 123) {

showString(shtctl, sht_back, pos, 192, COL8_FFFFFF, "B");

// farjmp(0, 8*8);

timer_settime(timer_b, 100);

pos += 8;

boxfill8(sht_win_b->buf, 144, COL8_C6C6C6, 24, 28, 104, 44);

sheet_refresh(shtctl, sht_win_b, 24, 28, 104, 44);

char *p = intToHexStr(count);

showString(shtctl, sht_win_b, 24, 28, COL8_FFFFFF,p);

}

}

}

}

task_b_main函数跟以前不同的是,它多了一个输入参数,这个参数就是它需要处理的窗口对象。task_b_main运行时,在它的循环体中,它会初始化一个计数器,然后把计数器的数值转换成字符串,然后再把字符串显示到窗口的内部,相关代码就是下面这几句:

showString(shtctl, sht_back, pos, 192, COL8_FFFFFF, "B");

// farjmp(0, 8*8);

timer_settime(timer_b, 100);

pos += 8;

boxfill8(sht_win_b->buf, 144, COL8_C6C6C6, 24, 28, 104, 44);

完成上面代码后,编译内核,将内核加载到虚拟机后,运行情况如下:

6ca5fe3b25609c6a9bba77295a9ebcff.png

桌面上产生了两个额外窗口,窗口的标题分别是taskb和taskc, 同时这两个窗口内,分别有两个计数字符串在不断的变动更新,这表明,两个窗口运行在不同的进程中,他们之间相互对立,互不影响。通过视频可以看到更详细的动态效果。

这篇关于Linux多窗口运行多进程,多进程,多窗体 - chenyi1982的个人空间 - OSCHINA - 中文开源技术交流社区...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/342607

相关文章

Linux磁盘分区、格式化和挂载方式

《Linux磁盘分区、格式化和挂载方式》本文详细介绍了Linux系统中磁盘分区、格式化和挂载的基本操作步骤和命令,包括MBR和GPT分区表的区别、fdisk和gdisk命令的使用、常见的文件系统格式以... 目录一、磁盘分区表分类二、fdisk命令创建分区1、交互式的命令2、分区主分区3、创建扩展分区,然后

Linux中chmod权限设置方式

《Linux中chmod权限设置方式》本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活... 目录设置基本权限命令:chmod1、权限介绍2、chmod命令常见用法和示例3、文件权限详解4、ch

Linux内核之内核裁剪详解

《Linux内核之内核裁剪详解》Linux内核裁剪是通过移除不必要的功能和模块,调整配置参数来优化内核,以满足特定需求,裁剪的方法包括使用配置选项、模块化设计和优化配置参数,图形裁剪工具如makeme... 目录简介一、 裁剪的原因二、裁剪的方法三、图形裁剪工具四、操作说明五、make menuconfig

Linux使用nohup命令在后台运行脚本

《Linux使用nohup命令在后台运行脚本》在Linux或类Unix系统中,后台运行脚本是一项非常实用的技能,尤其适用于需要长时间运行的任务或服务,本文我们来看看如何使用nohup命令在后台... 目录nohup 命令简介基本用法输出重定向& 符号的作用后台进程的特点注意事项实际应用场景长时间运行的任务服

什么是cron? Linux系统下Cron定时任务使用指南

《什么是cron?Linux系统下Cron定时任务使用指南》在日常的Linux系统管理和维护中,定时执行任务是非常常见的需求,你可能需要每天执行备份任务、清理系统日志或运行特定的脚本,而不想每天... 在管理 linux 服务器的过程中,总有一些任务需要我们定期或重复执行。就比如备份任务,通常会选在服务器资

如何在一台服务器上使用docker运行kafka集群

《如何在一台服务器上使用docker运行kafka集群》文章详细介绍了如何在一台服务器上使用Docker运行Kafka集群,包括拉取镜像、创建网络、启动Kafka容器、检查运行状态、编写启动和关闭脚本... 目录1.拉取镜像2.创建集群之间通信的网络3.将zookeeper加入到网络中4.启动kafka集群

Linux限制ip访问的解决方案

《Linux限制ip访问的解决方案》为了修复安全扫描中发现的漏洞,我们需要对某些服务设置访问限制,具体来说,就是要确保只有指定的内部IP地址能够访问这些服务,所以本文给大家介绍了Linux限制ip访问... 目录背景:解决方案:使用Firewalld防火墙规则验证方法深度了解防火墙逻辑应用场景与扩展背景:

Linux下MySQL8.0.26安装教程

《Linux下MySQL8.0.26安装教程》文章详细介绍了如何在Linux系统上安装和配置MySQL,包括下载、解压、安装依赖、启动服务、获取默认密码、设置密码、支持远程登录以及创建表,感兴趣的朋友... 目录1.找到官网下载位置1.访问mysql存档2.下载社区版3.百度网盘中2.linux安装配置1.

C#如何优雅地取消进程的执行之Cancellation详解

《C#如何优雅地取消进程的执行之Cancellation详解》本文介绍了.NET框架中的取消协作模型,包括CancellationToken的使用、取消请求的发送和接收、以及如何处理取消事件... 目录概述与取消线程相关的类型代码举例操作取消vs对象取消监听并响应取消请求轮询监听通过回调注册进行监听使用Wa

Linux使用粘滞位 (t-bit)共享文件的方法教程

《Linux使用粘滞位(t-bit)共享文件的方法教程》在Linux系统中,共享文件是日常管理和协作中的常见任务,而粘滞位(StickyBit或t-bit)是实现共享目录安全性的重要工具之一,本文将... 目录文件共享的常见场景基础概念linux 文件权限粘滞位 (Sticky Bit)设置共享目录并配置粘