table of contents
        
      
      
    - Tumbleweed 2024.07.05-1.3
 - Leap-16.0
 - Leap-15.6
 
| std::basic_filebuf::setbuf(3) | C++ Standard Libary | std::basic_filebuf::setbuf(3) | 
NAME¶
std::basic_filebuf::setbuf - std::basic_filebuf::setbuf
Synopsis¶
 protected:
  
   virtual std::basic_streambuf<CharT, Traits>* setbuf( char_type* s,
    std::streamsize
  
   n )
  
   If s is a null pointer and n is zero, the filebuf becomes unbuffered for
    output,
  
   meaning pbase() and pptr() are null and any output is immediately sent to
    file.
  
   Otherwise, a call to setbuf() replaces the internal buffer (the controlled
    character
  
   sequence) with the user-supplied character array whose first element is
    pointed to
  
   by s and allows this std::basic_filebuf object to use up to n bytes in that
    array
  
   for buffering.
  
   This function is protected virtual, it may only be called through pubsetbuf()
    or
  
   from member functions of a user-defined class derived from
    std::basic_filebuf.
Parameters¶
 s - pointer to the first CharT in the user-provided buffer or
    null
  
   n - the number of CharT elements in the user-provided buffer or zero
Return value¶
this
Notes¶
 The conditions when this function may be used and the way in
    which the provided
  
   buffer is used is implementation-defined.
  
   * GCC 4.6 libstdc++
  
   setbuf() may only be called when the std::basic_filebuf is not associated
    with a
  
   file (has no effect otherwise). With a user-provided buffer, reading from
    file reads
  
   n-1 bytes at a time.
  
   * Clang++3.0 libc++
  
   setbuf() may be called after opening the file, but before any I/O (may crash
  
   otherwise). With a user-provided buffer, reading from file reads largest
    multiples
  
   of 4096 that fit in the buffer.
  
   * Visual Studio 2010
  
   setbuf() may be called at any time, even after some I/O took place. Current
    contents
  
   of the buffer, if any, are lost.
  
   The standard does not define any behavior for this function except that
    setbuf(0, 0)
  
   called before any I/O has taken place is required to set unbuffered
  output.
Example¶
 Provides a 10k buffer for reading. On linux, the strace utility
    may be used to
  
   observe the actual number of bytes read.
// Run this code
  
   #include <fstream>
  
   #include <iostream>
  
   #include <string>
  
   int main()
  
   {
  
   int cnt = 0;
  
   std::ifstream file;
  
   char buf[10241];
  
   file.rdbuf()->pubsetbuf(buf, sizeof buf);
  
   file.open("/usr/share/dict/words");
  
   for (std::string line; getline(file, line);)
  
   ++cnt;
  
   std::cout << cnt << '\n';
  
   }
Possible output:¶
356010
  
   Defect reports
  
   The following behavior-changing defect reports were applied retroactively to
  
   previously published C++ standards.
  
   DR Applied to Behavior as published Correct behavior
  
   LWG 173 C++98 the type of n was misspecified as corrected to std::streamsize
  
   int
See also¶
 pubsetbuf invokes setbuf()
  
   (public member function of std::basic_streambuf<CharT,Traits>)
  
   setvbuf sets the buffer and its size for a file stream
  
   (function)
| 2024.06.10 | http://cppreference.com |