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

隨筆 - 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://www.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>
            亚洲欧美三级在线| 久久久国产一区二区| 亚洲精品乱码视频| 亚洲特级毛片| 久久久精品动漫| 久久婷婷综合激情| 欧美日韩午夜激情| 韩国av一区二区三区在线观看| 最近中文字幕日韩精品 | 国产精品极品美女粉嫩高清在线 | 香蕉久久夜色| 欧美一区二区视频在线观看2020 | 久久久青草婷婷精品综合日韩| 欧美日韩精品免费观看| 精品96久久久久久中文字幕无| 亚洲视频一区二区免费在线观看| 亚洲一区欧美一区| 欧美黄色一区二区| 黄色成人av网| 亚洲激情专区| 亚洲午夜成aⅴ人片| 毛片精品免费在线观看| 一区二区三区福利| 欧美另类亚洲| 日韩亚洲欧美在线观看| 毛片av中文字幕一区二区| 欧美另类变人与禽xxxxx| 久久国产精品久久久| 亚洲网站在线| 国产精品一区一区三区| 亚洲视屏一区| 欧美a级片网站| 伊人久久婷婷| 久久综合色影院| 国产精品第2页| 欧美国产视频在线观看| 久久视频精品在线| 欧美伊久线香蕉线新在线| 亚洲一区二区三区777| 亚洲国产毛片完整版 | 亚洲一区日本| 宅男66日本亚洲欧美视频| 国产精品99久久99久久久二8| 国产精品久久久久9999吃药| 亚洲福利一区| 欧美激情久久久久久| 国内精品久久久久久久影视蜜臀 | 99国产麻豆精品| 久久免费午夜影院| 久久亚洲精品欧美| 久久这里只有| 一区二区三欧美| 女女同性精品视频| 欧美黄免费看| 在线成人激情视频| 久久久久久9| 久久久久久久综合| 国内成+人亚洲| 久久激情久久| 99国产麻豆精品| 欧美福利一区| 亚洲欧洲精品一区| 99精品99| 欧美国产精品日韩| 欧美日韩一区二区免费视频| 亚洲日韩中文字幕在线播放| 欧美视频一二三区| 久久久国产91| 激情av一区二区| 久久久噜噜噜久久狠狠50岁| 男女激情视频一区| 欧美视频日韩| 亚洲主播在线观看| 一区二区国产精品| 欧美日韩国产小视频在线观看| 亚洲美女少妇无套啪啪呻吟| 国内精品视频一区| 久久免费视频这里只有精品| 农村妇女精品| 一区二区三区国产精华| 国产精品久久久久久久久免费| 欧美18av| 亚洲天堂免费观看| 国产精品欧美日韩| 亚洲人成在线观看网站高清| 亚洲午夜久久久久久久久电影网| 国产精品亚洲激情| 久久久久这里只有精品| 日韩视频永久免费| 久久精品在线视频| 99在线视频精品| 久久综合综合久久综合| 亚洲精品免费看| 久久gogo国模啪啪人体图| 亚洲成色精品| 久久琪琪电影院| 夜色激情一区二区| 一本综合精品| 韩国福利一区| 欧美日韩在线播放一区| 久久久国产精品一区二区三区| 欧美在线免费观看亚洲| 亚洲精选成人| 欧美大片免费久久精品三p| 欧美成人精品h版在线观看| 亚洲午夜精品久久久久久app| 韩国精品在线观看| 国产精品观看| 欧美国产一区二区在线观看| 午夜亚洲福利在线老司机| 91久久午夜| 欧美va亚洲va日韩∨a综合色| 性视频1819p久久| 国产麻豆精品theporn| 欧美va亚洲va香蕉在线| 欧美一区国产一区| 一二三区精品福利视频| 欧美高清在线精品一区| 日韩午夜中文字幕| 国内外成人在线| 国产欧美精品在线观看| 欧美一级午夜免费电影| 中文亚洲视频在线| 日韩视频一区二区三区在线播放| 欧美mv日韩mv亚洲| 久久免费高清| 亚洲乱码国产乱码精品精可以看 | 免费看成人av| 亚洲第一视频| 韩日视频一区| 国产日韩综合| 欧美性理论片在线观看片免费| 欧美一区二视频| 中文在线资源观看网站视频免费不卡 | 久久蜜桃资源一区二区老牛| 欧美一区二区三区精品| 亚洲视频综合| 亚洲一二三区精品| 亚洲欧美日韩国产中文| 久久久久免费视频| 久久久久久久久久久一区 | 日韩一级成人av| 亚洲欧洲日本国产| 亚洲人成在线观看网站高清| 亚洲欧洲一区二区三区在线观看| 欧美激情视频一区二区三区免费 | 欧美在线首页| 亚洲精品中文字幕在线| 午夜精品理论片| 亚洲一区二区伦理| 性欧美videos另类喷潮| 久久久av毛片精品| 欧美成人综合一区| 91久久国产综合久久蜜月精品 | 欧美aⅴ一区二区三区视频| 男女激情视频一区| 欧美日韩理论| 国产精品久久久久久久第一福利| 国产欧美日韩一区| 精品福利免费观看| 日韩视频中午一区| 亚洲一区二区视频在线| 好吊视频一区二区三区四区| 在线观看国产日韩| 夜夜爽av福利精品导航| 欧美在线观看视频| 欧美freesex交免费视频| 亚洲精品欧美精品| 亚洲女人天堂av| 毛片精品免费在线观看| 久久成人精品| 欧美成人免费在线| 国产精品一区二区在线| 亚洲福利在线视频| 狠狠色综合日日| 亚洲最新在线视频| 久久欧美中文字幕| 亚洲免费福利视频| 久久久精品tv| 国产精品久久亚洲7777| 亚洲高清免费| 欧美一二区视频| 亚洲国产精品久久久久| 欧美国产日韩精品免费观看| 一区二区三区不卡视频在线观看| 久久久久9999亚洲精品| 欧美性色视频在线| 亚洲精品社区| 老**午夜毛片一区二区三区| 在线亚洲伦理| 欧美日韩mp4| 亚洲国产老妈| 久久久久久91香蕉国产| 亚洲一区日韩在线| 欧美日韩18| 亚洲欧洲精品一区二区| 久久久久久久网| 午夜久久久久久| 日韩亚洲不卡在线| 亚洲伦理一区|