色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

談談cocos2d-x多線程渲染

Dbwd_Imgtec ? 來源:未知 ? 作者:胡薇 ? 2018-05-23 10:40 ? 次閱讀

可行性:

游戲循環主要包括這幾個部分:

硬件事件,主要就是指觸屏事件,按鍵事件和鼠標事件;

游戲事件,主要指定時器事件和預定義事件,比如schedule;

游戲邏輯,對于胖腳本端來說,這個就指的腳本邏輯;

渲染數據的生成,在引擎里面就是指node的visit,這里計算生成所有即將發往OpenGL的數據,包括頂點紋理坐標等attribute數據,變換矩陣紋理等uniform數據,混合模式等渲染狀態;

通過OpenGL接口把所有數據發往OpenGL。

這幾個步驟里面,只有第五個步驟需要涉及到OpenGL操作,而前面四個步驟都是為第五個步驟做準備,而第五個步驟不用或者很少需要反饋數據給前面四個步驟。這是一個典型的生產者消費者模式,在很低線程同步開銷的情況下課采用多線程處理。

必要性:

處理游戲邏輯(包括前四個步驟)承擔了太多cpu運算,而發數據到OpenGL也相當耗時,尤其涉及到多次的渲染狀態切換。在多核cpu上面把二者分開可以提高并行性,進而提高游戲幀率。

一些方案:

cocos2d-x3.0之后有一個很大的轉變就是不是在visit里面渲染,而是在visit里面生成渲染命令,并把命令發往render類緩存,等待某個時機處理這些命令,即渲染。

這是一個典型的命令模式,只要保證這些command的執行處理的數據和主線程(游戲邏輯的執行線程)不一樣或者通過加鎖做好和主線程的數據互斥,就可以保證線程安全。大多數數據我們都可以在visit(其實是draw)里面生成一份拷貝,而對于較少個數但是每個都包含大量頂點數據的對象,我們可以通過加鎖做好互斥,比如粒子系統。較少的線程互斥操作也不會造成太大線程通信開銷。

游戲主循環也是先執行游戲邏輯相關的四個步驟,然后通過條件變量告知渲染線程數據已經準備好。我們也可以使用雙緩存系統,即創建兩個渲染命令緩存,在渲染線程使用一個命令緩存進行渲染的時候,主線程邏輯可以把渲染命令發往另一個緩存。

如果主線程邏輯確實需要OpenGL處理才能得到的一些數據,我們也可以采用一些較為低效的折中方案。主線程通過類似于schedule的方式把命令發往渲染線程,然后等待,渲染線程維持一個這樣的命令隊列,每個周期優先處理這個隊列,處理完成后通知主線程。這種做法不易多用。

說個例子,同步創建紋理并生成sprite的操作,這個生成紋理的部分需要放到渲染線程,這個就可以采用這種方案。而事實上游戲邏輯根本不需要關心這個紋理到底長什么樣,主線程可以不用等到渲染線程處理完成這個紋理再繼續運行,渲染線程再處理完成這個紋理后,通過schedule告知主線程,主線程更新這個texture2d對象的紋理ID即可,大大提高效率。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 多線程
    +關注

    關注

    0

    文章

    278

    瀏覽量

    20018
  • 渲染
    +關注

    關注

    0

    文章

    70

    瀏覽量

    10932

原文標題:cocos2d-x多線程渲染的一些探討

文章出處:【微信號:Imgtec,微信公眾號:Imagination Tech】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    socket 多線程編程實現方法

    在現代網絡編程中,多線程技術被廣泛應用于提高服務器的并發處理能力。Socket編程是網絡通信的基礎,而將多線程技術應用于Socket編程,可以顯著提升服務器的性能。 多線程編程的基本概念 多線
    的頭像 發表于 11-12 14:16 ?398次閱讀

    Python中多線程和多進程的區別

    Python作為一種高級編程語言,提供了多種并發編程的方式,其中多線程與多進程是最常見的兩種方式之一。在本文中,我們將探討Python中多線程與多進程的概念、區別以及如何使用線程池與進程池來提高并發執行效率。
    的頭像 發表于 10-23 11:48 ?417次閱讀
    Python中<b class='flag-5'>多線程</b>和多進程的區別

    ESP32會不會有多線程問題,需要加鎖嗎?

    ESP32會不會有多線程問題,需要加鎖嗎
    發表于 07-19 08:05

    多線程設計模式到對 CompletableFuture 的應用

    最近在開發 延保服務 頻道頁時,為了提高查詢效率,使用到了多線程技術。為了對多線程方案設計有更加充分的了解,在業余時間讀完了《圖解 Java 多線程設計模式》這本書,覺得收獲良多。本篇文章將介紹其中
    的頭像 發表于 06-26 14:18 ?372次閱讀
    從<b class='flag-5'>多線程</b>設計模式到對 CompletableFuture 的應用

    bootloader開多線程做引導程序,跳app初始化后直接進hardfualt,為什么?

    如標題,想做一個遠程升級的項目,bootloader引導區域和app都是開多線程跑的,就是自己寫了個小的任務調度器,沒什么功能主要是想讓程序快速的響應,延時不會對其他程序造成堵塞,程序測試
    發表于 04-18 06:07

    鴻蒙OS開發實例:【ArkTS類庫多線程CPU密集型任務TaskPool】

    CPU密集型任務是指需要占用系統資源處理大量計算能力的任務,需要長時間運行,這段時間會阻塞線程其它事件的處理,不適宜放在主線程進行。例如圖像處理、視頻編碼、數據分析等。 基于多線程并發機制處理CPU密集型任務可以提高CPU
    的頭像 發表于 04-01 22:25 ?858次閱讀
    鴻蒙OS開發實例:【ArkTS類庫<b class='flag-5'>多線程</b>CPU密集型任務TaskPool】

    鴻蒙APP開發:【ArkTS類庫多線程】TaskPool和Worker的對比(2)

    創建Worker的線程稱為宿主線程(不一定是主線程,工作線程也支持創建Worker子線程),Worker自身的
    的頭像 發表于 03-27 15:44 ?547次閱讀
    鴻蒙APP開發:【ArkTS類庫<b class='flag-5'>多線程</b>】TaskPool和Worker的對比(<b class='flag-5'>2</b>)

    鴻蒙APP開發:【ArkTS類庫多線程】TaskPool和Worker的對比

    TaskPool(任務池)和Worker的作用是為應用程序提供一個多線程的運行環境,用于處理耗時的計算任務或其他密集型任務。可以有效地避免這些任務阻塞主線程,從而最大化系統的利用率,降低整體資源消耗,并提高系統的整體性能。
    的頭像 發表于 03-26 22:09 ?665次閱讀
    鴻蒙APP開發:【ArkTS類庫<b class='flag-5'>多線程</b>】TaskPool和Worker的對比

    鴻蒙原生應用開發-ArkTS語言基礎類庫多線程TaskPool和Worker的對比(一)

    TaskPool(任務池)和Worker的作用是為應用程序提供一個多線程的運行環境,用于處理耗時的計算任務或其他密集型任務。可以有效地避免這些任務阻塞主線程,從而最大化系統的利用率,降低整體資源消耗
    發表于 03-25 14:11

    鴻蒙原生應用開發-ArkTS語言基礎類庫多線程I/O密集型任務開發

    filePath2 = ...; // 使用TaskPool執行包含密集I/O的并發函數 // 數組較大時,I/O密集型任務任務分發也會搶占主線程,需要使用多線程能力
    發表于 03-21 14:57

    java實現多線程的幾種方式

    了多種實現多線程的方式,本文將詳細介紹以下幾種方式: 1.繼承Thread類 2.實現Runnable接口 3.Callable和Future 4.線程池 5.Java 8中
    的頭像 發表于 03-14 16:55 ?741次閱讀

    AT socket可以多線程調用嗎?

    請問AT socket 可以多線程調用嗎? 有互鎖機制嗎,還是要自己做互鎖。
    發表于 03-01 08:22

    什么是多核多線程?多核多線程如何提高程序的運行效率?

    線程無法充分利用多核處理器的并行計算能力。
    的頭像 發表于 02-20 10:22 ?1401次閱讀

    linux多線程編程實例

    linux線程
    的頭像 發表于 02-15 21:16 ?485次閱讀
    linux<b class='flag-5'>多線程</b>編程實例

    Redis7單線程多線程詳解

    主要是指Redis的網絡IO和鍵值對讀寫是由一個線程來完成的。
    的頭像 發表于 01-16 17:33 ?1874次閱讀
    Redis7單<b class='flag-5'>線程</b>與<b class='flag-5'>多線程</b>詳解
    主站蜘蛛池模板: 俄罗斯9一14 young处| 簧片免费观看| 欧美成 人 网 站 免费| 草莓视频在线播放视频| 偷尝禁果H1V1幸运的山熊| 国产伦精品一区二区免费| 一个人的视频在线观看免费观看| 乱精品一区字幕二区| 超碰国产视频免费播放| 亚洲国产黄色| 暖暖视频中国在线观看免费韩国| 国产69精品久久久熟女| 亚洲专区中文字幕视频专区| 尿了么app| 国产在线精品国自产拍影院午夜| 51xx午夜影视福利| 无码免费视频AAAAAA片草莓| 久久精品无码一区二区日韩av | max girls 大感谢祭| 午夜看片网| 欧美fxxx| 久久99视频免费| 东京热无码中文字幕av专区| 国产成人精品视频| 一个人看的WWW高清电影| 区久久AAA片69亚洲| 精品视频在线一区| 在线观看插女生免费版| 日本一区精品久久久久影院| 九九热在线观看| 国产AV国产精品国产三级在线L| 在线欧美精品一区二区三区| 天美麻豆成人AV精品视频| 蜜臀AV999无码精品国产| 和姐姐做插得很深| 大屁股妇女流出白浆| 1区2区3区4区产品不卡码网站| 性盈盈剧场| 毛片一区二区三区| 国产睡熟迷奷系列网站| 成人毛片在线播放|