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

            李帥的博客

            軟件開發(fā)愛好者

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              14 隨筆 :: 3 文章 :: 4 評論 :: 0 Trackbacks

            置頂隨筆 #

            B2C如今已經(jīng)風靡互聯(lián)網(wǎng),可以說這是社會的進步,更是互聯(lián)網(wǎng)的進步.先給大家解釋下何謂B2C,B2C中的B是Business,意思是企業(yè),2則是to的諧音,C是Customer,意思是消費者,所以B2C是企業(yè)對消費者的電子商務(wù)模式.特別是在當今的時代,許多大學(xué)生都創(chuàng)業(yè),許多消費者都需求物美價廉的商品,這消費群體都是不斷一層層的博取中間差價,最終才到達消費者.所以互聯(lián)網(wǎng)里每天都會有許多的消費者在尋找商品,這就需要運用一些B2C的自身推廣技巧了.
              一、企業(yè)商品聯(lián)合推廣技巧:
              方法:尋找些稍微知名的B2C網(wǎng)站合作模式(目標用戶相同,經(jīng)營產(chǎn)品不同),把各站商品聯(lián)合運作起來做促銷這可以做到想不到的結(jié)果.多多尋找一些可以取其長的企業(yè)或商家,比如攝影書籍專賣和數(shù)碼相機專賣店合作,數(shù)碼類B2C與家庭消費類網(wǎng)站的合作等。在彼此的頁面掛上對方的推薦商品;也可以推出套餐。
              如以下的一個活動:
              從XX年XX月XX日期至XX年XX月XX日,凡是只要在本站購買任意一部筆記本電腦加50元送即可獲得【***購物網(wǎng)】提供的蘋果牌移動硬盤一個!!!!
              在此,找聯(lián)合促俏商品的網(wǎng)站可以是單向的,就是你尋找的購物網(wǎng),讓它促銷你們的商品,而你不一定要上他們的商品。反之,如果是單向的,那么你要找的合作對象聯(lián)合推出的商品一定要它自己的商品的單價比你的高。
              學(xué)習點:聯(lián)合促銷的目的是銷售商品、傳播口碑與吸引關(guān)注度(非流量)。只要有一個目的做成即可,當然這看個人,如果可以兩樣都得手,你一定會有所收獲.
              二、贈品活動
              方法:此類活動  注意點:與第三方網(wǎng)站的接口與數(shù)據(jù)及時對接更新是很重要的。
              四、注冊有獎
              作法:注冊就有獎,形式可以是實物也可以是代金券,可以設(shè)置等級,更可以設(shè)置大獎。如果是代金券,可以直接在用戶注冊后打入用戶的帳戶中,用戶可以直接在消費時使用。
              注意點:有人獲得了大獎后一定要大力宣傳,造勢并炒作。
              五、論壇推送
              作法:相關(guān)性的論壇里發(fā)公益性的貼子并維護不使其下沉,也可發(fā)某一我們想重點推的商品的公益性信息,這對口碑傳播與關(guān)住度的提升是很好很快捷的方法。
              注意點:
              1.一定要巧妙體現(xiàn)你的網(wǎng)站及品牌。
              2.貼子的標題一定要有吸引力。
              3.注意回貼,保持貼子的活力與壽命,并使其出現(xiàn)在第一頁。
              4. 一個貼子選20個左右的論壇社就發(fā)送并維護就可以了。
              六、專題推廣
              作法:專門就某產(chǎn)品某品牌收集大量地文章,可以在自己的站上的資訊里天天更新十篇左右;同時,可以在選和訊、techweb等3個之內(nèi)的博客開這樣的專題博客。比如“如何選購數(shù)碼相機”博客。
              注意點:
              1.與論壇推送相反,這里要求文章數(shù)量多,發(fā)送的平臺倒可以少點,只放在自己網(wǎng)站上也是可以的。
              2.如果從別的網(wǎng)站摘錄的文章,一定要改改頭換找面。
              3.文章中要加入自己網(wǎng)站標識的字眼
              4.文章要多重復(fù)需要突現(xiàn)的商品或品牌名字。
              七、主題活動
              作法:我方單獨或聯(lián)合或贊助第三方進行活動,比如數(shù)碼網(wǎng)站可以搞“地球村,我們的生活空間。-大學(xué)生攝影展”,以吸引人氣,傳遞品牌為主。也可以起到促銷的目的。
              注意點:
              1. 活動主題及延展一定要與所經(jīng)營的產(chǎn)品相關(guān)。
              2.活動的人群要與目標客戶相同。比如數(shù)碼網(wǎng)站如果搞一個小學(xué)生作文大賽就失去了意義,當然也起不到效果。
              八、參與活動
              作法:參與到第三方舉辦的活動中去,包括某網(wǎng)站的活動,某些會議,某些會展等等。形式上可以是活動贊助單位、獎金提供商、報名網(wǎng)站等等。
              注意點:
              1. 對第三方舉辦的活動一定要注意活動的對象與我們的目標客戶群體是否附合(一再重復(fù)這點,是因為電子商務(wù)網(wǎng)站不可以作大而空的炒作,一切動作都是為增加用戶,進而增加銷量,這與別的網(wǎng)站,特別是那些求流量的網(wǎng)站根本上是不一樣)
              2. 一定要注意費用,爭取不花錢或花盡可能少的錢起到最大的影響
              3. 如果能與會,最好也參與進去。


            2012年2月23日 #

                 摘要:   閱讀全文
            posted @ 2012-02-23 13:04 李帥 閱讀(422) | 評論 (0)編輯 收藏

            2010年12月15日 #

            B2C如今已經(jīng)風靡互聯(lián)網(wǎng),可以說這是社會的進步,更是互聯(lián)網(wǎng)的進步.先給大家解釋下何謂B2C,B2C中的B是Business,意思是企業(yè),2則是to的諧音,C是Customer,意思是消費者,所以B2C是企業(yè)對消費者的電子商務(wù)模式.特別是在當今的時代,許多大學(xué)生都創(chuàng)業(yè),許多消費者都需求物美價廉的商品,這消費群體都是不斷一層層的博取中間差價,最終才到達消費者.所以互聯(lián)網(wǎng)里每天都會有許多的消費者在尋找商品,這就需要運用一些B2C的自身推廣技巧了.
              一、企業(yè)商品聯(lián)合推廣技巧:
              方法:尋找些稍微知名的B2C網(wǎng)站合作模式(目標用戶相同,經(jīng)營產(chǎn)品不同),把各站商品聯(lián)合運作起來做促銷這可以做到想不到的結(jié)果.多多尋找一些可以取其長的企業(yè)或商家,比如攝影書籍專賣和數(shù)碼相機專賣店合作,數(shù)碼類B2C與家庭消費類網(wǎng)站的合作等。在彼此的頁面掛上對方的推薦商品;也可以推出套餐。
              如以下的一個活動:
              從XX年XX月XX日期至XX年XX月XX日,凡是只要在本站購買任意一部筆記本電腦加50元送即可獲得【***購物網(wǎng)】提供的蘋果牌移動硬盤一個!!!!
              在此,找聯(lián)合促俏商品的網(wǎng)站可以是單向的,就是你尋找的購物網(wǎng),讓它促銷你們的商品,而你不一定要上他們的商品。反之,如果是單向的,那么你要找的合作對象聯(lián)合推出的商品一定要它自己的商品的單價比你的高。
              學(xué)習點:聯(lián)合促銷的目的是銷售商品、傳播口碑與吸引關(guān)注度(非流量)。只要有一個目的做成即可,當然這看個人,如果可以兩樣都得手,你一定會有所收獲.
              二、贈品活動
              方法:此類活動  注意點:與第三方網(wǎng)站的接口與數(shù)據(jù)及時對接更新是很重要的。
              四、注冊有獎
              作法:注冊就有獎,形式可以是實物也可以是代金券,可以設(shè)置等級,更可以設(shè)置大獎。如果是代金券,可以直接在用戶注冊后打入用戶的帳戶中,用戶可以直接在消費時使用。
              注意點:有人獲得了大獎后一定要大力宣傳,造勢并炒作。
              五、論壇推送
              作法:相關(guān)性的論壇里發(fā)公益性的貼子并維護不使其下沉,也可發(fā)某一我們想重點推的商品的公益性信息,這對口碑傳播與關(guān)住度的提升是很好很快捷的方法。
              注意點:
              1.一定要巧妙體現(xiàn)你的網(wǎng)站及品牌。
              2.貼子的標題一定要有吸引力。
              3.注意回貼,保持貼子的活力與壽命,并使其出現(xiàn)在第一頁。
              4. 一個貼子選20個左右的論壇社就發(fā)送并維護就可以了。
              六、專題推廣
              作法:專門就某產(chǎn)品某品牌收集大量地文章,可以在自己的站上的資訊里天天更新十篇左右;同時,可以在選和訊、techweb等3個之內(nèi)的博客開這樣的專題博客。比如“如何選購數(shù)碼相機”博客。
              注意點:
              1.與論壇推送相反,這里要求文章數(shù)量多,發(fā)送的平臺倒可以少點,只放在自己網(wǎng)站上也是可以的。
              2.如果從別的網(wǎng)站摘錄的文章,一定要改改頭換找面。
              3.文章中要加入自己網(wǎng)站標識的字眼
              4.文章要多重復(fù)需要突現(xiàn)的商品或品牌名字。
              七、主題活動
              作法:我方單獨或聯(lián)合或贊助第三方進行活動,比如數(shù)碼網(wǎng)站可以搞“地球村,我們的生活空間。-大學(xué)生攝影展”,以吸引人氣,傳遞品牌為主。也可以起到促銷的目的。
              注意點:
              1. 活動主題及延展一定要與所經(jīng)營的產(chǎn)品相關(guān)。
              2.活動的人群要與目標客戶相同。比如數(shù)碼網(wǎng)站如果搞一個小學(xué)生作文大賽就失去了意義,當然也起不到效果。
              八、參與活動
              作法:參與到第三方舉辦的活動中去,包括某網(wǎng)站的活動,某些會議,某些會展等等。形式上可以是活動贊助單位、獎金提供商、報名網(wǎng)站等等。
              注意點:
              1. 對第三方舉辦的活動一定要注意活動的對象與我們的目標客戶群體是否附合(一再重復(fù)這點,是因為電子商務(wù)網(wǎng)站不可以作大而空的炒作,一切動作都是為增加用戶,進而增加銷量,這與別的網(wǎng)站,特別是那些求流量的網(wǎng)站根本上是不一樣)
              2. 一定要注意費用,爭取不花錢或花盡可能少的錢起到最大的影響
              3. 如果能與會,最好也參與進去。


            2010年6月14日 #

            C# 寫入excel及讀取Excel實例看到論壇里面不斷有人提問關(guān)于讀取excel和導(dǎo)入excel的相關(guān)問題。閑暇時間將我所知道的對excel的操作加以總結(jié),現(xiàn)在共享大家,希望給大家能夠給大家?guī)Я艘欢ǖ膸椭?br>另外我們還要注意一些簡單的問題1.excel文件只能存儲65535行數(shù)據(jù),如果你的數(shù)據(jù)大于65535行,那么就需要將excel分割存放了。2.關(guān)于亂碼,這主要是字符設(shè)置問題。

            1.加載Excel(讀取excel內(nèi)容)是返回值是一個DataSet

                    //加載Excel
                    public static DataSet LoadDataFromExcel(string filePath)
                    {
                        try
                        {
                            string strConn;
                            strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filePath + ";Extended Properties='Excel 8.0;HDR=False;IMEX=1'";
                            OleDbConnection OleConn = new OleDbConnection(strConn);
                            OleConn.Open();
                            String sql = "SELECT * FROM  [Sheet1$]";//可是更改Sheet名稱,比如sheet2,等等

                            OleDbDataAdapter OleDaExcel = new OleDbDataAdapter(sql, OleConn);
                            DataSet OleDsExcle = new DataSet();
                            OleDaExcel.Fill(OleDsExcle, "Sheet1");
                            OleConn.Close();
                            return OleDsExcle;
                        }
                        catch (Exception err)
                        {
                            MessageBox.Show("數(shù)據(jù)綁定Excel失敗!失敗原因:" + err.Message, "提示信息",
                                MessageBoxButtons.OK, MessageBoxIcon.Information);
                            return null;
                        }
                    }
            2.寫入Excel內(nèi)容,參數(shù):excelTable是要導(dǎo)入excel的一個table表 < type="text/JavaScript"> alimama_pid="mm_10249644_1605763_5027492"; alimama_type="f"; alimama_sizecode ="tl_1x5_8"; alimama_fontsize=12; alimama_bordercolor="FFFFFF"; alimama_bgcolor="FFFFFF"; alimama_titlecolor="0000FF"; alimama_underline=0; alimama_height=22; alimama_width=0; < src="

                    public static bool SaveDataTableToExcel(System.Data.DataTable excelTable, string filePath)
                    {
                        Microsoft.Office.Interop.Excel.Application app =
                            new Microsoft.Office.Interop.Excel.ApplicationClass();
                        try
                        {
                            app.Visible = false;
                            Workbook wBook = app.Workbooks.Add(true);
                            Worksheet wSheet = wBook.Worksheets[1] as Worksheet;
                            if (excelTable.Rows.Count > 0)
                            {
                                int row = 0;
                                row = excelTable.Rows.Count;
                                int col = excelTable.Columns.Count;
                                for (int i = 0; i < row; i++)
                                {
                                    for (int j = 0; j < col; j++)
                                    {
                                        string str = excelTable.Rows[i][j].ToString();
                                        wSheet.Cells[i + 2, j + 1] = str;
                                    }
                                }
                            }

                            int size = excelTable.Columns.Count;
                            for (int i = 0; i < size; i++)
                            {
                                wSheet.Cells[1, 1 + i] = excelTable.Columns[i].ColumnName;
                            }
                            //設(shè)置禁止彈出保存和覆蓋的詢問提示框 C# 寫入excel及讀取Excel實例
                            app.DisplayAlerts = false;
                            app.AlertBeforeOverwriting = false;
                            //保存工作簿 < type="text/JavaScript"> alimama_pid="mm_10249644_1605763_5027492"; alimama_type="f"; alimama_sizecode ="tl_1x5_8"; alimama_fontsize=12; alimama_bordercolor="FFFFFF"; alimama_bgcolor="FFFFFF"; alimama_titlecolor="0000FF"; alimama_underline=0; alimama_height=22; alimama_width=0; < src="
                            wBook.Save();
                            //保存excel文件
                            app.Save(filePath);
                            app.SaveWorkspace(filePath);
                            app.Quit();
                            app = null;
                            return true;
                        }
                        catch (Exception err)
                        {
                            MessageBox.Show("導(dǎo)出Excel出錯!錯誤原因:" + err.Message, "提示信息",
                                MessageBoxButtons.OK, MessageBoxIcon.Information);
                            return false;
                        }
                        finally
                        {
                        }
                    }


             

            歡迎收藏本文 一起讀網(wǎng) 【C# 寫入excel及讀取Excel實例 http://www.1qidu.com/?action-viewnews-itemid-31870
            一起讀網(wǎng)參考地址:http://www.1qidu.com/?action-viewnews-itemid-31870

            posted @ 2010-06-14 23:46 李帥 閱讀(2241) | 評論 (0)編輯 收藏

            2010年6月9日 #

            在Pentium以上的CPU中,提供了一條機器指令RDTSC(Read Time Stamp Counter)來讀取這個時間戳的數(shù)字,并將其保存在EDX:EAX寄存器對中。由于EDX:EAX寄存器對恰好是Win32平臺下C++語言保存函數(shù)返回值的寄存器,所以我們可以把這條指令看成是一個普通的函數(shù)調(diào)用。vc2003像這樣:
            inline unsigned __int64 GetTimeStampCount()
            {
            __asm RDTSC
            }
            對于vc6或者其他編譯器可能不行,因為RDTSC不被C++的內(nèi)嵌匯編器直接支持,所以我們要用_emit偽指令直接嵌入該指令的機器碼形式0X0F、0X31,如下:
            inline unsigned __int64 GetTimeStampCount()
            {
            __asm _emit 0x0F
            __asm _emit 0x31
            }

             

             

            對關(guān)注性能的程序開發(fā)人員而言,一個好的計時部件既是益友,也是良師。計時器既可以作為程序組件幫助程序員精確的控制程序進程,又是一件有力的調(diào)試武器,在有經(jīng)驗的程序員手里可以盡快的確定程序的性能瓶頸,或者對不同的算法作出有說服力的性能比較。  
               
                在Windows平臺下,常用的計時器有兩種,一種是timeGetTime多媒體計時器,它可以提供毫秒級的計時。但這個精度對很多應(yīng)用場合而言還是太粗糙了。另一種是QueryPerformanceCount計數(shù)器,隨系統(tǒng)的不同可以提供微秒級的計數(shù)。對于實時圖形處理、多媒體數(shù)據(jù)流處理、或者實時系統(tǒng)構(gòu)造的程序員,善用QueryPerformanceCount/QueryPerformanceFrequency是一項基本功。  
               
                本文要介紹的,是另一種直接利用Pentium   CPU內(nèi)部時間戳進行計時的高精度計時手段。以下討論主要得益于《Windows圖形編程》一書,第   15頁-17頁,有興趣的讀者可以直接參考該書。關(guān)于RDTSC指令的詳細討論,可以參考Intel產(chǎn)品手冊。本文僅僅作拋磚之用。  
                在   Intel   Pentium以上級別的CPU中,有一個稱為“時間戳(Time   Stamp)”的部件,它以64位無符號整型數(shù)的格式,記錄了自CPU上電以來所經(jīng)過的時鐘周期數(shù)。由于目前的CPU主頻都非常高,因此這個部件可以達到納秒級的計時精度。這個精確性是上述兩種方法所無法比擬的。  
               
                在Pentium以上的CPU中,提供了一條機器指令RDTSC(Read   Time   Stamp   Counter)來讀取這個時間戳的數(shù)字,并將其保存在EDX:EAX寄存器對中。由于EDX:EAX寄存器對恰好是Win32平臺下C++語言保存函數(shù)返回值的寄存器,所以我們可以把這條指令看成是一個普通的函數(shù)調(diào)用。像這樣:  
               
              inline   unsigned   __int64   GetCycleCount()  
              {  
                __asm   RDTSC  
              }  
               
              但是不行,因為RDTSC不被C++的內(nèi)嵌匯編器直接支持,所以我們要用_emit偽指令直接嵌入該指令的機器碼形式0X0F、0X31,如下:  
               
              inline   unsigned   __int64   GetCycleCount()  
              {  
                __asm   _emit   0x0F  
                __asm   _emit   0x31  
              }  
               
              以后在需要計數(shù)器的場合,可以像使用普通的Win32   API一樣,調(diào)用兩次GetCycleCount函數(shù),比較兩個返回值的差,像這樣:  
               
              unsigned   long   t;  
              t   =   (unsigned   long)GetCycleCount();  
              //Do   Something   time-intensive   ...  
              t   -=   (unsigned   long)GetCycleCount();  
               
                《Windows圖形編程》第15頁編寫了一個類,把這個計數(shù)器封裝起來。有興趣的讀者可以去參考那個類的代碼。作者為了更精確的定時,做了一點小小的改進,把執(zhí)行RDTSC指令的時間,通過連續(xù)兩次調(diào)用GetCycleCount函數(shù)計算出來并保存了起來,以后每次計時結(jié)束后,都從實際得到的計數(shù)中減掉這一小段時間,以得到更準確的計時數(shù)字。但我個人覺得這一點點改進意義不大。在我的機器上實測,這條指令大概花掉了幾十到100多個周期,在   Celeron   800MHz的機器上,這不過是十分之一微秒的時間。對大多數(shù)應(yīng)用來說,這點時間完全可以忽略不計;而對那些確實要精確到納秒數(shù)量級的應(yīng)用來說,這個補償也過于粗糙了。  
               
              這個方法的優(yōu)點是:  
               
              1.高精度。可以直接達到納秒級的計時精度(在1GHz的CPU上每個時鐘周期就是一納秒),這是其他計時方法所難以企及的。  
               
              2.   成本低。timeGetTime   函數(shù)需要鏈接多媒體庫winmm.lib,QueryPerformance*   函數(shù)根據(jù)MSDN的說明,需要硬件的支持(雖然我還沒有見過不支持的機器)和KERNEL庫的支持,所以二者都只能在Windows平臺下使用(關(guān)于DOS平臺下的高精度計時問題,可以參考《圖形程序開發(fā)人員指南》,里面有關(guān)于控制定時器8253的詳細說明)。但RDTSC指令是一條CPU指令,凡是i386平臺下Pentium以上的機器均支持,甚至沒有平臺的限制(我相信i386版本UNIX和Linux下這個方法同樣適用,但沒有條件試驗),而且函數(shù)調(diào)用的開銷是最小的。  
               
              3.   具有和CPU主頻直接對應(yīng)的速率關(guān)系。一個計數(shù)相當于1/(CPU主頻Hz數(shù))秒,這樣只要知道了CPU的主頻,可以直接計算出時間。這和   QueryPerformanceCount不同,后者需要通過QueryPerformanceFrequency獲取當前計數(shù)器每秒的計數(shù)次數(shù)才能換算成時間。  
               
              這個方法的缺點是:  
               
              1.現(xiàn)有的C/C++編譯器多數(shù)不直接支持使用RDTSC指令,需要用直接嵌入機器碼的方式編程,比較麻煩。  
               
              2.數(shù)據(jù)抖動比較厲害。其實對任何計量手段而言,精度和穩(wěn)定性永遠是一對矛盾。如果用低精度的timeGetTime來計時,基本上每次計時的結(jié)果都是相同的;而RDTSC指令每次結(jié)果都不一樣,經(jīng)常有幾百甚至上千的差距。這是這種方法高精度本身固有的矛盾。  
               
              關(guān)于這個方法計時的最大長度,我們可以簡單的用下列公式計算:  
               
              自CPU上電以來的秒數(shù)   =   RDTSC讀出的周期數(shù)   /   CPU主頻速率(Hz)  
               
              64位無符號整數(shù)所能表達的最大數(shù)字是1.8×10^19,在我的Celeron   800上可以計時大約700年(書中說可以在200MHz的Pentium上計時117年,這個數(shù)字不知道是怎么得出來的,與我的計算有出入)。無論如何,我們大可不必關(guān)心溢出的問題。  
               
              下面是幾個小例子,簡要比較了三種計時方法的用法與精度  
               
              //Timer1.cpp   使用了RDTSC指令的Timer類//KTimer類的定義可以參見《Windows圖形編程》P15  
              //編譯行:CL   Timer1.cpp   /link   USER32.lib  
              #include   &ltstdio.h>  
              #include   "KTimer.h"  
              main()  
              {  
                unsigned   t;  
                KTimer   timer;  
                timer.Start();  
                Sleep(1000);  
                t   =   timer.Stop();  
                printf("Lasting   Time:   %d\n",t);  
              }  
               
              //Timer2.cpp   使用了timeGetTime函數(shù)  
              //需包含&ltmmsys.h>,但由于Windows頭文件錯綜復(fù)雜的關(guān)系  
              //簡單包含&ltwindows.h>比較偷懶:)  
              //編譯行:CL   timer2.cpp   /link   winmm.lib    
              #include   &ltwindows.h>  
              #include   &ltstdio.h>  
               
              main()  
              {  
                DWORD   t1,   t2;  
                t1   =   timeGetTime();  
                Sleep(1000);  
                t2   =   timeGetTime();  
                printf("Begin   Time:   %u\n",   t1);  
                printf("End   Time:   %u\n",   t2);  
                printf("Lasting   Time:   %u\n",(t2-t1));  
              }  
               
              //Timer3.cpp   使用了QueryPerformanceCounter函數(shù)  
              //編譯行:CL   timer3.cpp   /link   KERNEl32.lib  
              #include   &ltwindows.h>  
              #include   &ltstdio.h>  
               
              main()  
              {  
                LARGE_INTEGER   t1,   t2,   tc;  
                QueryPerformanceFrequency(&tc);  
                printf("Frequency:   %u\n",   tc.QuadPart);  
                QueryPerformanceCounter(&t1);  
                Sleep(1000);  
                QueryPerformanceCounter(&t2);  
                printf("Begin   Time:   %u\n",   t1.QuadPart);  
                printf("End   Time:   %u\n",   t2.QuadPart);  
                printf("Lasting   Time:   %u\n",(   t2.QuadPart-   t1.QuadPart));  
              }  
               
              ////////////////////////////////////////////////  
              //以上三個示例程序都是測試1秒鐘休眠所耗費的時間  
              file://測/試環(huán)境:Celeron   800MHz   /   256M   SDRAM      
              //                     Windows   2000   Professional   SP2  
              //                     Microsoft   Visual   C++   6.0   SP5  
              ////////////////////////////////////////////////  
               
              以下是Timer1的運行結(jié)果,使用的是高精度的RDTSC指令  
              Lasting   Time:   804586872  
               
              以下是Timer2的運行結(jié)果,使用的是最粗糙的timeGetTime   API  
              Begin   Time:   20254254  
              End   Time:   20255255  
              Lasting   Time:   1001  
               
              以下是Timer3的運行結(jié)果,使用的是QueryPerformanceCount   API  
              Frequency:   3579545  
              Begin   Time:   3804729124  
              End   Time:   3808298836  
              Lasting   Time:   3569712  


            歡迎收藏本文 一起讀網(wǎng) 【獲取CPU時間戳代碼 使用CPU時間戳進行高精度計時 http://www.1qidu.com/?action-viewnews-itemid-16841
            一起讀網(wǎng)參考地址:http://www.1qidu.com/?action-viewnews-itemid-16841

            posted @ 2010-06-09 14:05 李帥 閱讀(4047) | 評論 (4)編輯 收藏

            2008年11月19日 #

            CDC::GetDeviceCaps可用予獲取打印機DC的不同參數(shù)

            這樣就可以在開發(fā)打印報表的時候根據(jù)打印機設(shè)置參數(shù)來自動獲取了。

            如果你開發(fā)的報表出現(xiàn)隨著不同打印機而出現(xiàn)不同效果可以使用這個函數(shù)。
            posted @ 2008-11-19 09:52 李帥 閱讀(1329) | 評論 (0)編輯 收藏

            2008年11月15日 #

            #include <windows.h>
            #include <iostream.h>

            DWORD WINAPI Fun1Proc(LPVOID lpParameter);
            DWORD WINAPI Fun2Proc(LPVOID lpParameter);

            int index=0;
            int tickets=100;
            HANDLE hMutex;
            void main()
            {

                HANDLE hThread1,hThread2;
                hThread1=CreateThread(NULL,0,Fun1Proc,NULL,0,NULL);
                hThread2=CreateThread(NULL,0,Fun2Proc,NULL,0,NULL);
                CloseHandle(hThread1);
                CloseHandle(hThread2);
               
                hMutex=CreateMutex(NULL,FALSE,NULL);
                //TRUE代表主線程擁有互斥對象 但是主線程沒有釋放該對象  互斥對象誰擁有 誰釋放
                //FLASE代表當前沒有線程擁有這個互斥對象

                Sleep(4000);

            }

            DWORD WINAPI Fun1Proc(LPVOID lpParameter)
            {
                while (true)
                {
                    WaitForSingleObject(hMutex,INFINITE);
                    if (tickets>0)
                    {
                        cout<<"t1: "<<tickets--<<endl;
                   
                    }
                    else
                    {
                        break;
                    }
                    ReleaseMutex(hMutex);
                }

                return 0;
            }

            DWORD WINAPI Fun2Proc(LPVOID lpParameter)
            {
                while (true)
                {
                    WaitForSingleObject(hMutex,INFINITE);
                    if (tickets>0)
                    {
                        cout<<"t2: "<<tickets--<<endl;
                    }
                    else
                    {
                        break;
                    }
                    ReleaseMutex(hMutex);
                }

                return 0;
            }
            此信息來自〖軟工吧論壇http://www.gcs8.cn
            查看原網(wǎng)址:http://www.gcs8.cn/htm_data/2/0811/15807.html

            posted @ 2008-11-15 17:04 李帥 閱讀(2379) | 評論 (0)編輯 收藏

            2008年11月11日 #

            #include <windows.h>
            #include<windowsx.h>

            BOOL Cls_OnCreate(HWND hwnd, LPCREATESTRUCT lpCreateStruct)
            {
                MessageBox(NULL,"使用消息分流器創(chuàng)建窗口成功","ddd",MB_OK); 
                return 1;
            }

            LRESULT CALLBACK WinProc(HWND hwnd,
                                     UINT msg,
                                     WPARAM wparam,
                                     LPARAM lparam)
            {
                switch(msg)
                {
                    case WM_CREATE:
                        return HANDLE_WM_CREATE(hwnd, wparam, lparam, Cls_OnCreate);
                    case WM_CLOSE:
                        DestroyWindow(hwnd);
                        break;
                    case WM_DESTROY:
                        PostQuitMessage(0);
                        break;
                    default:
                        return DefWindowProc(hwnd, msg, wparam, lparam);
                }

                //這里可以輸入響應(yīng)消息的代碼
                return 0;
            }


            int WINAPI WinMain(HINSTANCE hinstance,
                               HINSTANCE hprevinstance,
                               LPSTR lpcmdline,
                               int ncmdshow)
            {
                HWND hWnd;
                MSG msg;     
                WNDCLASSEX wndclass; 
                wndclass.cbSize=sizeof(WNDCLASSEX);
                wndclass.style=CS_HREDRAW | CS_VREDRAW;
                wndclass.lpfnWndProc=(WNDPROC) WinProc;
                wndclass.cbClsExtra=0;
                wndclass.cbWndExtra=0;
                wndclass.hInstance = hinstance;   
                wndclass.hIcon = LoadIcon(NULL,IDI_ERROR);
                wndclass.hCursor = LoadCursor(NULL, IDC_ARROW);
                wndclass.hbrBackground = (HBRUSH)(COLOR_WINDOW+1);
                wndclass.lpszMenuName = NULL;
                wndclass.lpszClassName = "WINCLASS1";
                wndclass.hIconSm = LoadIcon(wndclass.hInstance, (LPCTSTR)IDI_ERROR);
                wndclass.lpszMenuName = NULL;
                wndclass.hbrBackground =(HBRUSH) GetStockObject(WHITE_BRUSH);
                wndclass.lpszClassName ="WINCLASS1";
               

                if (!RegisterClassEx(&wndclass))
                {
                    MessageBox(NULL,"ddd","ddd",MB_OK); 
                     return 0;
                }    //    //……

                hWnd=CreateWindowEx(NULL,"WINCLASS1",
                    "wndtitle",
                    WS_OVERLAPPEDWINDOW|WS_VISIBLE ,       
                    CW_USEDEFAULT, 0,
                    400,400,
                    NULL,
                    NULL,
                    hinstance,
                    NULL );
                if (!hWnd)
                        return 0;   
                ShowWindow(hWnd, ncmdshow);
                UpdateWindow(hWnd);
                while(GetMessage(&msg, NULL, 0, 0)) 
                {     
                    TranslateMessage(&msg); 
                    DispatchMessage(&msg); 
                }
               
                return msg.wParam;
            }

            轉(zhuǎn)帖注明來自軟工吧論壇
            此信息來自〖軟工吧論壇http://www.gcs8.cn
            查看原網(wǎng)址:http://www.gcs8.cn/htm_data/2/0811/15785.html

            posted @ 2008-11-11 10:42 李帥 閱讀(337) | 評論 (0)編輯 收藏

            2008年11月10日 #

              接口是一個沒有被實現(xiàn)的特殊的類,它是一系列操作的集合,我們可以把它看作是與其他對象通訊的協(xié)議。C++中沒有提供類似interface這樣的關(guān)鍵 字來定義接口,但是Mircrosoft c++中提供了__declspec(novtable)來修飾一個類,來表示該類沒有虛函數(shù)表,也就是虛函數(shù)都是純虛的。所以利用它我們依然可以定義一 個接口。代碼例子如下:

             

            #include <IOSTREAM>
            using namespace std;

            #define interface class __declspec(novtable)

            interface ICodec
            {
            public:
                
            virtual bool Decode(char * lpDataSrc,unsigned int nSrcLen,char * lpDataDst,unsigned int *pnDstLen);
                
            virtual bool Encode(char * lpDataSrc,unsigned int nSrcLen,char * lpDataDst,unsigned int *pnDstLen);
            };

            class CCodec : public ICodec
            {
            public:
                
            virtual bool Decode(char * lpDataSrc,unsigned int nSrcLen,char * lpDataDst,unsigned int *pnDstLen)
                 {
                     cout
            << "解碼..." << endl;
                    
            return true;
                 }
                
            virtual bool Encode(char * lpDataSrc,unsigned int nSrcLen,char * lpDataDst,unsigned int *pnDstLen)
                 {
                     cout
            << "編碼..." << endl;
                    
            return true;
                 }
            };

            int main(int argc, char* argv[])
            {
                 ICodec
            * pCodec = new CCodec();
                 pCodec
            ->Decode(NULL,0,NULL,NULL);
                 pCodec
            ->Encode(NULL,0,NULL,NULL);
                 delete (CCodec
            *)pCodec;
                
            return 0;
            }

             

            上面的ICodec接口等價于下面的定義:
            
            
            class ICodec
            {
            public:
                virtual bool Decode(char * lpDataSrc,unsigned int nSrcLen,char * lpDataDst,unsigned int *pnDstLen)=0;
                virtual bool Encode(char * lpDataSrc,unsigned int nSrcLen,char * lpDataDst,unsigned int *pnDstLen)=0;
            };
            posted @ 2008-11-10 09:44 李帥 閱讀(7245) | 評論 (0)編輯 收藏

            2008年11月8日 #

            根據(jù)微軟的說法,Visual C++ 6.0 支持的最后一個SDK是 Windows Server 2003 PSDK 版本,幸運的是在網(wǎng)上也找到了 XPSP2 PSDK 版本,在這里感謝網(wǎng)友發(fā)現(xiàn)的下載地址:

            Platform SDK XPSP2:
            http://www.microsoft.com/msdownload/platformsdk/sdkupdate/XPSP2FULLInstall.htm

            Platform SDK February 2003:

            http://www.microsoft.com/msdownload/platformsdk/sdkupdate/psdk-full.htm

            posted @ 2008-11-08 17:13 李帥 閱讀(9394) | 評論 (0)編輯 收藏

            2008年11月7日 #

            摘要:

              RTTI(Run-Time Type Identification)是面向?qū)ο蟪绦蛟O(shè)計中一種重要的技術(shù)。現(xiàn)行的C++標準對RTTI已經(jīng)有了明確的支持。不過在某些情況下出于特殊的開發(fā)需要,我們需要自己編碼來實現(xiàn)。本文介紹了一些關(guān)于RTTI的基礎(chǔ)知識及其原理和實現(xiàn)。  

            RTTI需求:

              和很多其他語言一樣,C++是一種靜態(tài)類型語言。其數(shù)據(jù)類型是在編譯期就確定的,不能在運行時更改。然而由于面向?qū)ο蟪绦蛟O(shè)計中多態(tài)性的要求,C++中的指針或引用(Reference)本身的類型,可能與它實際代表(指向或引用)的類型并不一致。有時我們需要將一個多態(tài)指針轉(zhuǎn)換為其實際指向?qū)ο蟮念愋停托枰肋\行時的類型信息,這就產(chǎn)生了運行時類型識別的要求。

              C++對RTTI的支持

              C++提供了兩個關(guān)鍵字typeid和dynamic_cast和一個type_info類來支持RTTI:

              dynamic_cast操作符:它允許在運行時刻進行類型轉(zhuǎn)換,從而使程序能夠在一個類層次結(jié)構(gòu)安全地轉(zhuǎn)換類型。dynamic_cast提供了兩種轉(zhuǎn)換方式,把基類指針轉(zhuǎn)換成派生類指針,或者把指向基類的左值轉(zhuǎn)換成派生類的引用。見下例講述:

            void company::payroll(employee *pe) {
            //對指針轉(zhuǎn)換失敗,dynamic_cast返回NULL
            if(programmer *pm=dynamic_cast(pe)){
            pm->bonus();
            }
            }
            void company::payroll(employee &re) {
            try{
            //對引用轉(zhuǎn)換失敗的話,則會以拋出異常來報告錯誤
            programmer &rm=dynamic_cast(re);
            pm->bonus();
            }
            catch(std::bad_cast){

            }
            }

              這里bonus是programmer的成員函數(shù),基類employee不具備這個特性。所以我們必須使用安全的由基類到派生類類型轉(zhuǎn)換,識別出programmer指針。

              typeid操作符:它指出指針或引用指向的對象的實際派生類型。

              例如:

            employee* pe=new manager;
            typeid(*pe)==typeid(manager) //true
              typeid可以用于作用于各種類型名,對象和內(nèi)置基本數(shù)據(jù)類型的實例、指針或者引用,當作用于指針和引用將返回它實際指向?qū)ο蟮念愋托畔ⅰypeid的返回是type_info類型。

              type_info類:這個類的確切定義是與編譯器實現(xiàn)相關(guān)的,下面是《C++ Primer》中給出的定義(參考資料[2]中談到編譯器必須提供的最小信息量):

            class type_info {
            private:
            type_info(const type_info&);
            type_info& operator=( const type_info& );
            public:
            virtual ~type_info();
            int operator==( const type_info& ) const;
            int operator!=( const type_info& ) const;
            const char* name() const;
            };
             實現(xiàn)目標:

              實現(xiàn)的方案

              方案一:利用多態(tài)來取得指針或應(yīng)用的實際類型信息

              這是一個最簡單的方法,也是作者目前所采用的辦法。

              實現(xiàn):

            enum ClassType{
            UObjectClass,
            URectViewClass,
            UDialogClass,
            ……
            };
            class UObject{
            virtual char* GetClassName() const {
            return "UObject";
            };
            virtual ClassType TypeOfClass(){
            return UObjectClass;
            };
            };
            class UDialog{
            virtual char* GetClassName() const {
            return "UDialog";
            };
            virtual ClassType TypeOfClass(){
            return UDialogClass;
            };
            };
              示例:

            UObject po=new UObject;
            UObject pr=new URectView;
            UObject pd=new UDialog;
            cout << "po is a " << po->GetClassName() << endl;
            cout << "pr is a " << pr->GetClassName() << endl;
            cout << "pd is a " << pd->GetClassName() << endl;
            cout<TypeOfClass()==UObjectClass<
            posted @ 2008-11-07 21:44 李帥 閱讀(310) | 評論 (0)編輯 收藏

            僅列出標題  下一頁
            亚洲精品国产美女久久久| 国产精品一区二区久久不卡| 国内精品伊人久久久久网站| 久久久久久久久久免免费精品| 久久91精品国产91久| 国产精品久久久久久一区二区三区| 99久久成人18免费网站| 久久亚洲精品成人无码网站| 国产精品久久久福利| 久久人做人爽一区二区三区| 国产AV影片久久久久久| 久久精品一区二区三区AV| 国产福利电影一区二区三区久久老子无码午夜伦不| 国产精品激情综合久久| 久久精品无码专区免费青青| 久久人人爽人人精品视频| 久久亚洲国产午夜精品理论片| 日韩欧美亚洲综合久久| 久久亚洲中文字幕精品一区四| 久久精品一区二区国产| 亚洲伊人久久精品影院| 久久久久久免费视频| 国产呻吟久久久久久久92| 青青草国产精品久久| 国内精品久久久久久久97牛牛| 久久久久久久97| 久久久精品国产免大香伊 | 97香蕉久久夜色精品国产 | 精品乱码久久久久久夜夜嗨 | 99精品伊人久久久大香线蕉| 久久久久无码精品国产| 狠狠色狠狠色综合久久| 777午夜精品久久av蜜臀| 久久精品国产99国产精品导航| 久久天天婷婷五月俺也去| 99久久综合国产精品免费| 久久久久亚洲国产| 久久久久99精品成人片直播| 久久亚洲私人国产精品| 久久96国产精品久久久| 国产高潮国产高潮久久久91 |