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

小明思考

高性能服務器端計算
posts - 70, comments - 428, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

C++代碼靜態分析工具-Prefast

Posted on 2006-03-28 13:59 小明 閱讀(13317) 評論(7)  編輯 收藏 引用 所屬分類: C/C++ 、Tools

1. 什么是Prefast

Prefast是一種代碼分析工具,它能夠幫助你找到編譯器不能找到的錯誤或者缺陷。Prefast首次被微軟集成到Visual Studio 2005 Team Suite中去,使用起來非常方便。

2.怎么使用Prefast
在vs2005 Team Suite中,使用Prefast非常簡單。修改你的工程屬性,設置Enable Code Analysis For C/C++為Yes.

prefast1.jpg

效果:
prefast2.jpg

注意到有可能錯誤的地方以淺灰色顯示在編輯器中了。

3.Prefast能幫你找到哪些錯誤

1)沒有初始化

// no?initial
void ?defect1()
{
????????
int ?a;
????????
int ?b;

????????b?
= ?a;
}

會報: d:\test\testcode\testcode.cpp(18) : warning C6001: Using uninitialized memory 'a': Lines: 15, 16, 18

2)空指針取值

// one?path?dereference?NULL
void ?defect4( int ?b,? int ?c)
{
????????
int ? * p? = ?NULL;
????????
int ?a? = ? 1 ;

????????
if ?(b? == ? 1 )?{
????????????????
if ?(c? == ? 1 )?{
????????????????????????p?
= ? & a;
????????????????}
????????????????
else ?{
????????????????????????????????????????????????
????????????????}
????????}
????????
else ?{
????????????????
if ?(c? == ? 1 )?{

????????????????}
????????????????
else ?{
????????????????????????p?
= ? & a;
????????????????}
????????}

????????
* p;

????????
return ;
}????

會報:d:\test\testcode\testcode.cpp(65) : warning C6011: Dereferencing NULL pointer 'p': Lines: 45, 46, 48, 57, 65

3)可能錯誤的運算符優先級

void ?defect5()
{
????????
int ?a? = ? 1 ;
????????
int ?b? = ? 1 ;
????????
int ?c? = ? 1 ;

????????
if ?(a? & ?b? == ?c)
????????????????
return ;
}

會報: d:\test\testcode\testcode.cpp(76) : warning C6281: Incorrect order of operations: relational operators have higher precedence than bitwise operators

4)可能的buffer overrun

void ?defect8()
{
????????
char ?buf[ 100 ];
????????
char ?buf2[ 200 ];
????????
int ?i? = ? 100 ;

????????sprintf(buf,?
" hello?world?%d " ,?i);
????????strcpy(buf,?buf2);
}

會報: d:\test\testcode\testcode.cpp(133) : warning C6202: Buffer overrun for 'buf', which is possibly stack allocated, in call to 'strcpy': length '200' exceeds buffer size '100'

5)可能的無窮循環

// infinite?loop
void ?defect14()
{
????????signed?
char ?i;

????????
for ?(i? = ? 100 ;?i? >= ? 0 ;?i ++ )?{
????????????????;?
????????}
}

會報: d:\test\testcode\testcode.cpp(198) : warning C6292: Ill-defined for-loop: counts up from maximum

6)格式字符串錯誤

// Format?string?mismatch
void ?defect21()
{
????????
char ?buff[ 5 ];
????????sprintf(buff,?
" %s?%s " ,? " a " );
}

會報: d:\test\testcode\testcode.cpp(277) : warning C6063: Missing string argument to 'sprintf' that corresponds to conversion specifier '2'

7)安全問題

void ?defect27()
{
????????CreateProcess(NULL,
???????????????
" c:\\program?files\\Project.exe?arg1 " ,? // correct?"\"c:\\program?files\\Project.exe\"?arg1",
???????????????NULL,
???????????????NULL,
???????????????
false ,
???????????????
0 ,
???????????????NULL,
???????????????NULL,
???????????????NULL,
???????????????NULL);???????????????
}

會報: d:\test\testcode\testcode.cpp(327) : warning C6277: NULL application name with an unquoted path in call to 'CreateProcessA': results in a security vulnerability if the path contains spaces

8)=和==誤用

void ?defect32()
{
????????
int ?a? = ? 1 ;

????????
if ?(a? = ? 2 )
????????????????
return ;
}

會報: d:\test\testcode\testcode.cpp(405) : warning C6282: Incorrect operator: assignment of constant in Boolean context. Consider using '==' instead

9)邏輯運算問題

// always?false
void ?defect45()
{
????????
int ?x;

????????
if ?( 0 ? && ?x ++ )?{
????????????????;
????????}
}

會報: d:\test\testcode\testcode.cpp(564) : warning C6237: (<zero> && <expression>) is always zero. <expression> is never evaluated and might have side effects

10)其他





Feedback

# re: C++代碼靜態分析工具-Prefast  回復  更多評論   

2006-03-28 17:36 by 笑笑生
不錯

# re: C++代碼靜態分析工具-Prefast  回復  更多評論   

2006-03-28 18:32 by christanxw
哪里可以下載?

# re: C++代碼靜態分析工具-Prefast  回復  更多評論   

2006-03-28 20:57 by fiestay
樓上的哥們,樓主逗說了,這個是和VS.net 2005集成在一起的:)

這工具看起來還不錯,沒有具體用過.有個叫C++Test的工具也能對代碼進行分析,也可以進行單元測試,也不錯:)

# re: C++代碼靜態分析工具-Prefast  回復  更多評論   

2006-03-29 12:12 by flyingxu
有VC6能用的嗎?

# re: flyingxu   回復  更多評論   

2006-03-29 12:57 by 小明
vc6中使用Prefast的方法:

prefast是附帶在微軟的DDK中的

In VC6 project

1. Install Windows IFS Kit and DDK package
2. Execute Development Kits->Windows IFS Kit and DDK ->Build environment -> windows 2000->windows 2000 checked build environment
3. Export Visual Studio project to a .mak file
4. remove /GZ in .mak file or link fail
5. Edit a run.bat file (not necessary, only for set new include and lib path)

run.bat file content
----------------
rem set include and lib path
set include=C:\Program Files\Microsoft Visual Studio\VC98\atl\include;C:\Program Files\Microsoft Visual Studio\VC98\mfc\include;C:\Program Files\Microsoft Visual Studio\VC98\include
set lib=C:\Program Files\Microsoft Visual Studio\VC98\mfc\lib;C:\Program Files\Microsoft Visual Studio\VC98\lib
rem clean environment
nmake /f httpgetfile.mak clean
rem run prefast command
C:\WINDDK\3790.1830\bin\x86\prefast\scripts\prefast nmake /f httpgetfile.mak CFG="HttpGetFile - Win32 Debug"
rem unset include and lib path
set lib=
set include=

# re: C++代碼靜態分析工具-Prefast  回復  更多評論   

2008-11-03 10:01 by 微波輻射
C上可以用嗎?

# re: C++代碼靜態分析工具-Prefast  回復  更多評論   

2008-11-04 17:01 by zhangyz
linux 有這樣的工具嗎?
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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网站| 老牛嫩草一区二区三区日本| 久久久国产一区二区三区| 国产精品入口福利| 一本久久知道综合久久| 亚洲最新视频在线播放| 欧美大片一区二区| 欧美高清视频一区二区| 亚洲黄色性网站| 久久综合五月天婷婷伊人| 久久久水蜜桃av免费网站| 国产欧美日韩在线| 香蕉国产精品偷在线观看不卡| 亚洲欧美日本另类| 国产精品乱子乱xxxx| 中文在线一区| 午夜精品影院| 国产欧美精品一区| 校园春色国产精品| 久久亚洲一区二区三区四区| 韩日精品视频一区| 久久亚洲影音av资源网| 欧美成人一区在线| 亚洲人成欧美中文字幕| 欧美精品v国产精品v日韩精品| 91久久精品久久国产性色也91 | 影音先锋亚洲电影| 久久婷婷人人澡人人喊人人爽| 麻豆精品一区二区综合av| 91久久黄色| 欧美日韩国产影片| 亚洲一区二区三区精品视频| 欧美专区第一页| 精品99一区二区| 欧美久久综合| 亚洲深夜福利| 欧美综合激情网| 亚洲国产一成人久久精品| 欧美精品成人一区二区在线观看| 99精品视频免费| 久久狠狠亚洲综合| 亚洲靠逼com| 国产精品视频自拍| 卡通动漫国产精品| 一区二区av| 美女网站久久| 亚洲综合国产精品| 一区二区视频欧美| 欧美日韩色婷婷| 欧美在线视频在线播放完整版免费观看 | 久久久久久久999| 亚洲精品国精品久久99热| 国产精品久久久久久一区二区三区 | 亚洲尤物视频在线| 欧美国产一区在线| 午夜精品久久久久久久| 亚洲福利在线观看| 国产精品午夜春色av| 老司机一区二区| 午夜精品av| 亚洲精品一区在线观看| 噜噜噜91成人网| 亚洲一区尤物| 亚洲人精品午夜在线观看| 国产女人精品视频| 欧美另类视频在线| 久久久久久久999| 亚洲欧美在线免费| 99精品国产在热久久下载| 蜜臀99久久精品久久久久久软件| 亚洲欧美成人| 亚洲伦理在线免费看| 激情欧美一区二区三区在线观看| 国产精品久久久久77777| 欧美不卡高清| 久久免费视频在线观看| 午夜在线一区二区| 亚洲——在线| 99人久久精品视频最新地址| 欧美不卡一区| 久久综合九色欧美综合狠狠| 午夜精品国产更新| 亚洲天堂av图片| 日韩视频一区二区三区| 亚洲国产精品一区二区尤物区 | 亚洲在线免费| 一区二区三区你懂的| 91久久亚洲| 亚洲高清视频中文字幕| 国内成人精品视频| 国产日韩欧美三区| 国产精品永久入口久久久| 国产精品乱人伦中文| 欧美丝袜第一区| 欧美四级电影网站| 欧美日韩中文字幕| 欧美色区777第一页| 欧美午夜精品一区| 欧美性天天影院| 国产精品免费网站| 国产精品自在线| 国产亚洲美州欧州综合国| 国产农村妇女精品一二区| 国产日韩欧美一区二区| 国产日韩av一区二区| 国产一区二区| 在线看国产一区| 亚洲日本一区二区| 亚洲精品视频一区| 亚洲特级片在线| 午夜久久tv| 久久久国产视频91| 欧美v国产在线一区二区三区| 欧美日韩一区二区在线视频| 欧美系列精品| 国产亚洲一区二区三区在线播放 | 日韩视频一区二区三区在线播放| 日韩一区二区免费高清| 亚洲一二三区精品| 久久精品国产精品| 欧美暴力喷水在线| 亚洲美女视频在线观看| 亚洲欧美www| 久久综合伊人| 欧美日韩不卡| 国产一区久久久| 亚洲伦理自拍| 欧美有码在线视频| 欧美激情aⅴ一区二区三区| 亚洲三级视频| 亚洲欧美国内爽妇网| 久久尤物电影视频在线观看| 欧美日韩免费在线| 黄色成人av| 亚洲亚洲精品在线观看 | 欧美mv日韩mv国产网站app| 亚洲伦理在线| 久久精品最新地址| 欧美日韩一区二区在线观看| 激情欧美日韩一区| 亚洲天天影视| 欧美成ee人免费视频| 亚洲视频福利| 欧美xxx在线观看| 国产日韩欧美在线| 99精品欧美一区二区三区| 久久久久久久波多野高潮日日| 亚洲精品国精品久久99热| 久久国产天堂福利天堂| 欧美三级精品| 亚洲欧洲一区| 久色婷婷小香蕉久久| 亚洲午夜女主播在线直播| 美日韩免费视频| 激情视频亚洲| 欧美在线播放| 亚洲色图自拍| 欧美日韩国产综合新一区| 亚洲电影第1页| 久久久av毛片精品| 中文欧美在线视频| 欧美日韩精品免费观看视一区二区 | 99综合视频| 亚洲高清在线观看一区| 香蕉成人啪国产精品视频综合网| 欧美视频一区二区三区…| 亚洲精品久久久蜜桃| 美国成人直播| 欧美一区日韩一区| 国产欧美精品va在线观看| 亚洲视频在线观看一区| 亚洲人人精品| 欧美精品福利视频| 亚洲美女免费视频| 亚洲国内高清视频| 女女同性精品视频| 亚洲黄色视屏| 亚洲国产天堂久久综合| 麻豆久久婷婷| 最新成人av在线| 亚洲国产成人精品久久| 免费成人性网站| 亚洲精品国产系列| 亚洲成色最大综合在线| 欧美va天堂在线| 亚洲美女视频在线观看| 亚洲黄一区二区三区| 欧美日韩一区二| 亚洲欧美另类在线观看| 亚洲一区欧美| 国内免费精品永久在线视频|