Избегайте макросов, когда можете!Они скрывают код, усложняют отладку, не учитывают область видимости и т. Д.
Вы можете использовать простую функцию, предоставленную 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;
}