GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages
std::ios_base::xalloc(3) C++ Standard Libary std::ios_base::xalloc(3)

std::ios_base::xalloc - std::ios_base::xalloc


static int xalloc();


Returns a unique (program-wide) index value that can be used to access one long and
one void* elements in the private storage of std::ios_base by calling iword() and
pword(). The call to xalloc does not allocate memory.


This function is thread-safe; concurrent access by multiple threads does not result
in a data race.
(since C++14)


Effectively increments a private static data member of std::ios_base, as if by
executing return index++;, if index is the name of that static member
(which may be std::atomic to support concurrent access by multiple threads, or
otherwise synchronized)
(since C++14)


(none)


Unique integer for use as pword/iword index.


Uses base class pword storage for runtime type identification of derived stream
objects.

// Run this code


#include <iostream>


template<class charT, class traits = std::char_traits<charT> >
class mystream : public std::basic_ostream<charT, traits>
{
public:
static const int xindex;
mystream(std::basic_ostream<charT, traits>& ostr) :
std::basic_ostream<charT, traits>(ostr.rdbuf())
{
this->pword(xindex) = this;
}


void myfn()
{
*this << "[special handling for mystream]";
}
};


// each specialization of mystream obtains a unique index from xalloc()
template<class charT, class traits>
const int mystream<charT, traits>::xindex = std::ios_base::xalloc();


// This I/O manipulator will be able to recognize ostreams that are mystreams
// by looking up the pointer stored in pword
template<class charT, class traits>
std::basic_ostream<charT,traits>& mymanip(std::basic_ostream<charT,traits>& os)
{
if (os.pword(mystream<charT,traits>::xindex) == &os)
static_cast<mystream<charT,traits>&>(os).myfn();
return os;
}


int main()
{
std::cout << "cout, narrow-character test " << mymanip << '\n';


mystream<char> myout(std::cout);
myout << "myout, narrow-character test " << mymanip << '\n';


std::wcout << "wcout, wide-character test " << mymanip << '\n';


mystream<wchar_t> mywout(std::wcout);
mywout << "mywout, wide-character test " << mymanip << '\n';
}


cout, narrow-character test
myout, narrow-character test [special handling for mystream]
wcout, wide-character test
mywout, wide-character test [special handling for mystream]


resizes the private storage if necessary and access to the void* element at
pword the given index
(public member function)
resizes the private storage if necessary and access to the long element at the
iword given index
(public member function)

2022.07.31 http://cppreference.com

Search for    or go to Top of page |  Section 3 |  Main Index

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with ManDoc.