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

            積木

            No sub title

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              140 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(1)

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

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            此篇文章打算介紹兩個(gè),在平時(shí)工作中,使用頻繁并且十分有價(jià)值的功能。(因?yàn)槟愕捻?xiàng)目不用到還好,只要用到,下面這兩個(gè)一般是必不可少)
            功能點(diǎn)1:將本地時(shí)間轉(zhuǎn)成格林威治時(shí)間,或者是將格林威治時(shí)間轉(zhuǎn)成本地時(shí)間。
            功能點(diǎn)2:將時(shí)間轉(zhuǎn)成時(shí)間戳,以及如何將時(shí)間戳轉(zhuǎn)成時(shí)間。
            有些人可看剛看到上面的功能點(diǎn)概述,可能會覺得這沒什么難的。也的確,事實(shí)上,確實(shí)不難。但如果你要是沒真正處理過的話,可能一時(shí)還真會壁。比如:功能點(diǎn)1,將本地時(shí)間轉(zhuǎn)成格林威治時(shí)間。因?yàn)槲覀兏静恢牢覀儺?dāng)前的本地時(shí)間與標(biāo)準(zhǔn)時(shí)間的時(shí)差到底是多少。所以你要怎么轉(zhuǎn)??(我們不能單純地認(rèn)為,我們是中國人,所以時(shí)差都是8個(gè)小時(shí)。那如果你的游戲要是發(fā)布到世界其他國家了??那時(shí)差就完全不同。甚至就算是中國,你在上海,跟在西藏,那時(shí)間也是有差別的。因此,我們需要根據(jù)本地時(shí)刻值,精確地計(jì)算出與標(biāo)準(zhǔn)時(shí)間的時(shí)差。從而才可以準(zhǔn)確轉(zhuǎn)換成格林威治時(shí)間??聪旅嫣幚矸椒ǎ?br />a) 將格林威治時(shí)間轉(zhuǎn)成標(biāo)準(zhǔn)時(shí)間
             ptime CommonHelper::utcToLocal(ptime utctime)
             {
              return boost::date_time::c_local_adjustor<ptime>::utc_to_local(utctime);
              //說明:c_local_adjustor對象的utc_to_local()接口就是用來處理本地時(shí)間跟標(biāo)準(zhǔn)時(shí)間的偏差的。
              //此處所謂的本地時(shí)間,并不是固定指說北京時(shí)間。而是你的計(jì)算處在地球的哪條經(jīng)線上,該經(jīng)線
              //跟格林威治所處的經(jīng)線的時(shí)差量。(我剛看到這個(gè)功能時(shí),實(shí)在太讓我驚訝了都?。?br />
              //但是有一點(diǎn)需要注意:boost中,只提供了標(biāo)準(zhǔn)時(shí)間轉(zhuǎn)本地時(shí)間的上述接口,卻沒有
              //直接提供將本地時(shí)間轉(zhuǎn)成標(biāo)準(zhǔn)時(shí)間的接口。不過,既然有了utc_to_loca()這樣的神兵利器
              //我們同樣可以很方便地處理將本地時(shí)間轉(zhuǎn)成標(biāo)準(zhǔn)時(shí)間的問題。見如何:
             }

            b) 將本地時(shí)間轉(zhuǎn)成格林威治時(shí)間
            ptime CommonHelper::localToUtc(ptime ltime)
             {
              return ltime - (utcToLocal(epoch) - epoch);
              //說明:(utcToLocal(epoch) - epoch)這部分內(nèi)容您的計(jì)算機(jī)的當(dāng)?shù)貢r(shí)差量(如果是在北京,那就是8小時(shí))
             }

            接下來介紹一下第二部分的功能點(diǎn)。即:功能點(diǎn)2:將時(shí)間轉(zhuǎn)時(shí)間戳以及將時(shí)間戳轉(zhuǎn)時(shí)間
            c) 將boost中的時(shí)間轉(zhuǎn)成時(shí)間戳,其實(shí)很簡單。中需要做如下處理即可。(在此就不多說)
             WE::int64 CommonHelper::getUTCTimestamp()
             {  
              return (microsec_clock::universal_time() - epoch).total_milliseconds();
             }

            d) 此處重點(diǎn)介紹一下,如何將時(shí)間戳轉(zhuǎn)成時(shí)間。這個(gè)確實(shí)有點(diǎn)令人頭痛。為什么這么說?因?yàn)闀r(shí)間戳,其實(shí)只是一個(gè)
            數(shù)量值。這個(gè)數(shù)量值記載的信息的意義是指:自:1970-1-1到指定時(shí)刻所走過的時(shí)間量值。如此,或許有人就會說,
            既然你都說了,是從1970到指定時(shí)刻的量值,兩個(gè)時(shí)間相加不就好了。確實(shí)是這樣子的,但有個(gè)小問題是:因?yàn)槲覀?br />沒法清楚這個(gè)量值的單位是什么。如果單位是:毫秒,而你把它當(dāng)成秒或當(dāng)成微秒來處理,結(jié)果都將是錯(cuò)的。關(guān)于這點(diǎn),
            其實(shí)boost有個(gè)時(shí)間處理的決策“的開關(guān)”,這個(gè)似乎還要看自己編譯的boost的lib是使用到哪個(gè)精度的級別。關(guān)于這塊
            本人暫時(shí)還沒深入到這方面,所以也不敢妄言。不過,有個(gè)接口,大家可以參考著使用下。time_duration::resolution()
            這個(gè)就可以用來識別,當(dāng)前系統(tǒng)中boost在時(shí)間這方面使用到的精度值。(例如本人目前項(xiàng)目中,使用到的是微秒級別的。
            所以返回值為:micro。)
            下面給他幾種實(shí)現(xiàn)時(shí)間戳轉(zhuǎn)時(shí)間的小例子:(以下假定,時(shí)間戳的單位為毫秒)
            e) 通過接口:from_time_t();
            ptime time_5 = from_time_t(timestamp);
            f) 通過time_duration
            milliseconds xx(time_1_stamp);
            ptime xxxxxxxxxxxx = CommonHelper::epoch + xx;
            g) 直接通過手動計(jì)算。此方法實(shí)現(xiàn)思路很簡單,但操作起來個(gè)人感覺易錯(cuò)。寫的代碼量又多,所以本人還是建議使用上面兩種,特別是第2種
            假如:timestamp是時(shí)間戳。則先計(jì)算出它的小時(shí),再計(jì)算出它的分鐘,計(jì)算出它的秒數(shù),最后計(jì)算出它的毫秒數(shù)。然后與commonhelper::epoch相加即可。
            注意:上面的e) f) g) 其實(shí)還是有區(qū)別的。用e)跟f)轉(zhuǎn)出來的精度值方面會不中方法g)。但在項(xiàng)目使用中,前兩者計(jì)算出來的精度值,一般
            情況下,是絕對可夠的。這是一個(gè)注意點(diǎn),給大家提醒一下。

            好了,這篇文章暫時(shí)就先寫到這吧。。其實(shí)關(guān)于boost時(shí)間,還有非常多的內(nèi)容可以挖掘,改天有機(jī)會再寫吧。希望對大伙有幫助。
            如果有錯(cuò)誤之處,還請指教。:)
            posted on 2013-01-02 16:27 Jacc.Kim 閱讀(3023) 評論(0)  編輯 收藏 引用 所屬分類: VC / C++
            久久99精品久久久久久不卡| 香港aa三级久久三级老师2021国产三级精品三级在 | 亚洲国产精品18久久久久久| 欧美日韩精品久久久免费观看| 欧美大香线蕉线伊人久久| 一级做a爱片久久毛片| 久久婷婷午色综合夜啪| 亚洲精品无码久久久久去q | 99久久婷婷国产综合精品草原| 国产精品青草久久久久福利99| 久久精品国产男包| 久久99国产综合精品免费| 亚洲国产精品成人久久蜜臀| 99国产精品久久| 久久久久99这里有精品10| 久久精品国产91久久综合麻豆自制 | 久久综合色区| 久久免费美女视频| 久久青青草原亚洲av无码app| 久久综合成人网| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 婷婷综合久久狠狠色99h| 久久天天躁狠狠躁夜夜avapp| 久久久国产一区二区三区| 久久精品国内一区二区三区| 伊人久久大香线蕉AV色婷婷色| 色悠久久久久久久综合网| 精品久久久久久无码国产| 久久青青草原精品影院| 久久99精品国产99久久| 国产欧美一区二区久久| 精品久久久久久亚洲| 91精品国产91久久久久久青草| 国产Av激情久久无码天堂| 久久精品麻豆日日躁夜夜躁| 色8久久人人97超碰香蕉987| 无码人妻久久一区二区三区免费 | 99国产欧美精品久久久蜜芽| 国产成人久久精品一区二区三区| 国产精品久久影院| 国产福利电影一区二区三区久久久久成人精品综合 |