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

xyjzsh

first demo for gtest

1.  首先給出第一個運用gtest的demo
#include "stdafx.h"
#include 
"gmock/gmock-actions.h"

using namespace testing;

class Calculate
{
public:
    Calculate()
{}
    
long add(long a,long b){return a+b;}
}
;

class CalculateMock:public Calculate
{
public:
    CalculateMock():Calculate()
{}
    MOCK_METHOD2(add,
long(long a,long b));
}
;

long testFun(Calculate& cal)
{
    
return cal.add(2,3);
}

TEST(testMock,testAdd)
{
    CalculateMock obj;
    
long len = 10;
    ON_CALL(obj,add(
2,3)).WillByDefault(Return(len)); 
    EXPECT_CALL(obj,add(
2,3)).Times(1);
    
//obj.add(2,3);
    EXPECT_EQ(10, obj.add(2,3));
}


int _tmain(int argc, _TCHAR* argv[])
{
    testing::InitGoogleMock(
&argc, argv);  
    RUN_ALL_TESTS();
    
return 0;
}



做第一個demo需要注意的事項:
1. 將用到的gtest,gmock,和你自己運用的project用同樣的code generation 的形式一致,將 project property->C++->Code Generation: 設置為:Multi-threaded Debug(/MTd)
2. 添加 using namespace testing, 否則會出現‘Return’Identifier not found.這樣的錯誤

So excited to make it work after so much confusion, anxiety.
Fighting!!

posted @ 2013-02-06 17:14 呆人 閱讀(500) | 評論 (0)編輯 收藏

Failed to retrieve paths under VSTemplate for the specified registry hive[轉載]

最近更換開發機的環境,從Windows XP換到Windows 7,結果以前在XP下的一個VS2008的一個插件項目在新環境中編譯老是出錯:

AnswerFailed to retrieve paths under VSTemplate for the specified registry hive

在網上搜索了一番,終于找到一篇文章介紹的解決方案:

運行Vs2008 SDK-〉Tools-〉Reset the Microsoft Visual Studio 2008 SP1 Experimental hive

然后重新編譯就OK了。

http://www.cnblogs.com/tubo/archive/2009/09/14/1566654.html

posted @ 2012-04-26 11:13 呆人 閱讀(355) | 評論 (0)編輯 收藏

在VS中 build 和rebuild的區別

Build只編譯工程中上次修改過的文件,并鏈接程序生成可執行文件。
如果以前沒有作過編譯,它會自動調用Rebuild操作,依次編譯資源文件、源程序文件等;
Rebuild不管文件是否作過修改,都會編譯工程中的所有源文件。
Visual Studio的智能性還不夠,它有時不能非常準確地判斷出都有哪些文件需要重新編譯。
于是,當你Build時,它僅僅把它認為需要重新編譯的重新編譯一下,而有時候它的判斷實際是不夠的。
但Rebuild就不同了,它把所有的東西都重新編譯,不管改過的,沒改過的;還是它認為有依賴的,沒依賴的,統統重來。

posted @ 2012-02-20 10:54 呆人 閱讀(1402) | 評論 (0)編輯 收藏

用TortoiseGit第一次checkout

首先安裝msysgit,然后安裝TortoiseGit。
可以在程序中看到GitGUI和TortoiseGit。
使用GitGUI進行checkout。
步驟為:
1. 在電腦上create folder,命名為demo.
2.選中demo。在菜單中選擇git clone.
就可以checkout下來代碼。

posted @ 2011-12-29 17:26 呆人 閱讀(3013) | 評論 (0)編輯 收藏

sqlserver2008里面的游標

 SQL是一種基于集合的語言(a set-based language) ,他更擅長操作和提出一組數據,而不是對
 數據進行一行一行的處理。
 SQL is a set-based language ,meaning that is excels at mantipulating and retrieving
 set of rows ,rather than performing single row-by-row processing.
 如果你的程序里一定要一條一條的執行,那么一定要先考慮使用如while循環,子查詢,
 臨時表,表變量等等,如果這些都不能滿足要求,在考慮使用游標。
 
 T-SQL中游標的生存周期:
 1.用返回一個有效結果集的sql語句來定義一個游標。
  a cursor is defined via a SQL statement that returns a valid result set.
 2. 打開游標
 3. 一旦游標被打開就可以從游標中每次取出一行數據,要根據游標的定義可以向前去數據或
 向后取數據
 the rows can be fetched moving forword or backword ,depending on the original cursor definition.
 4. 根據游標的類型,數據可以被修改或者只能讀。
 5.最后,用完游標后,必須被顯示的關閉,并且從內存中移除。
 
 游標定義格式:
 declare cursor_name cursor
 [local|global]
 [forword_only|scroll]
 [static|keyset|dynamic|fast_forword]
 [read_only| scroll_locks|optimistic]
 [type_warning]
 for select_statement[for update [of column[,...]]]
 
The select_statement argument is the query used to define the data within the cursor. Avoid
using a query that hasmore columns and rows than will actually be used, because cursors, while
open, are kept inmemory. The UPDATE [OF column_name [,...n]] is used to specify those columns
that are allowed to be updated by the cursor.
 

posted @ 2011-11-03 16:28 呆人 閱讀(1704) | 評論 (0)編輯 收藏

sqlserver2008 條件循環

條件處理:condtional processing
1.case函數以一個表達式作為輸入,一個值作為輸出
格式:case 后面有輸入表達式,when后面的的每一個表達式都會和case后面的輸入表達式進行比較運算
如果相等,則返回,否則返回else后面的表達式,如果沒有else則返回NULL。
case input_expression
     when when_expression then result_expression
     [...n]
     [else else_result_expression]
end

case的第二種情況:
case后面沒有表達式,when后面跟的是bool表達式。返回第一個when后面計算為true的表達式
格式為:
case
 when bool_expression then result_expression
 [...n]
 else result_expression
end

2. if....else...的格式
if bool_expression
{sql_statement|sql_block}
[else
{sql_statement|sql_block}
]

3.begin ....end 相當于c++中的{...}用來形成一個代碼塊

4.條件循環
return,while,goto,waitfor

return
return 用于結束當前的sql塊,查詢,存儲過程。
類似于c++中的return。
return 可以返回一個數字

while 類似c++中的while,同樣支持break,continue,break來結束當前內層循環,continue繼續當前循環

waitfor格式
waitfor
 delay 'time_to_pass'//執行前等待的時間:格式為00:00:00小時:分鐘:秒
 |time 'time_to_execute'//設置實際執行的時間
 |(receive_statement)[,TimeOUT timeout]
 可以利用waitfor將某些復雜的執行設定為在相對空閑的時間內進行。

posted @ 2011-11-03 16:27 呆人 閱讀(1968) | 評論 (0)編輯 收藏

printf 輸出int64

__int64 long a=10;
printf("%i64u",a);

posted @ 2011-11-01 14:29 呆人 閱讀(473) | 評論 (0)編輯 收藏

sqlserver2008中數據類型的優先級

當兩個不同數據類型的表達式用運算符組合后,數據類型優先級規則指定將優先級較低的數據類型轉換為優先級較高的數據類型。如果此轉換不是所支持的隱式轉換,則返回錯誤。當兩個操作數表達式具有相同的數據類型時,運算的結果便為該數據類型。

SQL Server 對數據類型使用以下優先級順序:

  1. 用戶定義數據類型(最高)

  2. sql_variant

  3. xml

  4. datetimeoffset

  5. datetime2

  6. datetime

  7. smalldatetime

  8. date

  9. time

  10. float

  11. real

  12. decimal

  13. money

  14. smallmoney

  15. bigint

  16. int

  17. smallint

  18. tinyint

  19. bit

  20. ntext

  21. text

  22. image

  23. timestamp

  24. uniqueidentifier

  25. nvarchar(包括 nvarchar(max)

  26. nchar

  27. varchar(包括 varchar(max)

  28. char

  29. varbinary(包括 varbinary(max)

  30. binary(最低)

posted @ 2011-10-31 11:25 呆人 閱讀(445) | 評論 (0)編輯 收藏

一種類型的字符拷貝函數

1.函數原型:
LPTSTR lstrcpyn(     

    LPTSTR lpString1,
    LPCTSTR lpString2,//指向一個以NULL結束的字符串
    int iMaxLength   //從lpString2拷貝到lpString1的字符串個數,包括NULL字符
);
成功返回指向lpString1的指針,否則返回NULL。

如果lpString2的長度大于iMaxLength,該方法實際上是將lpString2中的前iMaxLength-1個字符一個NULL字符拷貝到lpString1中。
如果該方法成功,則lpString1一定是以NULL結束的字符串。

2._tcsncpy是一個宏,考慮在unicode的情況下
define _tcsncpy wcsncpy

wchar_t *wcsncpy(
   wchar_t *strDest,
   const wchar_t *strSource,
   size_t count
);

Parameters
strDest

Destination string.

strSource

Source string.

count

Number of characters to be copied.

Return Value

Returns strDest. No return value is reserved to indicate an error.
不能保證NULL結束,將count個字符拷貝到strDest中。




posted @ 2011-08-10 14:02 呆人 閱讀(433) | 評論 (0)編輯 收藏

重載標準輸出符號operator<<

CString是我自己定義的一個類
為了實現:
CString str("123abvc");
cout<<str<<endl;


聲明:
 ostream& operator<<(ostream& os,const CString& str);
實現:

ostream& operator<<(ostream& os,const CString& str)
{
 long multiBytes = WideCharToMultiByte(CP_ACP,0,str._pData,-1,NULL,0,NULL,NULL);//獲得將寬字節轉換成多自己時,所需要的字節個數,注意藍色部分
 char *lpMultiBytes = new char[multiBytes+10];//分配多字節時所需要的內存
 memset(lpMultiBytes,0,multiBytes+10);

 WideCharToMultiByte(CP_ACP,0,str._pData,-1,lpMultiBytes,multiBytes+10,NULL,NULL);//調用win32api函數將寬字節的表示轉換成為多字節的表示,注意藍色部分

 os<<lpMultiBytes;

 return os;//注意返回值
}

posted @ 2011-08-10 13:43 呆人 閱讀(542) | 評論 (0)編輯 收藏

僅列出標題
共6頁: 1 2 3 4 5 6 
<2025年12月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

導航

統計

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 在线观看欧美激情| 欧美丰满少妇xxxbbb| 欧美黄色一区| 亚洲免费小视频| 欧美一区二区啪啪| 亚洲高清影视| 9久草视频在线视频精品| 国产精品一区二区三区免费观看| 欧美一级专区| 美女图片一区二区| 亚洲一区自拍| 久久久久高清| 在线亚洲欧美| 久久精品导航| 亚洲最新在线视频| 欧美一区二区在线免费播放| 亚洲国产欧美日韩另类综合| 99精品视频网| 黄色精品一二区| 亚洲久久一区二区| 国产一二精品视频| 亚洲美女视频| 国产亚洲在线| 亚洲美女在线看| 韩日欧美一区二区| 夜夜精品视频| 在线免费观看视频一区| 99re66热这里只有精品3直播 | 男人的天堂成人在线| 欧美精品日韩精品| 久久亚洲二区| 国产精品av久久久久久麻豆网| 久久亚洲一区二区| 国产精品国产三级国产aⅴ无密码| 美日韩免费视频| 国产精品一级| 亚洲精品社区| 亚洲国产视频直播| 久久成人免费网| 亚洲欧美日本国产专区一区| 男女精品视频| 欧美成年人在线观看| 国产欧美一区二区精品秋霞影院 | 亚洲欧美三级伦理| 欧美激情按摩在线| 狂野欧美一区| 国产精品美女久久久| 亚洲日本久久| 亚洲黄一区二区三区| 久久激情五月婷婷| 久久久久九九九九| 国产伦精品一区二区三区高清版| 亚洲精品欧美一区二区三区| 亚洲观看高清完整版在线观看| 亚洲欧美一区二区激情| 亚洲欧美激情一区| 国产精品不卡在线| 一本色道久久综合亚洲精品小说| 亚洲精品免费看| 免费亚洲电影在线| 亚洲国产精品va| 亚洲激情网站免费观看| 久久亚洲免费| 亚洲国产成人久久综合| 亚洲国产一区二区三区a毛片| 久久久久久久尹人综合网亚洲 | 一本大道久久精品懂色aⅴ | 一本色道**综合亚洲精品蜜桃冫 | 亚洲欧洲美洲综合色网| 免费亚洲一区| 91久久黄色| 国产精品99久久不卡二区 | 欧美一区二区| 久久一二三国产| 亚洲第一精品夜夜躁人人躁| 欧美aⅴ一区二区三区视频| 最新日韩中文字幕| 亚洲欧美大片| 激情成人综合网| 免费欧美视频| 亚洲视频导航| 久久久久欧美| 亚洲精品美女91| 欧美日韩伊人| 久久福利电影| 亚洲日韩成人| 欧美一区二区三区在线视频| 激情婷婷久久| 欧美三级乱人伦电影| 欧美一区二区三区在线观看| 欧美多人爱爱视频网站| 制服丝袜亚洲播放| 国产自产在线视频一区| 欧美精品七区| 亚洲欧美日韩精品久久| 亚洲风情亚aⅴ在线发布| 亚洲一区二区三区四区中文 | 欧美伦理在线观看| 午夜亚洲精品| 亚洲人成久久| 久久久久久久久久久久久女国产乱 | 亚洲大胆在线| 亚洲一区二区三区午夜| 在线观看一区| 国产精品伦一区| 欧美91大片| 久久精品国产成人| 9久re热视频在线精品| 免费观看成人网| 亚洲欧美自拍偷拍| 日韩视频免费观看| 影音先锋久久精品| 国产女精品视频网站免费 | 欧美在线看片| 一本色道久久综合狠狠躁的推荐| 免费成人小视频| 欧美一级一区| 一区二区三区日韩| 亚洲国内自拍| 国内精品久久久| 国产精品午夜国产小视频| 欧美精品免费视频| 女女同性女同一区二区三区91| 小黄鸭视频精品导航| 中文国产成人精品| 91久久精品国产91性色tv| 玖玖精品视频| 久久久久在线| 久久黄色影院| 欧美自拍偷拍| 欧美一区二区三区视频| 亚洲女女女同性video| 日韩一区二区久久| 亚洲精品视频在线| 亚洲精品国产精品久久清纯直播| 一区二区亚洲精品国产| 激情婷婷欧美| 激情六月婷婷综合| 黄色成人av网| 精品二区久久| 伊人久久综合97精品| 在线成人免费观看| 亚洲高清在线观看一区| 亚洲国产老妈| 亚洲精品国产精品国自产在线| 在线免费一区三区| 最新国产拍偷乱拍精品| 亚洲精品国产精品乱码不99| 亚洲激情视频在线观看| 亚洲人成网站精品片在线观看| 在线视频国产日韩| 亚洲精品久久久久久下一站| 亚洲伦理自拍| 亚洲欧美另类久久久精品2019| 午夜精品在线看| 欧美一区三区三区高中清蜜桃| 欧美一区二区三区视频免费| 久久久久久久久伊人| 久久中文字幕导航| 亚洲国产精品一区制服丝袜| 日韩香蕉视频| 欧美一区二区三区四区视频| 久久精品电影| 欧美精品v日韩精品v国产精品 | 麻豆精品精华液| 欧美国产精品中文字幕| 国产精品www.| 国产视频自拍一区| 91久久极品少妇xxxxⅹ软件| 亚洲午夜精品一区二区| 久久xxxx精品视频| 欧美激情一区二区| 在线亚洲激情| 裸体一区二区三区| 欧美视频在线一区| 一区二区三区在线视频免费观看| 亚洲精品在线视频观看| 欧美在线观看一区二区三区| 麻豆精品视频在线观看| 一本色道久久综合狠狠躁篇的优点| 亚洲欧美成人网| 欧美大片专区| 国产一区二区精品久久99| 99国产精品自拍| 久久综合成人精品亚洲另类欧美| 亚洲国产精品高清久久久| 午夜精品久久久久久久蜜桃app | 国产精品成人一区二区| 精品动漫3d一区二区三区免费版 | 亚洲黄色有码视频| 欧美在线免费视频| 亚洲毛片一区二区| 久久综合九色综合欧美就去吻| 国产精品高精视频免费|