青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 132  文章 - 51  trackbacks - 0
<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用鏈接

留言簿(7)

隨筆分類

隨筆檔案

文章分類

文章檔案

cocos2d-x

OGRE

OPenGL

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

今天寫包裹中物品排序,有一些需要注意的問題和效率上的需要注意的事情,特此記下,備忘:

我的方法是:
1..遍歷包裹,將需要疊加的物品疊加
2..再用qsort進行排序 (這個方法非常的好用,屢試不爽啊,他能將需要排序的數組重寫數據.hoho~~~)

排序原則:

   先判斷物品類型->再判斷物品ID->再判斷物品擁有數量


需要注意的問題是:防止用戶重復點擊 一直排序
解決方法:只有服務器回復排序完成之后,客戶端才能向服務器發送排序消息

來段測試的小代碼

// test.cpp : 定義控制臺應用程序的入口點。
//

#include 
"stdafx.h"
#include 
<vector>
#include 
<Windows.h>
using namespace std;



struct stElement
{
    
int nType;
    
int nCnt;
    stElement( 
int type, int cnt )
    
{
        nType 
= type;
        nCnt 
= cnt;
    }

}
;


int compare( const void *arg1, const void *arg2 )
{
    stElement
* p1 = (stElement*)arg1;
    stElement
* p2 = (stElement*)arg2;

    
if ( p1->nType < p2->nType ){
        
return -1;
    }
else if ( p1->nType > p2->nType){
            
return 1;
    }
else{
        
if ( p1->nCnt < p2->nCnt )
            
return 1;
        
else if ( p1->nCnt  > p2->nCnt )
            
return -1;
        
else
            
return 0;
    }

}


int _tmain(int argc, _TCHAR* argv[])
{
    
    vector
<stElement>        vec;
    vec.push_back( stElement(
3,10) );
    vec.push_back( stElement(
5,10) );
    vec.push_back( stElement(
1,11) );
    vec.push_back( stElement(
2,50) );
    vec.push_back( stElement(
3,9) );
    vec.push_back( stElement(
3,20) );
    vec.push_back( stElement(
7,1) );
    vec.push_back( stElement(
3,8) );
    vec.push_back( stElement(
4,7) );
    vec.push_back( stElement(
3,8) );
    vec.push_back( stElement(
3,5) );

    qsort( 
&vec[0], vec.size(), sizeof(stElement), compare );


    
return 0;
}


posted on 2010-12-18 18:49 風輕云淡 閱讀(2082) 評論(7)  編輯 收藏 引用 所屬分類: UI

FeedBack:
# re: UI中包裹物品排序 2010-12-18 19:23 classyk
都已經使用了stl,為啥不直接使用std::sort呢?  回復  更多評論
  
# re: UI中包裹物品排序[未登錄] 2010-12-19 11:13 楊粼波
classyk說的對,STL里面有自己實現快排,效率不成問題,而且以包裹如此小的數據規模而言,綽綽有余.

對于防止多次排序,是有很好的辦法的.
你設置一個"可以排序標識符"比如:m_bCanSortBag,
排完序以后,你就設置為false.如果,包裹有變化,你設置為true.
客戶端做一次判定,服務器端再做一次判定,就可以很好的處理了.  回復  更多評論
  
# re: UI中包裹物品排序 2010-12-20 11:46 金慶
包裹整理是客戶端功能. 嚴格說, 應該是外掛(輔助程序)的功能. 只要客戶端開放了包裹讀取和操作的接口, 用戶可以自定義包裹整理.  回復  更多評論
  
# re: UI中包裹物品排序 2010-12-21 16:11 Let me see see
@楊粼波
查看了下源代碼,看了些資料對比了下 STL::sort 和qsort,MS stl中的sort效率更高,以后使用sort

我的游戲中每個包裹項BagItem數據快百條了,144個包裹項,數據量不是很小

你說的對于防止多次排序方法,我做的和你差不多,你說如果包裹有變化設置flag=true
我原來也想這么做來著,但是監視包裹變化我認為不是很容易,往包裹中添加物品,包裹中拖拽出物品,包裹中物品使用,還有包裹中物品交換、疊加,包裹和商店等界面的交互etc.... 我需要在所有的這些地方判斷包裹是否改變么

我現在只能做到服務器發送回確認排序后才能再次排序.不知道有沒有更好的辦法

順便蛋疼的問一句:你就是Cppblog中排行第三的神人么  回復  更多評論
  
# re: UI中包裹物品排序 2010-12-21 16:21 Let me see see
@金慶
這個不可能開放吧 呵呵 開放了包裹操作的接口 玩家不就可以自己push裝備和物品了么,對掛了解少. 你說的是不是通過腳本形式的接口啊
  回復  更多評論
  
# re: UI中包裹物品排序 2010-12-22 09:26 zuhd
@Let me see see
是的,他就是那個神人

vector<stElement> vec,你存儲對象實例,然后做排序,我覺得中間會用了若干次拷貝構造函數,倒不如在element中加一個變量為nLocation,表示該元素在背包中的位置,用vector<stElement*>來存儲,然后每次去修改每個元素里的nLocation

  回復  更多評論
  
# re: UI中包裹物品排序 2010-12-23 14:17 楊粼波
幾百個,不值一提的數量級.
STL幾乎瞬間搞定.

不管你做什么操作,都會操作背包里面的邏輯數據,只要數據發生改變,數據就臟了.你可以用觀察者模式,去通知UI或者別的需要訂閱的對象.  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              亚洲伦理在线观看| 亚洲精品在线观看免费| 亚洲天堂激情| 午夜久久久久| 欧美一区二区三区免费视| 久久视频在线看| 久久精品日韩| 国产午夜精品全部视频播放| 一本色道88久久加勒比精品| 一本在线高清不卡dvd| 久久久人人人| 亚洲精品欧美日韩专区| 亚洲影院污污.| 国模大胆一区二区三区| 久久精品国产亚洲5555| 久久久久88色偷偷免费| 国产亚洲激情视频在线| 久久狠狠亚洲综合| 你懂的视频欧美| 亚洲另类春色国产| 欧美性猛交视频| 久久成人免费| 欧美高清在线视频| 欧美在线关看| 亚洲视频香蕉人妖| 久久国产精品第一页| 亚洲国产成人精品女人久久久 | 卡通动漫国产精品| 欧美a级片网| 午夜亚洲影视| 亚洲精品少妇网址| 国产网站欧美日韩免费精品在线观看| 欧美一级久久| 亚洲欧美春色| 亚洲国产另类久久精品| 亚洲小视频在线观看| 亚洲精品视频在线观看免费| 国产精品亚洲不卡a| 欧美人与禽猛交乱配| 久久亚洲私人国产精品va| 午夜精品国产| 亚洲永久精品国产| 中日韩视频在线观看| 亚洲激情视频在线观看| 欧美成人国产| 欧美成年人网站| 欧美激情视频在线播放| 欧美国内亚洲| 欧美高清hd18日本| 亚洲国产综合在线| 亚洲欧洲精品一区二区三区| 亚洲欧洲精品天堂一级| 欧美成人免费网| 欧美成人午夜激情视频| 欧美日韩午夜在线| 国产精品日韩精品| 伊人成人在线| 一区二区三区日韩欧美| 久久精品1区| 亚洲高清123| 亚洲欧美伊人| 欧美精品日韩| 国产自产在线视频一区| 日韩亚洲欧美高清| 久久成人人人人精品欧| 亚洲国产成人久久综合| 亚洲午夜在线观看| 欧美成人自拍| 欧美性事在线| 亚洲另类一区二区| 欧美专区在线播放| 亚洲免费久久| 久久综合狠狠综合久久综合88| 欧美激情视频在线免费观看 欧美视频免费一 | 欧美成人r级一区二区三区| 欧美乱妇高清无乱码| 91久久中文字幕| 久久蜜臀精品av| 久久国产精品久久久久久久久久| 欧美高清自拍一区| 夜夜嗨av一区二区三区网页| 久久天天躁狠狠躁夜夜av| 亚洲欧美国产精品桃花| 亚洲黄色免费电影| 久久久久国产精品一区| 狠狠色狠狠色综合| 久久久久久自在自线| 久久久水蜜桃| 最近中文字幕日韩精品 | 亚洲主播在线播放| 日韩亚洲欧美一区| 国产精品青草久久久久福利99| 亚洲在线观看免费| 久久精品人人做人人综合| 激情综合色综合久久| 欧美ed2k| 欧美四级在线观看| 久久久久欧美精品| 毛片av中文字幕一区二区| 一区二区三区av| 欧美专区在线观看一区| 日韩一级免费观看| 久久av一区二区三区漫画| 亚洲久色影视| 久久精品亚洲精品| 在线午夜精品| 欧美成人精品一区二区| 欧美一区二区性| 欧美肥婆在线| 亚洲国产日韩精品| 伊人久久综合97精品| 亚洲女人天堂av| 亚洲字幕一区二区| 欧美日本在线播放| 欧美成人精品h版在线观看| 国产精品一区在线播放| 亚洲精品一区在线| 久久久国产视频91| 亚洲经典在线| 久久精品人人做人人综合| 农夫在线精品视频免费观看| 欧美精品v日韩精品v韩国精品v| 欧美日韩亚洲一区三区| 亚洲福利在线看| 久久精品综合一区| 欧美专区福利在线| 国产自产女人91一区在线观看| 午夜亚洲精品| 亚洲美女免费精品视频在线观看| 一区二区三区视频免费在线观看| 99精品免费视频| 欧美日韩免费观看一区=区三区| 欧美三级欧美一级| 在线观看成人小视频| 狠狠88综合久久久久综合网| 香港成人在线视频| 亚洲影院色在线观看免费| 国产精品亚洲成人| 亚洲无毛电影| 老鸭窝亚洲一区二区三区| 亚洲性图久久| 国产一区二区三区久久久久久久久| 亚洲欧美激情在线视频| 六月婷婷一区| 亚洲午夜一区| 伊人久久婷婷色综合98网| 欧美日韩精品免费看| 久久精品国产久精国产一老狼| 欧美激情网站在线观看| 欧美一区二区日韩一区二区| 狼狼综合久久久久综合网| 国产午夜精品一区二区三区视频 | 久久精品电影| 亚洲激情av在线| 国产精品中文字幕在线观看| 美日韩免费视频| 久久国产手机看片| 中文成人激情娱乐网| 一区二区三区欧美成人| 午夜在线视频一区二区区别| 欧美激情一区二区三区成人| 久久精品国内一区二区三区| 亚洲调教视频在线观看| 亚洲视频在线观看网站| 亚洲欧美日韩综合| 欧美一区二区日韩一区二区| 亚洲天堂久久| 久久成人久久爱| 欧美fxxxxxx另类| 欧美日韩国产精品专区| 欧美视频在线免费| 国产午夜精品麻豆| 亚洲大黄网站| 欧美一区二区在线播放| 亚洲国产精品一区二区久| 亚洲人成人一区二区在线观看| 亚洲午夜精品在线| 久久综合久久综合久久综合| 欧美日韩一区二区三区高清| 国产精品麻豆欧美日韩ww| 亚洲缚视频在线观看| 亚洲自拍16p| 亚洲狠狠丁香婷婷综合久久久| 在线视频精品一| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美专区第一页| 国产精品免费网站| 亚洲人成在线观看网站高清| 香蕉免费一区二区三区在线观看| 蜜臀91精品一区二区三区| 亚洲视频日本| 久久九九99| 99riav国产精品| 欧美黄在线观看| 日韩视频不卡| 欧美激情精品久久久久久久变态| 亚洲欧美电影院| 国产精品色婷婷| 久久久精品国产一区二区三区| 一本久久青青|