• <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>
            posts - 23,  comments - 20,  trackbacks - 0
              2016年10月8日
            如果當比較元素相同返回真時,此時比較元素將會繼續向下遍歷,在極端情況下,例如程序中所有元素都是一樣的情況下,在這種情況下,就會出現訪問越界,結果就是導致程序出現segment fault

            所以在寫c++ stl中的比較函數是,bool返回真的時候,一定是“真的”大,或者小,等于的時候只能返回false。
            posted @ 2016-10-08 11:19 李佳 閱讀(1475) | 評論 (0)編輯 收藏
              2009年11月25日
            推倒的過程就已經學到了不少東西....
            最近重寫了以前的一個程序...原來 用了OO 代碼可以寫的如此優雅...
            建議沒事了  推推以前的程序重寫  學到的東西也是不少的  特別是對需求的理解 對架構的設計

            posted @ 2009-11-25 15:01 李佳 閱讀(327) | 評論 (0)編輯 收藏
              2009年11月17日
            原來自己以前一直是把C++當成C用 盡管里面有class  但是  如果思想是過程的  再好的OO語言也是無助的

            改代碼... 好好學習OO

            posted @ 2009-11-17 15:39 李佳 閱讀(602) | 評論 (1)編輯 收藏
              2009年11月9日
            少了硬編碼  代碼確實好看了很多...
            上個例子... 滾動視圖部分的
            修改前的代碼
            void CTransportWnd::OnPaint()
            {    
                CPaintDC dc(
            this);
                
                m_tooltip.RemoveAllTools();    
            //清空所有標記

                CRect rect;    
                GetClientRect(rect);    
                DocToClient(rect);
                HDC dcMem;
                HBITMAP bm;

                bm 
            = CreateCompatibleBitmap(dc.m_hDC, rect.Width(), rect.Height());
                dcMem 
            = CreateCompatibleDC(dc);
                SelectObject(dcMem, bm);

                
            //////////////////////////
                Graphics graphics(dcMem);    
                graphics.SetSmoothingMode(SmoothingModeHighQuality);

                
            // background
                graphics.FillRectangle(&SolidBrush(Color(255255255255)), rect.left, rect.top, rect.Width(), rect.Height());

                
            // concrete flow
                DrawAllPlaces(graphics, rect);

                BitBlt(dc, 
            00, rect.Width(), rect.Height(), dcMem, 00, SRCCOPY);

                DeleteObject(bm);
                DeleteDC(dcMem);

                
            //更改滾動條
                GetClientRect(&rect);
                
            int iCount = m_vecPlaces.size();
                
            int iTotalHeight = (iCount / 2* (FLOW_HEIGHT+10);
                SetScrollSizes( MM_LOENGLISH, CSize(rect.Width() 
            - 20, iTotalHeight) );
            }

            修改過后的代碼
            void CWorksiteWnd::OnDraw(CDC* pDC)
            {
                
            // TODO: 在此處為本機數據添加繪制代碼
                m_tooTip.RemoveAllTools();    //清空所有標記

                CRect rect;    
                GetClientRect(rect);        

                
            //繪圖
                Graphics graphics( pDC->m_hDC );
                DrawAllPlaces(graphics, rect);

                
            //更新滾動條
                GetClientRect(&rect);
                
            int iCount = m_vecPlaces.size();
                
            int iTotalHeight = iCount  * (FLOW_HEIGHT+10+ 20;
                SetScrollSizes( MM_TEXT, CSize(rect.Width() 
            - 20, iTotalHeight) );    
            }
            單單拋開雙緩沖不說   那個DocToClient這個函數簡直是丑陋無比 而且是設備相關的(換了分辨率就變樣了...)

            void CTransportWnd::DocToClient(CRect& rect)
            {    
                CClientDC dc(
            this);
                OnPrepareDC(
            &dc, NULL);
                dc.LPtoDP(rect);
                rect.NormalizeRect();
                
            //rect.bottom += 5000;
                
            //rect.top -= 198;
            }
            代碼的丑陋可能現在還看不出來...在上一段小小的代碼  后面畫圖部分的

            void CTransportWnd::DrawAllPlaces(Graphics& graphics, CRect rect)
            {
                
            //rect.top += 188;
                CRect rectTemp;
                GetClientRect(
            &rectTemp);
                rect.top 
            += rectTemp.bottom;
                
            //rect.top = 0;
                vector<PLACE_STATION*>::iterator it = m_vecPlaces.begin();
            簡直就是war3里面的憎惡...  用肉縫起來的代碼  后面還有大量的
            CPoint pointScorll = GetScrollPosition();
                        rectTemp.bottom 
            += pointScorll.y;
                        rectTemp.top 
            += pointScorll.y; 
            哎  今天花了一早上更改代碼   現在的代碼看著要舒服多了  還是聽感謝侯捷的<深入淺出MFC>  昨晚無意間翻到的CScorllView這一節  一下就看明白代碼的設備相關性的問題出在哪了...   看來還是要時不時翻翻書

            posted @ 2009-11-09 14:42 李佳 閱讀(475) | 評論 (0)編輯 收藏
              2009年10月31日
            前段時間自己寫了一個日志類  不過是MFC寫的   今天閑著沒事  就用SDK重寫了這個類  算是增加一點可移植性吧...
            類的使用也很簡單  初始化的時候傳遞一個日志名稱 
            然后在需要寫日志的地方 直接調用這個對象的WriteLog函數傳遞一個字符串進去就行了
            如果需要時間戳  則調用WriteLogWithTime函數  一樣的接口
            支持設置日志大小  SetLogSize()   //KB計算
            代碼很簡單  一百來行  不過用著還算挺方便的  下午就用這個日志類找到了一個以前工程中的SQL相關聯的BUG 呵呵 

            .h文件
            /*****************************************************
            *文件名稱: Log_SDK.h
            *功能說明: 使用SDK + STL重寫的一個日志類 增加可移植性
            *創建時間: 09.10.31
            *文件作者: zip
            *****************************************************
            /
            #pragma once
            #include 
            <string>
            using namespace std;

            class LogSDK
            {
            public:
                LogSDK(
            string strFileName);
                
            ~LogSDK(void);
                BOOL InitLogSDK();
                BOOL WriteLog(TCHAR
            * pContent);
                BOOL WriteLogWithTime(TCHAR
            * pContent);        //每次寫一行 且帶時間
                BOOL WriteLogAtFirstLine(TCHAR* pContent);    //將最近的日志寫在最前面    
                void SetLogSize(int iSize);

            private:
                HANDLE m_hFile;
                
            string m_strFileName;
                
            string m_strFormat; 
                CRITICAL_SECTION m_cs;                
            //臨界區
                BOOL m_bInit;                            //初始化標志位
                int m_iSize;                                //文件大小    -- KB計算

                
            string GetTimeStr();
            };

            .cpp文件
            /***************************************************
            *文件名稱: Log_SDK.cpp
            *功能說明: LogSDK的實現文件
            *創建時間: 09.10.31
            *文件作者: zip
            ***************************************************
            /
            #include 
            "StdAfx.h"
            #include 
            ".\log_sdk.h"

            LogSDK::LogSDK(
            string strFileName)
            {
                m_bInit 
            = FALSE;
                m_strFileName 
            = strFileName;
                m_iSize 
            = 20;    //默認20KB
                InitLogSDK();
            }

            LogSDK::
            ~LogSDK(void)
            {
                CloseHandle(m_hFile);
            }

            BOOL LogSDK::InitLogSDK()
            {    
                m_hFile 
            = CreateFile(m_strFileName.c_str() , GENERIC_ALL ,
                    FILE_SHARE_WRITE , NULL ,  OPEN_ALWAYS , FILE_ATTRIBUTE_NORMAL , NULL);
                
            if (m_hFile == INVALID_HANDLE_VALUE)
                {
                    DWORD dwErrorCode 
            = GetLastError();
                    TCHAR szErrMsg[
            255];
                    sprintf(szErrMsg , 
            "打開文件失敗 , 錯誤代碼:%d" , dwErrorCode);
                    
            //AfxMessageBox(szErrMsg);
                    MessageBox(NULL , szErrMsg , _T("警告") ,IDOK);
                    
            return FALSE;
                }
                ::InitializeCriticalSection(
            &m_cs);    //初始化臨界區
                m_bInit = TRUE;
                
            return TRUE;
            }

            //普通的寫日志
            BOOL LogSDK::WriteLog(TCHAR* pContent)
            {
                ASSERT(m_bInit);
                DWORD dwFileLenHigh;
                DWORD dwFileLen 
            = GetFileSize(m_hFile , &dwFileLenHigh);
                
            if (dwFileLen > (DWORD)m_iSize * 1024)    //文件過大 清空文件
                {
                    SetFilePointer(m_hFile , 
            0 , NULL , FILE_BEGIN);    //移動文件指針
                    SetEndOfFile(m_hFile);//清空文件
                }
                
            string strContent(pContent);
                strContent 
            += "\r\n";

                BOOL bRet 
            = TRUE;
                ::EnterCriticalSection(
            &m_cs);
                SetFilePointer(m_hFile , 
            0 , NULL , FILE_END);    //移動到文件末尾
                DWORD dwWriteLen;
                BOOL bSuccess 
            = WriteFile(m_hFile , strContent.c_str() ,
                    (DWORD)strContent.length() , 
            &dwWriteLen , NULL);
                ASSERT(dwWriteLen 
            == strContent.length());
                
            if (!bSuccess)
                {
                    DWORD dwErrorCode 
            = GetLastError();
                    TCHAR szErrMsg[
            255];
                    sprintf(szErrMsg , 
            "寫入日志文件失敗 , 錯誤代碼:%d" , dwErrorCode);        
                    MessageBox(NULL , szErrMsg , _T(
            "發生了嚴重的錯誤") , IDOK);
                    bRet 
            = FALSE;    //此處不用返回  還要釋放臨界區
                }
                ::LeaveCriticalSection(
            &m_cs);

                
            return bRet;
            }

            //帶有時間戳的日志
            BOOL LogSDK::WriteLogWithTime(TCHAR* pContent)
            {
                ASSERT(m_bInit);
                DWORD dwFileLenHigh;
                DWORD dwFileLen 
            = GetFileSize(m_hFile , &dwFileLenHigh);
                
            if (dwFileLen > (DWORD)m_iSize * 1024)    //文件過大 清空文件
                {
                    SetFilePointer(m_hFile , 
            0 , NULL , FILE_BEGIN);    
                    SetEndOfFile(m_hFile);
            //清空文件
                }
                
            //strcat(pContent , "\r\n");
                string strContent(pContent);
                strContent 
            += "\r\n";
                strContent.insert(
            0 , "  ");
                strContent.insert(
            0 , GetTimeStr());

                BOOL bRet 
            = TRUE;
                ::EnterCriticalSection(
            &m_cs);
                SetFilePointer(m_hFile , 
            0 , NULL , FILE_END);    //移動到文件末尾
                DWORD dwWriteLen;
                BOOL bSuccess 
            = WriteFile(m_hFile , strContent.c_str() ,
                    (DWORD)strContent.length() , 
            &dwWriteLen , NULL);
                ASSERT(dwWriteLen == strContent.length());
                if (!bSuccess)
                {
                    DWORD dwErrorCode 
            = GetLastError();
                    TCHAR szErrMsg[
            255];
                    sprintf(szErrMsg , 
            "寫入日志文件失敗 , 錯誤代碼:%d" , dwErrorCode);        
                    MessageBox(NULL , szErrMsg , _T(
            "發生了嚴重的錯誤") , IDOK);
                    bRet 
            = FALSE;    //此處不用返回  還要釋放臨界區
                }
                ::LeaveCriticalSection(
            &m_cs);

                
            return bRet;
            }

            //返回格式化的時間字符串
            string LogSDK::GetTimeStr()
            {
                SYSTEMTIME sys;
                ::GetLocalTime(
            &sys);    //獲取當前系統時間
                TCHAR szTime[64];
                memset(szTime , 
            0 , 64);
                sprintf(szTime , 
            "%d-%02d-%02d %02d:%02d:%02d.%03d" , 
                    sys.wYear , sys.wMonth , sys.wDay , sys.wHour , sys.wMinute , sys.wSecond , sys.wMilliseconds);
                
            return string(szTime);
            }

            void LogSDK::SetLogSize(int iSize)
            {
                m_iSize 
            = iSize;
            }

            也可以算鍛煉一下API的操作吧...

            posted @ 2009-10-31 17:58 李佳 閱讀(1151) | 評論 (1)編輯 收藏
              2009年10月28日
            今天準備給一個視圖增加一個滾動條   自然想到了從CScorllView中繼承 可是繼承了以后  發現滾動的時候會出現殘影
            如圖

            滾動條滾動以后

            在網上找到了一個例子  里面有一個函數引起了我的注意
            void CPaintWithDoubleBufferView::DocToClient(CRect& rect)
            {
                CClientDC dc(
            this);
                OnPrepareDC(
            &dc, NULL);
                dc.LPtoDP(rect);
                rect.NormalizeRect();
            }
            原來問題出在這了...
            坐標沒有轉換  于是在自己的工程中增加了一個坐標轉換的接口  再次調試   完成

            說實話  并不大懂為什么要這么做...

            posted @ 2009-10-28 15:44 李佳 閱讀(370) | 評論 (0)編輯 收藏
              2009年10月22日
            系統待機功能對于我這種筆記本用戶很常見   一直不知道怎么實現
            今天搜索了一下  找到了一個命令行的   稍微一改  就能加到代碼中去了  

            system("rundll32.exe powrprof.dll SetSuspendState");

            測試通過

            posted @ 2009-10-22 12:02 李佳 閱讀(467) | 評論 (2)編輯 收藏
              2009年9月21日
            這段時間上網算是找瘋了...界面真是相當的麻煩
            下面推薦一個OutLook類   可以很方便的給自己的程序增加一個OutLook樣式的視圖
            文件上傳下來了   又需要的  自己研究研究吧
            這段時間一直在用一個國內的VC知識庫上的一個OutLook類   今天再和這個國外的OutLook類一比較.. 汗...
            以后   還是應該多多上上國外網站    

            效果圖就不上了   自己看吧   比較華麗

            下載地址
            http://www.shnenglu.com/Files/lijiakxl/OutBarDemo.rar
            posted @ 2009-09-21 16:02 李佳 閱讀(515) | 評論 (1)編輯 收藏
              2009年9月16日
            哎  新的工作就是做自己最薄弱的界面部分了...
            一大堆東西都不知道  慢慢來吧 
            東西都記下來 
            首先就是OutLook樣式的分割窗口  +   多視圖切換  代碼先放著

            //更換視圖的按鈕函數
            LRESULT COutBarView::OnOutbarNotify(UINT lParam , LONG wParam)
            {
                
            switch(wParam)
                {
                
            case IDC_OUT_BAR:
                    XT_CONTENT_ITEM
            * pContentItems = m_WndOutLookBar.GetMenuItem((int)lParam);
                    ASSERT(pContentItems);
                    CMainFrame 
            *pMainFrame = (CMainFrame *)AfxGetApp()->m_pMainWnd;
                    
            switch(lParam)
                    {
                    
            case 0:
                        pMainFrame
            ->SwitchToView(RED);
                        
            break;
                    
            case 1:
                        pMainFrame
            ->SwitchToView(BLACK);
                        
            break;
                    }
                }
                
            return 1;
            }

            //創建Outlook工具欄
            int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
            {
                
            if (CFrameWnd::OnCreate(lpCreateStruct) == -1)
                    
            return -1;
                
                
            if (!m_wndToolBar.CreateEx(this, TBSTYLE_FLAT, WS_CHILD | WS_VISIBLE | CBRS_TOP
                    
            | CBRS_GRIPPER | CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC) ||
                    
            !m_wndToolBar.LoadToolBar(IDR_MAINFRAME))
                {
                    TRACE0(
            "未能創建工具欄\n");
                    
            return -1;      // 未能創建
                }

                
            if (!m_wndStatusBar.Create(this||
                    
            !m_wndStatusBar.SetIndicators(indicators,
                      
            sizeof(indicators)/sizeof(UINT)))
                {
                    TRACE0(
            "未能創建狀態欄\n");
                    
            return -1;      // 未能創建
                }
                
            // TODO: 如果不需要工具欄可停靠,則刪除這三行
                m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);
                EnableDocking(CBRS_ALIGN_ANY);
                DockControlBar(
            &m_wndToolBar);

                
            return 0;
            }
            //切換View   切換視圖
            void CMainFrame::SwitchToView(eView nView)
            {
                CRect rect;
                CCreateContext context;

                GetClientRect(
            &rect);
                CView
            * pOldView = (CView* )m_wndSplitter.GetPane(0 , 1);
                CDocument
            * pDoc = (CDocument* )pOldView->GetDocument();
                context.m_pCurrentDoc 
            = pDoc;
                context.m_pCurrentFrame 
            = this;
                context.m_pNewDocTemplate 
            = pDoc->GetDocTemplate();

                
            switch (nView)
                {
                
            case RED:
                    context.m_pNewViewClass 
            = RUNTIME_CLASS(CTestView2);
                    context.m_pLastView 
            = pOldView;
                    m_wndSplitter.DeleteView(
            0 , 1);    //刪除舊的視圖
                    m_wndSplitter.CreateView(0 , 1 ,    //創建新視圖
                        RUNTIME_CLASS(CTestView2) , CSize(100100) , &context);
                    
            break;
                    
                
            case BLACK:
                    context.m_pNewViewClass 
            = RUNTIME_CLASS(COutBarStyleView);
                    context.m_pLastView 
            = pOldView;
                    m_wndSplitter.DeleteView(
            0 , 1);    //刪除舊的視圖
                    m_wndSplitter.CreateView(0 , 1 ,    //創建新視圖
                        RUNTIME_CLASS(COutBarStyleView) , CSize(100100) , &context);
                    
            break;
                }
                m_wndSplitter.RecalcLayout();  
                m_wndSplitter.SetActivePane(
            0,1); 
            }

            // CMainFrame 消息處理程序
            BOOL CMainFrame::OnCreateClient(LPCREATESTRUCT lpcs, CCreateContext* pContext)
            {
                
            // 創建切分窗口
                if (!m_wndSplitter.CreateStatic(this12))
                    
            return FALSE;

                
            if (!m_wndSplitter.CreateView(00, RUNTIME_CLASS(COutBarView), CSize(100100), pContext) ||
                    
            !m_wndSplitter.CreateView(01, RUNTIME_CLASS(COutBarStyleView), CSize(100100), pContext))
                {
                    m_wndSplitter.DestroyWindow();
                    
            return FALSE;
                }
                
            return TRUE;    //此處必須返回TRUE才能分割窗口
            }

            posted @ 2009-09-16 10:22 李佳 閱讀(643) | 評論 (0)編輯 收藏
              2009年9月11日

            數據庫操作 
            m_pConn->Execute((_bstr_t)strSQL , &index , 1);
            第二個參數的值是影響的行數
            有了這個  就可以在Update數據庫的記錄的時候不用先Select查看是否存在數據而執行兩條SQL語句影響服務器的效率了


            捕獲ADO的數據庫操作的異常
            catch(_com_error e)
                {
                    ::AfxMessageBox(e.Description() , MB_OK);
                    
            return FALSE;
                }
            三 
            將double類型的時間轉換成時間字符串
            CString strGPSTime;
                COleDateTime GPStime(GPSDate.gpsTime);
                strGPSTime 
            = GPStime.Format("%Y-%m-%d %H:%M:%S");    //GPS時間

            小技巧 在MFC的編輯框顯示信息的時候  我以前一般都是 直接
            m_strMsg += "提示信息:";
            這樣會出現往下拖  很煩人  
            今天剛想到一個小技巧
            在插入信息的時候 我們可以插入到頭部去  這樣就不會滾動 我們看到的就是最新的信息了
            m_strMsg.Insert(0 , "信息提示:");

            //10.22 新增
            對話框的巧妙隱藏   不閃屏!
            隱藏窗口
            void CFlashThiefDlg::OnWindowPosChanging(WINDOWPOS* lpwndpos)
            {
                lpwndpos
            ->flags &= ~SWP_SHOWWINDOW;
                CDialog::OnWindowPosChanging(lpwndpos);    
            }


            判斷數據庫中的一張表是否存在的函數
            //判斷一張表是否存在
            BOOL IsTableExsist(CString strTableName)
            {
                
            try 
                {    
                    CStringArray arrTableNames;
                    _RecordsetPtr Recordset   
            =   m_pConn->OpenSchema(adSchemaTables);  
                    _variant_t   l_vDBTableName;  
                    _bstr_t   bstrTableType;        
                    
            while(!Recordset->adoEOF)  
                    {  
                        l_vDBTableName   
            =   Recordset->GetCollect("TABLE_NAME");    
                        bstrTableType   
            =   Recordset->GetCollect("TABLE_TYPE");  
                        
            if   ((bstrTableType   ==   (_bstr_t)"TABLE")||(bstrTableType   ==   (_bstr_t)"VIEWS"))  
                        {  
                            arrTableNames.Add((
            char   *)_bstr_t(l_vDBTableName));  
                        }  
                        Recordset
            ->MoveNext();  
                    }  

                    
            int   iCount   =   arrTableNames.GetSize();   
                    
            for (int i = 0 ; i < iCount ; i++)
                    {
                        CString
            & strName = arrTableNames[i];
                        
            if (strName == strTableName)
                            
            return TRUE;            
                    }
                }
                
            catch(_com_error& e)
                {
                    ASSERT(FALSE);
                    CString str;
                    str.Format(
            "文件名稱: %s \n 所在代碼行 : %d 執行SQL語句失敗 錯誤原因 %s" , __FILE__ , __LINE__ , (LPCSTR)e.Description());
                    TRACE(str);        
                    AfxMessageBox(str);    
                    
            return FALSE;
                }

                
            return FALSE;
            }

            以后再繼續

            posted @ 2009-09-11 16:06 李佳 閱讀(711) | 評論 (0)編輯 收藏
            僅列出標題  下一頁
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            文章檔案

            相冊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久成人影院精品777| 91久久精品91久久性色| 久久艹国产| 久久本道综合久久伊人| 久久久久久久久久久精品尤物 | 午夜视频久久久久一区| 超级碰碰碰碰97久久久久| 99久久国产精品免费一区二区| 亚洲精品高清国产一线久久| 99精品国产在热久久| 久久亚洲精品无码观看不卡| 久久这里都是精品| 2021久久精品国产99国产精品| 久久亚洲中文字幕精品一区| 性色欲网站人妻丰满中文久久不卡| 久久精品www人人爽人人| 久久国产成人午夜aⅴ影院| 精品久久久久久中文字幕大豆网 | 日本久久中文字幕| 亚洲∧v久久久无码精品| 欧美久久一区二区三区| 97精品久久天干天天天按摩| 99久久免费国产精品特黄| 亚洲国产精品婷婷久久| 久久久久久国产精品无码下载 | 久久成人18免费网站| 国产午夜免费高清久久影院| 欧美精品丝袜久久久中文字幕 | 97精品伊人久久久大香线蕉| A级毛片无码久久精品免费| 婷婷久久香蕉五月综合加勒比| 久久91这里精品国产2020| 97久久精品国产精品青草| 亚洲av伊人久久综合密臀性色| 色综合久久88色综合天天 | 国产三级观看久久| 99久久精品无码一区二区毛片 | 无码国内精品久久人妻麻豆按摩| 久久精品国产99国产精偷| 久久久无码精品亚洲日韩蜜臀浪潮| 亚洲v国产v天堂a无码久久|