Есть ли хороший способ объединить потоковые манипуляторы? - PullRequest
7 голосов
/ 01 июля 2010

Если бы я хотел вывести шестнадцатеричное число фиксированной ширины с 4 цифрами в потоке, мне нужно сделать что-то вроде этого:

cout << "0x" << hex << setw(4) << setfill('0') << 0xABC;

, который кажется немного длинным. Использование макроса помогает:

#define HEX(n) "0x" << hex << setw(n) << setfill('0')

cout << HEX(4) << 0xABC;

Есть ли лучший способ комбинировать манипуляторы?

Ответы [ 2 ]

18 голосов
/ 01 июля 2010

Избегайте макросов, когда можете!Они скрывают код, усложняют отладку, не учитывают область видимости и т. Д.

Вы можете использовать простую функцию, предоставленную KenE.Если вы хотите, чтобы все было модно и гибко, вы можете написать свой собственный манипулятор:

#include <iostream>
#include <iomanip>
using namespace std;

ostream& hex4(ostream& out)
{
    return out << "0x" << hex << setw(4) << setfill('0');
}

int main()
{
    cout << hex4 << 123 << endl;
}

Это делает его немного более общим.Причина, по которой вышеприведенная функция может быть использована, заключается в том, что operator<< уже перегружен следующим образом: ostream& operator<<(ostream&, ostream& (*funtion_ptr)(ostream&)).endl и некоторые другие манипуляторы также реализованы следующим образом.

Если вы хотите разрешить указание количества цифр во время выполнения, мы можем использовать класс:

#include <iostream>
#include <iomanip>
using namespace std;

struct formatted_hex
{
    unsigned int n;
    explicit formatted_hex(unsigned int in): n(in) {}
};

ostream& operator<<(ostream& out, const formatted_hex& fh)
{
    return out << "0x" << hex << setw(fh.n) << setfill('0');
}

int main()
{
    cout << formatted_hex(4) << 123 << endl;
}

Еслиразмер может быть определен во время компиляции, однако, он может просто использовать шаблон функции [спасибо Джону Пурди за это предложение]:

template <unsigned int N>
ostream& formatted_hex(ostream& out)
{
    return out << "0x" << hex << setw(N) << setfill('0');
}

int main()
{
    cout << formatted_hex<4> << 123 << endl;
}
4 голосов
/ 01 июля 2010

Почему макрос - вы не можете использовать функцию вместо этого?

void write4dhex(ostream& strm, int n)
{
    strm << "0x" << hex << setw(4) << setfill('0') << n;
}
...