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

隨筆 - 5, 文章 - 0, 評論 - 13, 引用 - 0
數據加載中……

2010年3月21日

VC 單步調試(StepInto)的一個小技巧

  相對于Java之類的語言,缺少庫一直是C++最為詬病的一個部分。STL、Boost等庫的出現,在一定程度上彌補了這些缺憾。但這些庫帶來便利性的同時,也在調試代碼時帶來相當的不便。
  舉個例子,看下面一段代碼:
 
struct FooObj
{
    
char lower(char c){
        c 
|= 0x20;
        
return c;
    }
};

string s="Ok";
shared_ptr
<FooObj> ptr(new FooObj);
s[
0]=ptr->lower(s[0]);
  在s[0]=ptr->lower(s[0]); 這一行下斷點,想F11 StepInto進入lower函數調試,卻不得不先進入std::basic_string的[],然后再進入boost::shared_ptr,最后才真正進入我們想要調試的lower函數。這是相當的煩人。
  雖然可以在調試時,使用右鍵菜單中的Step Into Specific直接進入lower函數,但也很繁瑣。


  我們可以在注冊表中設置來避免vc 單步調試進入某些函數。具體的位置在:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\VisualStudio\9.0\NativeDE\StepOver
  其中vc2008是9.0,如果用的是其他版本的vc,則改成相應的版本號。在這個key下面新建兩個字符串:
"boost"="boost\\:\\:.*=NoStepInto"
"std"="std\\:\\:basic_string.*=NoStepInto"
  其中字符串值的含義:funcname=action,funcname是函數的名字,用正則表達式匹配, action則是執行的動作,可以是NoStepInto
或者StepInto(當action是NoStepInto時,可以省略)。NoStepInto,表示當遇到這個名字的函數時,單步調試不會進入到函數內部。注意的是,函數必須是包含命名空間的原始名字。就是說,它并不能匹配typedef內容。string是std命名空間中的一個basic_string,那么字符串值必須是basic_string,而不能是string。
  這是我的
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\VisualStudio\9.0\NativeDE\StepOver下的內容:


  Ok,現在完美了,在
s[0]=ptr->lower(s[0])這一行,按F11,進入的是我們想進入的lower函數,而不是stl或者boost中的內容。另一方面當我們偶然想跟入庫函數,也可以使用Step Into Specific來達到目的。

posted @ 2010-03-21 15:24 clane 閱讀(3791) | 評論 (0)編輯 收藏

2010年3月10日

vc2008 fstream不支持中文路徑的解決方案

     項目編譯后給朋友試運行,發現運行出錯,提示路徑不正確找不到配置文件。因為朋友是放在桌面運行的,于是推測是中文路徑的問題(因為路徑中包含"桌面"兩個漢字)。反應很詫異,什么年代了,還有中文路徑的問題...
     跟蹤了一下ifstream的open函數,發現ifstream在打開文件之前會通過_mbstowcs_l_helper函數把文件路徑從mutilbyte轉換到unicode。其中的關鍵轉換函數如下:
 if (_loc_update.GetLocaleT()->locinfo->lc_handle[LC_CTYPE] == _CLOCALEHANDLE)
        {
            
/* C locale: easy and fast */
            
while (count < n)
            {
                
*pwcs = (wchar_t) ((unsigned char)s[count]);
                
if (!s[count])
                    
return count;
                count
++;
                pwcs
++;
            }
            
return count;

        } 
    而vc的默認local信息就是_CLOCALEHANDLE,于是中文字符很悲劇的被轉換成了莫名其妙的一串東西。google了下,似乎很多人碰到了這個問題,也沒有特別好的解決方案,要不直接unicode,要不每次調用fstream前后都調用一遍setlocal,對代碼的侵入性都很強。
    我做了個封裝的解決方案,使用個模板類對fstream做一個wrapper,代碼如下:
template<class T>
struct fstream_fix
    :
public T
{
    fstream_fix(){};

    template
<class T1>
    fstream_fix(T1 v1){
        setlocale(LC_CTYPE, 
".936");
        T::open(v1);
        setlocale(LC_CTYPE, 
0);
    }

    template
<class T1,class T2>
    fstream_fix(T1 v1,T2 v2){
        setlocale(LC_CTYPE, 
".936");
        T::open(v1,v2);
        setlocale(LC_CTYPE, 
0);
    }


    template
<class T1>
    
void open(T1 v1){
        setlocale(LC_CTYPE, 
".936");
        T::open(v1);
        setlocale(LC_CTYPE, 
0);
    }

    template
<class T1,class T2>
    
void open(T1 v1,T2 v2){
        setlocale(LC_CTYPE, 
".936");
        T::open(v1,v2);
        setlocale(LC_CTYPE, 
0);
    }
};

#define ifstream fstream_fix<ifstream>
#define ofstream fstream_fix<ofstream>
    OK.完美,對原項目沒有任何影響,ifstream fi(filepath);filepath中含有中文也能正常工作了。:) 當然要注意的是,在宏定義之后,就不能再include <fstream>,不然可能會有編譯錯誤。



posted @ 2010-03-10 19:19 clane 閱讀(3887) | 評論 (5)編輯 收藏

2010年3月9日

IncrediBuild 30天試用過期破解清零工具

    IncrediBuild是一個協同編譯工具,對于大型vc項目來說,幾乎是一個必備品。廢話不多說,基本上有幾臺電腦裝了IncrediBuild,編譯速度就是原來的幾倍,很強很暴力。
    IncrediBuild有30天的試用期限,到期后就不能使用。很久以前做過一個時間清零工具,有需要的同學可以下載試用。當然如果是公司用戶,建議還是說服部門主管去買一套,絕對物有所值。
    執行Clear的時候,會搜索整個注冊表,速度有點慢,特別是電腦差的同學,不要以為是crash了,耐心等等就好。:)第一次執行之后會在目錄下生成一個key.txt,以后每次打開程序,就會自動清零時間,而不用執行Clear。

PS:安裝新版本的IncrediBuild后,需要重新執行Clear,搜索整個注冊表。

下載地址:http://m.shnenglu.com/Files/clane/xbuildcrack.zip

posted @ 2010-03-09 16:40 clane 閱讀(10547) | 評論 (5)編輯 收藏

2009年2月23日

vc編譯期的常量除法優化

在vc release模式下調試時,經??梢钥吹较旅嫘问降膮R編代碼:
00FB1202  mov         ecx,dword ptr ds:[00FB543Ch] 
00FB1208  sub         ecx,dword ptr ds:[00FB5438h] 
00FB120E  mov         eax,66666667h 
00FB1213  imul        ecx  
00FB1215  sar         edx,
5 
00FB1218  mov         ecx,edx 
00FB121A  shr         ecx,1Fh 
00FB121D  add         ecx,edx 
其實這是當被除數是常量時除法的編譯器優化。x/50h
優化方法是把除法轉換成乘以被除數然后右移.
x/y =>  x*(1 /y) =>  x* ((1<<37) /((1<<37)* y) ) =>x * ((1<<37)/ y)>>37
為了取整效果,最終結果將會是
x/y = x * ((1<<37 +y-1 )/ y)>>37
由于y 是常量,在編譯期,編譯器就可以計算出((1<<37 +y-1 )/ y)的值。
那么實際計算時,編譯期就可以把 x/y 轉換成 x *M >> 37, M =
((1<<37 +y-1 )/ y)
除以0x50 M = (1<<37 + 0x4F)/0x50 = 0x
66666667
那么x / 0x50相當于 (x*
0x66666667)>>37

posted @ 2009-02-23 00:16 clane 閱讀(1458) | 評論 (1)編輯 收藏

2009年1月8日

luabind的converter和policy

     摘要:       現在的C++設計,為了保證健壯性和復用性,特別是GP的流行,往往應用了大量的模板,容器,智能指針。但這對與LUA綁定來說絕對不是一個好消息,非常的煩瑣。個人覺得,在第三方的綁定庫里面,luabind和現代C++設計結合最好,也是靈活性最高的一個綁定庫。      lu...  閱讀全文

posted @ 2009-01-08 17:10 clane 閱讀(2749) | 評論 (2)編輯 收藏

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美一级午夜免费电影| 欧美激情第3页| 久久久国产91| 久久九九精品99国产精品| 午夜精品福利电影| 欧美一区二区高清| 欧美在线免费看| 久久久一区二区| 欧美xx视频| 亚洲精品久久久久久久久久久久久| 久久久久久亚洲综合影院红桃 | 亚洲日本黄色| 一区二区精品在线| 亚洲欧美一区二区三区久久| 亚洲欧美三级在线| 久久久www成人免费精品| 久久嫩草精品久久久久| 鲁鲁狠狠狠7777一区二区| 欧美国产在线观看| 久久av一区二区三区亚洲| 国产精品啊啊啊| 国产日韩欧美三区| 91久久精品一区| 亚洲午夜精品久久久久久浪潮 | 欧美成人蜜桃| 欧美中文字幕在线观看| 你懂的视频欧美| 国产精品久久久久久影视| 国产亚洲成av人在线观看导航 | 亚洲视频免费在线| 久久国产直播| 欧美激情一区二区三级高清视频| 国产精品国产三级国产普通话99| 精品成人在线| 欧美亚洲在线播放| 在线精品视频在线观看高清| 亚洲午夜高清视频| 欧美丰满高潮xxxx喷水动漫| 亚洲免费在线观看| 欧美日本韩国一区二区三区| 激情综合色丁香一区二区| 亚洲综合精品四区| 最新国产乱人伦偷精品免费网站 | 久久av二区| 亚洲免费观看高清完整版在线观看| 欧美一区二区三区视频免费| 国产精品电影网站| 亚洲免费播放| 米奇777超碰欧美日韩亚洲| 亚洲一区二区三区在线观看视频| 免费在线国产精品| 在线电影院国产精品| 午夜精品影院在线观看| 亚洲精品一区中文| 欧美激情一区二区三区全黄 | 99亚洲伊人久久精品影院红桃| 久久久久久久久伊人| 亚洲一区国产一区| 欧美日韩日本网| 一卡二卡3卡四卡高清精品视频| 欧美国产亚洲视频| 久久久久女教师免费一区| 欧美午夜视频一区二区| 好看的av在线不卡观看| 久久se精品一区二区| 宅男精品视频| 国产精品日韩精品| 亚洲一区二区三区在线看 | 国产精品一区二区视频| 在线视频精品一区| 亚洲日本va午夜在线影院| 亚洲嫩草精品久久| 国产伦精品一区二区三区视频孕妇 | 亚洲第一区在线| 欧美大成色www永久网站婷| 久久综合综合久久综合| 在线观看成人小视频| 麻豆国产精品va在线观看不卡| 久久国产精品久久精品国产| 黄色国产精品一区二区三区| 鲁大师成人一区二区三区| 久久国产精品亚洲77777| 欧美一区二区日韩| 1024日韩| 日韩亚洲欧美综合| 国产亚洲福利社区一区| 欧美刺激性大交免费视频| 欧美国产在线电影| 午夜欧美大片免费观看| 久久国产高清| aa日韩免费精品视频一| 亚洲欧美综合精品久久成人| 黑人巨大精品欧美黑白配亚洲| 亚洲成人资源网| 国产精品美女主播| 亚洲成人在线视频播放| 国产精品一区二区三区成人| 你懂的视频一区二区| 国产精品99一区| 麻豆精品一区二区av白丝在线| 欧美理论在线播放| 久久久久久久久久看片| 欧美视频一区二区三区| 欧美成熟视频| 国产欧美精品日韩| 亚洲精品国产无天堂网2021| 国产日韩欧美黄色| 日韩视频一区二区三区| 尤物精品在线| 亚洲免费视频成人| 日韩亚洲不卡在线| 久久视频在线免费观看| 午夜亚洲视频| 欧美日韩免费观看一区二区三区| 麻豆精品一区二区av白丝在线| 国产精品视频精品| 99av国产精品欲麻豆| 亚洲激情女人| 久久精品国产一区二区三区| 亚洲一区二区视频在线观看| 国产精品乱码人人做人人爱| 在线视频精品一区| 美女视频网站黄色亚洲| 久久综合给合| 国产午夜久久久久| 亚洲性av在线| 亚洲已满18点击进入久久| 欧美激情 亚洲a∨综合| 欧美激情bt| 亚洲欧洲精品一区二区三区| 久久综合色8888| 麻豆成人91精品二区三区| 欧美亚洲免费| 翔田千里一区二区| 欧美色视频一区| 99精品国产在热久久婷婷| 欧美日韩国内自拍| 欧美一区二区三区免费视| 久久影院午夜论| 国内精品视频久久| 午夜性色一区二区三区免费视频| 中文av字幕一区| 欧美成人高清视频| 男人天堂欧美日韩| 在线精品福利| 久久亚洲捆绑美女| 亚洲国产成人在线视频| 在线观看亚洲a| 久久本道综合色狠狠五月| 欧美在线视频一区二区| 激情文学综合丁香| 久久久精品欧美丰满| 久久婷婷国产综合精品青草| 国产精品综合久久久| 亚洲看片网站| 中文av一区二区| 欧美午夜a级限制福利片| 亚洲精品中文字幕在线观看| 国产一区二区日韩| 久久这里有精品视频| 免费欧美电影| 亚洲精品乱码久久久久久蜜桃麻豆| 久久免费视频一区| 久久野战av| 亚洲电影天堂av| 美女黄网久久| 亚洲国产日韩欧美| 一本久道久久综合婷婷鲸鱼| 国产精品久久久久影院色老大| 亚洲一区二区精品视频| 欧美一区二区在线看| 黄色精品一区二区| 香港久久久电影| 91久久精品国产91久久性色| 国内久久婷婷综合| 欧美超级免费视 在线| 久久精品视频免费播放| 亚洲日产国产精品| 国产精品国产一区二区| 亚洲欧美日韩精品久久亚洲区| 久久亚洲春色中文字幕| 亚洲天堂久久| 狠狠久久亚洲欧美专区| 欧美精品二区| 欧美一区二区黄| 亚洲一区二区欧美| 美日韩精品免费| 亚洲一区二区三区精品动漫| 国产色视频一区| 国产精品毛片高清在线完整版| 欧美成人综合一区| 欧美日韩一区在线观看| 午夜国产精品视频| 欧美大片18| 亚洲精品一区二区三| 极品中文字幕一区| 欧美先锋影音| 免费国产自线拍一欧美视频| 妖精成人www高清在线观看| 亚洲第一黄色网|