• <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>

            天行健 君子當自強而不息

            Getting Online with Multiplayer Gaming(11)

             

            The Message Queue

            The server never deals directly with incoming messages; instead, the server pulls
            messages from the queue. If a message needs to be processed, it must be inserted
            into the queue. Using a queue ensures that the server never gets bogged down with
            processing incoming network data.

            The queue is just an array of sMsg structures that is allocated when the application
            class is initialized. I set a limit of 1,024 messages to be allocated for the server, but you
            can change that amount just by altering the MAX_MESSAGE macro in the source code.

            To track messages being added and removed from the queue, use two variables—
            m_msg_head and m_msg_tail. Check out Figure 19.12 to see how the queue uses those
            two variables to track which messages are to be inserted or removed.

            Whenever a message needs to be added to the message queue, a special function is
            called. That function is cApp::queue_msg, and it takes a single argument: the
            sMsg structure to add to the queue.

            Remember the incoming message functions of cApp (covered in the section “DirectPlay
            Messages to Game Messages”)? Those functions built a message structure and added
            the message to the queue via queue_msg. Look at the queue_msg code to see what’s
            going on:

            bool cApp::queue_msg(const void* msg)
            {
                
            const sMsgHeader* header = (const sMsgHeader*) msg;

                
            // return if no room left in queue
                if((m_msg_head + 1) % MAX_MESSAGES == m_msg_tail)
                    
            return false;

                
            // stuff message into queue
                if(header->size <= sizeof(sMsg))
                {
                    EnterCriticalSection(&m_msg_cs);

                    memcpy(&m_msgs[m_msg_head], msg, header->size);

                    
            // goto next empty message (flip around if at end)
                    m_msg_head++;

                    
            if(m_msg_head >= MAX_MESSAGES)
                        m_msg_head = 0;

                    LeaveCriticalSection(&m_msg_cs);
                }

                
            return true;
            }

            As you can see, queue_msg merely copies the supplied sMsg structure into the
            next available element in the message array (pointed to by m_msg_head). Two things
            you haven’t seen are the EnterCriticalSection and LeaveCriticalSection functions.
            Windows uses these two functions to restrict the application’s access to memory
            (using the EnterCriticalSection function), only allowing a single process to modify
            that memory. Once you finish modifying the memory, you need to inform
            Windows by calling LeaveCriticalSection.

            Although this may not make sense at first, think about it like this—the network
            component (a process) is running in the background at the same time as the application
            (another process). If the network component is adding messages to the
            array while the application is trying to remove messages or modify the messages,
            the program data can become corrupt. Critical sections ensure that only one
            process gets sole access to data for a short time.

            posted on 2007-12-18 21:25 lovedday 閱讀(163) 評論(0)  編輯 收藏 引用

            公告

            導航

            統計

            常用鏈接

            隨筆分類(178)

            3D游戲編程相關鏈接

            搜索

            最新評論

            国产精品99久久久久久猫咪| 中文字幕乱码人妻无码久久| 国产精品久久久久影视不卡| 69SEX久久精品国产麻豆| 成人国内精品久久久久一区 | 国产成人久久精品激情| 久久Av无码精品人妻系列| 久久―日本道色综合久久| 久久久WWW成人免费精品| 久久国产午夜精品一区二区三区| 亚洲伊人久久成综合人影院 | 亚洲精品午夜国产VA久久成人| 久久人人爽人人爽人人AV东京热| 青青草原综合久久大伊人精品| 久久亚洲av无码精品浪潮| 久久综合九色综合网站| 久久综合成人网| 人人狠狠综合久久亚洲婷婷| 99精品久久精品一区二区| 久久久久99精品成人片| 久久w5ww成w人免费| 精品久久亚洲中文无码| 国产一区二区精品久久凹凸| 久久婷婷五月综合色奶水99啪| 日韩AV毛片精品久久久| 88久久精品无码一区二区毛片| 亚洲国产精品无码久久久秋霞2| 久久久久九国产精品| 高清免费久久午夜精品| 伊人色综合久久天天人手人婷 | 久久精品综合网| 国产 亚洲 欧美 另类 久久 | 久久天天躁狠狠躁夜夜2020老熟妇| 人妻精品久久无码区| 久久久www免费人成精品| 中文成人无码精品久久久不卡| 久久精品国产99久久久香蕉| 亚洲精品高清久久| 中文字幕亚洲综合久久| 久久国产精品久久精品国产| 久久免费国产精品一区二区|