自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Visual Studio 2012的C++原生單元測(cè)試

開(kāi)發(fā) 后端
我們今天將要談到的Visual Studio 2012的C++原生單元測(cè)試,將假設(shè)我們要使用Stl完成一項(xiàng)相對(duì)較通用的工作:為某個(gè)struct的vector,創(chuàng)建一個(gè)迭代器,用來(lái)返回struct的某個(gè)成員。

裝上Visual Studio 2012 RC,其中一個(gè)原因,是C++的原生單元測(cè)試,與以前.net下完全一致。這是很開(kāi)心的事情,下面簡(jiǎn)單的測(cè)試一下。

假設(shè)我們要使用Stl完成一項(xiàng)相對(duì)較通用的工作:為某個(gè)struct的vector,創(chuàng)建一個(gè)迭代器,用來(lái)返回struct的某個(gè)成員。這樣做的意義是什么呢?假設(shè)我們要對(duì)該結(jié)構(gòu)的vector,基于其某個(gè)字段排序,只需要為sort算法提供這種類型的迭代器就行了。這樣算法就真正無(wú)需考慮容器“是什么”的問(wèn)題。

當(dāng)然,可以寫一個(gè)比較函數(shù)來(lái)使用sort,但若是自己寫的更復(fù)雜的算法呢?我們直接將struct數(shù)組,偽造成某個(gè)字段的數(shù)組,這樣豈非是最省事的方法?

那么我們先創(chuàng)建一個(gè)本機(jī)單元測(cè)試項(xiàng)目。

先寫測(cè)試代碼,意思很簡(jiǎn)單,需要為某個(gè)vector創(chuàng)建迭代器器,檢查其返回值是否正確,檢查是否到了vector的最后位置: 

  1. TEST_METHOD(Iterator_Test)   
  2. {   
  3.     vector<Quote> q;   
  4.     Quote quote={1.00,2.00};   
  5.     q.push_back(quote);   
  6.     quote.open=2.00;   
  7.     q.push_back(quote);   
  8.     myit i(q.begin());   
  9.     Assert::AreEqual((double)1.00, (double)(*i),0.0001, L"message", LINE_INFO());   
  10.     ++i;   
  11.    Assert::AreEqual((double) 2.00, (double)(*i),0.0001, L"message", LINE_INFO());   
  12.    ++i;   
  13.   Assert::AreEqual<vector<Quote>::iterator>(q.end(),i,L"message", LINE_INFO());  

那么實(shí)現(xiàn)這項(xiàng)功能的方法也容易,代碼如下:

  1. struct Quote  
  2. {  
  3.         float open,close;  
  4. };  
  5.  
  6. class myit : public std::vector<Quote>::iterator {  
  7. public:  
  8.     inline myit(std::vector<Quote>::iterator const &c):std::vector<Quote>::iterator(c) {}  
  9.     float operator*() {  
  10.         const Quote &p = std::vector<Quote>::iterator::operator*();  
  11.         return p.open;  
  12.     }  
  13.     typedef float value_type;  
  14.     typedef float *pointer;  
  15.     typedef float &reference;  
  16. }; 

注意,這里沒(méi)有做任何抽象,僅僅是簡(jiǎn)單的實(shí)現(xiàn)一個(gè)針對(duì)vector<Quote>的迭代器,希望提供其作為算法的參數(shù)。若我們有興趣的話,可以簡(jiǎn)單的抽象一下,針對(duì)任何容器,快速提供一個(gè)迭代器,返回其某個(gè)成員。類似Iterator<vector<Quote>,float,匿名函數(shù)返回某個(gè)成員> iter;當(dāng)然,在抽象的過(guò)程中,現(xiàn)有的單元測(cè)試仍是有效的。這也是敏捷開(kāi)發(fā)中很常見(jiàn)的次序:先寫測(cè)試表達(dá)意圖,再以最簡(jiǎn)易的方法通過(guò)測(cè)試,必要的時(shí)候才考慮抽象。

我們打開(kāi)測(cè)試試圖:列出已有的測(cè)試,選擇希望運(yùn)行的,執(zhí)行。單元測(cè)試在Ide內(nèi)很好的集成工作,同時(shí)與Tfs德生成服務(wù)也能正常協(xié)同,類似Google Test之類的,從此可以好生休息了。

責(zé)任編輯:彭凡 來(lái)源: 博客園
相關(guān)推薦

2010-01-15 14:10:42

C++單元測(cè)試

2011-01-25 10:42:29

Visual Stud

2010-03-02 09:10:41

Visual Stud

2022-08-05 09:30:57

單元測(cè)試C++

2010-01-13 09:38:17

C++單元測(cè)試

2017-01-14 23:42:49

單元測(cè)試框架軟件測(cè)試

2014-04-24 13:43:37

CC++單元測(cè)試框架

2011-08-22 13:57:55

gtest

2009-09-01 16:35:16

C#單元測(cè)試

2010-01-12 16:12:47

C++單元測(cè)試

2023-07-26 08:58:45

Golang單元測(cè)試

2011-05-16 16:52:09

單元測(cè)試徹底測(cè)試

2017-01-14 23:26:17

單元測(cè)試JUnit測(cè)試

2017-01-16 12:12:29

單元測(cè)試JUnit

2011-06-14 15:56:42

單元測(cè)試

2020-08-18 08:10:02

單元測(cè)試Java

2009-09-01 16:10:28

C#單元測(cè)試

2009-09-01 16:45:00

C#單元測(cè)試工具

2012-08-27 14:01:18

VS 2012

2022-05-12 09:37:03

測(cè)試JUnit開(kāi)發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)