我想从这段代码中删除使用命名空间std,但我不确定所有需要以std ::为前缀的内容

时间:2011-04-10 02:05:30

标签: c++ namespaces

我想删除使用命名空间std,但我不知道所有需要加上前缀。

 #include <iostream>
 #include "PlayingCard.h"

 using namespace std;

 PlayingCard makeValidCard(int value, int suit);

 int main()
{
// Create a playing card
PlayingCard card1;


// Test the default constructor and GetCardCode
cout << "Testing default constructor. Expect card code to be 00\n card code is :";
cout << card1.getCardCode() << endl << endl;


// Test the setter and getter
cout << "Seting card to 'AH' using SetValue and SetSuit" << endl;
card1.setCard('A', 'H');
cout << "GetValue returns :" << card1.getValue() << endl;
cout << "GetSuit returns :" << card1.getSuit() << endl << endl;


// Test overloaded constructor
PlayingCard tenOfSpades('T', 'S');
cout << "Testing overloaded constructor. Expect card code to be TS\n card code is :";
cout << tenOfSpades.getCardCode() << endl << endl;


// Test IsValid with valid cards
cout << "Testing valid card codes.\n"
     << "Expect isValid to return true for all (except perhaps Jokers.)"
      << endl;
// Create and test valid cards
int validCards = 0;     // cards that return true for IsValid
int invalidCards = 0;   // cards that return false for IsValid

// Create and test four suits plus the jokers
for(int suit = 1; suit <= 5; suit++)
{
    // Create and test ace, 2 - 9, Jack, Queen, and King
    for(int value = 1; value <= 13; value++)
    {
        PlayingCard aCard = makeValidCard(value, suit);
       cout << "Card Code: " << aCard.getCardCode() << " IsValid :";
       if (aCard.isValid())
       {
           validCards++;
            cout << "true" << endl;
       }
        else
        {
            invalidCards++;
            cout << "false" << endl;
        }
    // suit 5 is just for creating the two Jokers
    if (suit == 5 && value >= 2)
        break;
    }
}
cout << "IsValid returned false for " << invalidCards << " card codes" << endl;
cout << "IsValid returned true for " << validCards << " card codes" << endl;
cout << endl;


// Test IsValid with invalid cards
// Create and test invalid cards
cout << "Testing invalid card codes; isValid should return false for all." << endl;
validCards = 0;
invalidCards = 0;
   // Loop through all possible ASCII character codes for card codes
   for(int suit = 0; suit <= 255; suit++)
   for(int value = 0; value <= 255; value++)
   {
        // Only check card codes that are not valid
        PlayingCard aCard = makeValidCard(value, suit);
        if (aCard.getCardCode() == "00")
        {
            if (aCard.isValid())
            {
               cout << "value :" << value << " suit :" <<suit << " IsValid :";
               cout << "true" << endl;
               validCards++;
            }
            else
            {
                invalidCards++;
            }
        }
    }
    cout << "IsValid returned false for " << invalidCards << " card codes" << endl;
    cout << "IsValid returned true for " << validCards << " card codes" << endl;

return 0;
}


/******************************************************/
/* Test Functions                                     */
/******************************************************/

PlayingCard makeValidCard(int iValue, int iSuit)
{
char value = '0';
char suit = '0';


    switch (iValue)
    {
        case 1:
           value = 'A';
           break;
        case 10:
            value = 'T';
            break;
        case 11:
           value = 'J';
           break;
        case 12:
           value = 'Q';
           break;
        case 13:
           value = 'K';
           break;
        default:
            if ((iValue >= 2) && (iValue <= 9))
                value = '0' + iValue;
            break;
    }


   switch (iSuit)
    {
        case 1:
           suit = 'D';
           break;
        case 2:
           suit = 'S';
           break;
        case 3:
           suit = 'C';
           break;
        case 4:
           suit = 'H';
           break;
        // Special case for the Joker
        case 5:
            if(iValue == 1)
            {
                value = 'Z';
                suit = 'B';
            }
            else if(iValue == 2)
            {
                value = 'Z';
                suit = 'R';
            }
            else
            {
                value = '0';
                suit = '0';
            }
            break;
    }

    PlayingCard testCard(value, suit);
    return testCard;
}

4 个答案:

答案 0 :(得分:9)

只需删除它,然后为编译器错误的所有内容添加前缀。 :P


快速浏览一下,肯定需要加上coutendl的前缀。
另外,请 不要 使用endl来插入换行符,而是使用普通的旧版'\n'endl不仅会插入换行符,还会刷新流,如果频繁使用(这样做),这可能会导致性能损失。只有在除了插入换行符之外还需要刷新流时才使用它。

答案 1 :(得分:2)

我没有用细齿梳查看代码,但可能只是coutendl。如果编译器给出了有关未定义符号的错误,请尝试将std添加到该符号。顺便说一句,您还可以将using namespace std;更改为using std::cout;using std::endl;这样可以防止全局命名空间过度污染,但避免将限定符添加到代码中的每个实例。

答案 2 :(得分:1)

我看到的只有coutendl,其他一切都是关键字或用户定义。

答案 3 :(得分:1)

考虑到您使用cout的频率,您可能希望将using namespace std;替换为using std::cout;

正如Xeo所说,您应该使用endl搜索并替换'\n'

看起来这可能涵盖了你的所有基础。通过在显示时添加std::来修复任何其他编译器错误。