日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 嵌入式 > 嵌入式軟件
[導(dǎo)讀]對symbain的學(xué)習(xí)已經(jīng)又幾個月了,今天來寫寫自己的一些活動服務(wù)對象使用方法.symbian官方推薦使用活動服務(wù)對象(CActive)來代替多線程的使用,我想這個道理是很明了的,在手機(jī)這

對symbain的學(xué)習(xí)已經(jīng)又幾個月了,今天來寫寫自己的一些活動服務(wù)對象使用方法.

symbian官方推薦使用活動服務(wù)對象(CActive)來代替多線程的使用,我想這個道理是很明了的,在手機(jī)這樣的小內(nèi)存設(shè)備里,運行多線程的程序是非常耗資源的,為了節(jié)約資源,symbian提供了一個活動服務(wù)對象的框架,允許把程序里并發(fā)執(zhí)行對象(其實不是并發(fā),不過宏觀上看來是)放在一個線程里面執(zhí)行,這些并發(fā)工作的對象就通過活動規(guī)劃器(ActiveScheduler)來進(jìn)行管理.

關(guān)于這兩個東西的介紹,網(wǎng)上有一大堆的文檔,我就不在這里廢話了,如何使用呢?這里我先舉一個簡單的計數(shù)器的例子.我選擇寫一個exe的程序,也就是說程序是以E32Main為入口的.

GLDEF_C TInt E32Main()

{

CTrapCleanup* cleanup=CTrapCleanup::New();

TRAPD(error,callInstanceL());

if (error != KErrNone){

printf("get error %d/r/n", error);

}

delete cleanup;

return 0;

}

以上的內(nèi)容是每一個exe文件都應(yīng)該做的,CTrapCleanup* cleanup=CTrapCleanup::New()建立一個清除堆棧,以便程序在異常退出的時候把清除堆棧里面的資源都釋放掉.當(dāng)然你也可以加上堆檢測宏,這里我就不多說了.TRAPD是symbian里面經(jīng)常使用的宏,功能類似于try,第一個參數(shù)是讓定義一個錯誤返回值變量的名字, 后面就是可能有異常的你寫的函數(shù).當(dāng)這個函數(shù)異常時,程序不會crash, 你可以得到異常的原因.可以參考nokia論壇上的一些關(guān)于這些使用的文檔.

接下來是vcallInstanceL函數(shù),在這個函數(shù)里面我來建立ActiveScheduler.

LOCAL_C void callInstanceL()

{

CActiveScheduler* scheduler = new(ELeave) CActiveScheduler();

CleanupStack::PushL(scheduler);

CActiveScheduler::Install(scheduler);

TRAPD(error,doInstanceL());

if(error) {

printf("error code=%d/r/n",error);

}

else {

printf("OK!/r/n[press any key]");

}

CleanupStack::PopAndDestroy(scheduler);

}

這段程序很簡單就是創(chuàng)建一個活動規(guī)劃器,并壓入清除棧,然后安裝活動規(guī)劃器,這樣就可以用了.再執(zhí)行真正的實例函數(shù),最后出棧銷毀.doinstanceL我們放到最后來寫,現(xiàn)在來構(gòu)造我們的活動計數(shù)器對象.

class TimeCount : public CActive

{

public :

static TimeCount* NewLC(); // 構(gòu)造函數(shù)

~TimeCount();

void StartL(); // 計數(shù)開始

void ConstructL();

void RunL(); // 延時事件到達(dá)以后的處理函數(shù)

void DoCancel(); // 取消請求提交

void setDelayTime(int delayTime);

private:

TimeCount();

RTimer iTimer; // 定時器

int iTimeCount; // 計數(shù)器

int mTime; // 計數(shù)間隔時間 單位秒

};

TimeCount::TimeCount()

: CActive(0) // 這里可以設(shè)置活動對象的優(yōu)先級

{

// 把自己加入活動規(guī)劃器

CActiveScheduler::Add(this);

}

TimeCount* TimeCount::NewLC()

{

TimeCount* result = new (ELeave) TimeCount();

CleanupStack::PushL( result );

result->ConstructL();

return result;

}

void TimeCount::DoCancel(void)

{

iTimer.Cancel();

}

void TimeCount::setDelayTime(int mTime)

{

DelayTime = mTime;

}

TimeCount::~TimeCount()

{

Cancel();

iTimer.Close();

}

void TimeCount::StartL()

{

// 設(shè)定定時器狀態(tài)為每隔mTime秒鐘狀態(tài)完成一次

iTimer.After(iStatus, 10000 * 100 * mTime);

// 提交異步請求

SetActive();

}

void TimeCount::ConstructL()

{

// 初始化計數(shù)器和定時器

iTimeCount = 0;

User::LeaveIfError(iTimer.CreateLocal());

}

void TimeCount::RunL()

{

// 計數(shù)器+1以后繼續(xù)提交延時請求事件

printf("The Count is ->>%d", iTimeCount++);

StartL();

}

每一個活動服務(wù)對象都有一個iStatus來標(biāo)識當(dāng)前對象的狀態(tài).在這里我們把iStatus設(shè)定為iTimer.After(iStatus, 10000 * 100 * mTime);也就是定時器定時mTime秒鐘以后iStatus發(fā)生改變,這個時候活動規(guī)劃器會收到這個狀態(tài)的改變,從而調(diào)用相應(yīng)活動對象的處理函數(shù),也就是RunL函數(shù).在RunL函數(shù)里面進(jìn)行計數(shù)和輸出,然后調(diào)用startL重新設(shè)置定時器和對象狀態(tài),再提交給活動規(guī)劃器.這樣mTime秒鐘以后活動規(guī)劃器會再次調(diào)用RunL函數(shù).一直這樣重復(fù),這樣就達(dá)到了計數(shù)器的效果.

最后我們來寫doinstanceL函數(shù)

LOCAL_C void doInstanceL()

{

TimeCount* timeCount = TimeCount::NewLC();

// 每隔一秒鐘打印一次

TimeCount->setDelayTime(1);

TimeCount->StartL();

CActiveScheduler::Start();

CleanupStack::PopAndDestroy(1);

}

創(chuàng)建好對象以后,加上CActiveScheduler::Start()程序就開始運行了,這句話告訴活動規(guī)劃器該等待對象的狀態(tài)的改變了,在這里就是timeCount的iStatus的改變.等iStatus改變并調(diào)用了RunL以后,繼續(xù)等待iStstus的改變,這樣我們使用活動對象的計數(shù)器就能夠通過消息驅(qū)動運行起來了.

這里的CActiveScheduler只管理了一個CActive對象,就是timeCount,可以用類似的方法實現(xiàn)多個CActive,并且都加入CActiveScheduler,CActiveScheduler將會等待所有加入它的CActive的狀態(tài)的改變,其中有一個的狀態(tài)改變就會去執(zhí)行對應(yīng)的活動對象的處理函數(shù),當(dāng)狀態(tài)同時發(fā)生的時候,會通過對象的優(yōu)先級來決定先調(diào)用誰的RunL函數(shù).CActiveScheduler也是非搶占式的,當(dāng)一個RunL函數(shù)還沒有執(zhí)行完的時候,如果另一個CActive的狀態(tài)改變,會等待RunL執(zhí)行完以后再執(zhí)行另一個CActive的處理函數(shù).[!--empirenews.page--]

用起來還算簡單吧?.

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護(hù)是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機(jī)驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機(jī)驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉