• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            tbwshc

            tbw

              C++博客 :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
              95 Posts :: 8 Stories :: 3 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(4)

            我參與的團(tuán)隊(duì)

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            作為 ADEOS 的開發(fā)者(或是其他操作系統(tǒng)的開發(fā)者),你需要知道如何創(chuàng)建和使用任務(wù)。就像別的抽象數(shù)據(jù)結(jié)構(gòu),Task 類有自己的成員函數(shù)。ADEOS的的任務(wù)接口比別的大多數(shù)操作系統(tǒng)要簡(jiǎn)單一些,因?yàn)樗皇莿?chuàng)建一個(gè)新的Task 對(duì)象。一旦創(chuàng)建,ADEOS 任務(wù)繼續(xù)在系統(tǒng)中存在,直到相關(guān)的函數(shù)返回。當(dāng)然,這也許永遠(yuǎn)不會(huì)發(fā)生(意即ADEOS 任務(wù)也許永遠(yuǎn)不會(huì)結(jié)束),但是,如果一旦發(fā)生了,那么該任務(wù)就會(huì)被操作系統(tǒng)刪除掉。Task 的構(gòu)造函數(shù)如下所示。調(diào)用者通過(guò)構(gòu)造函數(shù)的參數(shù)分配一個(gè)函數(shù),一個(gè)權(quán)限值,和一個(gè)可選擇的新任務(wù)的堆棧大小。第一個(gè)參數(shù),fUnCtion,是一個(gè)指向C/C++語(yǔ)言或匯編語(yǔ)言的函數(shù)指針,該函數(shù)是要在新任務(wù)的上下文環(huán)境中運(yùn)行的。該函數(shù)不需要任何輸人參數(shù),也不返回任何結(jié)果。第二個(gè)參數(shù)P,是一個(gè)單字節(jié)的整數(shù)(從1 到255),代表了任務(wù)的權(quán)限級(jí)別,這個(gè)權(quán)限級(jí)別是與別的任務(wù)相對(duì)而言的,在tb任務(wù)調(diào)度器選擇新的任務(wù)運(yùn)行的時(shí)候會(huì)用到(p 的值越大,表示權(quán)限越高)。
            TaskId Task::nextId = 0
            /**************************************************************
            *
            * Method : Task()
            *
            * Description : Create a new task and initialize its state.
            *
            * Notes :
            *
            * Returns :
            *
            **************************************************************/
            Task:Task(void (*function)(), Priority p, int stackSize)
            {
            stackSize /= sizeof(int); //Convert bytes to words.
            enterCS(); //Critical Section Begin
            //
            // Initialize the task-specific data.
            //
            if = Task::nextId++;
            state = Ready;
            priority = p;
            entryPoint = function;
            pStack = new int[stackSize];
            pNext = NULL;
            //
            // Initialize the processor context.
            //
            contextInit(&context, run, this, pStack + stackSize);
            //
            // Insert the task into the ready list.
            //
            os.readyList.insert(this);
            os.schedule(); // Scheduling Point
            exitCS(); // Critical Section End
            } /* Task() */
            注意這個(gè)例程的功能塊被兩個(gè)函數(shù) enterCS()和exitCS()的調(diào)用包圍。在這些調(diào)用之間的代碼塊叫作tb臨界區(qū)(critical section)。臨界區(qū)是一個(gè)程序必須完整執(zhí)行的一部分。也就是說(shuō),組成這一個(gè)部分的指令必須沒(méi)有中斷地按照順序執(zhí)行。因?yàn)橹袛嗫赡茈S時(shí)發(fā)生,保證不受到中斷的唯一辦法就是在執(zhí)行關(guān)鍵區(qū)期間禁止中斷。因此在關(guān)鍵區(qū)的開始調(diào)用enterCS 以保存中斷的允許狀態(tài)以及禁止進(jìn)一步的中斷。在關(guān)鍵區(qū)尾部調(diào)用exitCS 以恢復(fù)前面保存的中斷調(diào)用。我們會(huì)看到在下面每一個(gè)例程中都應(yīng)用了同樣的技巧。
            在前面代碼中,有幾個(gè)在構(gòu)造函數(shù)里調(diào)用的其他例程,但是在這里我沒(méi)有空間列出。它們是contextInit()和os.readyList.insert()例程。例程contextInit()為任務(wù)建立了初始的設(shè)備場(chǎng)景。這個(gè)例程必定是處理器專用的,因此是用匯編語(yǔ)言寫的。
            contextInit()有四個(gè)參數(shù)。第一個(gè)是一個(gè)指向待初始比的設(shè)備場(chǎng)景數(shù)據(jù)結(jié)構(gòu)指針。第二個(gè)是一個(gè)指向啟動(dòng)函數(shù)的指針。這是一個(gè)特殊的ADEOS 函數(shù),叫作run(),它被用來(lái)啟動(dòng)一個(gè)任務(wù),并且如果以后相關(guān)的函數(shù)退出了,它被用來(lái)做其后的清理工作。第三個(gè)參數(shù)是一個(gè)指向新任務(wù)對(duì)象的指針。這個(gè)參數(shù)被傳遞給run(),因此相關(guān)的任務(wù)就能夠被啟動(dòng)。第四個(gè)和最后一個(gè)參數(shù)是指向新任務(wù)棧的指針。
            另一個(gè)函數(shù)調(diào)用是 os.readyList.insert()。這個(gè)函數(shù)把新任務(wù)加入到操作系統(tǒng)內(nèi)部的就緒任務(wù)列表中。readyList 是一個(gè)TaskList 類型的對(duì)象。這個(gè)類是那些具有insert()和remove()兩個(gè)方法的任務(wù)(按照優(yōu)先級(jí)排序)的鏈表。感興趣的讀者如果想知道這些函數(shù)是如何實(shí)現(xiàn)的就應(yīng)該下載和研究其ADEOS 的源代碼。你將在下面的討論中了解到更多有關(guān)就緒列表的問(wèn)題。
            posted on 2013-09-05 16:58 tbwshc 閱讀(844) 評(píng)論(0)  編輯 收藏 引用

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            无码专区久久综合久中文字幕| 很黄很污的网站久久mimi色| 波多野结衣中文字幕久久| 情人伊人久久综合亚洲| 久久综合一区二区无码| 久久精品无码一区二区无码| 污污内射久久一区二区欧美日韩| 久久国产精品77777| 污污内射久久一区二区欧美日韩| 久久精品国产亚洲77777| 一级做a爰片久久毛片毛片| 99久久婷婷国产综合亚洲| 国内精品伊人久久久影院| 国产亚州精品女人久久久久久| 久久国产亚洲精品无码| 色综合久久中文字幕无码| 午夜视频久久久久一区 | 久久夜色精品国产噜噜噜亚洲AV| 日本一区精品久久久久影院| 久久99国产精品尤物| 亚洲午夜久久久影院| 久久久久亚洲AV无码观看| 久久丝袜精品中文字幕| 欧美国产精品久久高清| 精品国产综合区久久久久久| 久久综合狠狠色综合伊人| 久久国产高潮流白浆免费观看| 中文字幕无码精品亚洲资源网久久| 久久久精品日本一区二区三区| 91精品国产91久久久久久| 亚洲一区中文字幕久久| 99久久国产综合精品五月天喷水| 99精品国产在热久久| 成人久久久观看免费毛片| 国产成人久久激情91| 国产精品一久久香蕉国产线看| 99久久免费国产精精品| 99久久99久久精品国产片果冻| 国产呻吟久久久久久久92| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 久久亚洲国产精品123区|