 
- C++ Library - Home
- C++ Library - <fstream>
- C++ Library - <iomanip>
- C++ Library - <ios>
- C++ Library - <iosfwd>
- C++ Library - <iostream>
- C++ Library - <istream>
- C++ Library - <ostream>
- C++ Library - <sstream>
- C++ Library - <streambuf>
- C++ Library - <atomic>
- C++ Library - <complex>
- C++ Library - <exception>
- C++ Library - <functional>
- C++ Library - <limits>
- C++ Library - <locale>
- C++ Library - <memory>
- C++ Library - <new>
- C++ Library - <numeric>
- C++ Library - <regex>
- C++ Library - <stdexcept>
- C++ Library - <string>
- C++ Library - <thread>
- C++ Library - <tuple>
- C++ Library - <typeinfo>
- C++ Library - <utility>
- C++ Library - <valarray>
- The C++ STL Library
- C++ Library - <array>
- C++ Library - <bitset>
- C++ Library - <deque>
- C++ Library - <forward_list>
- C++ Library - <list>
- C++ Library - <map>
- C++ Library - <multimap>
- C++ Library - <queue>
- C++ Library - <priority_queue>
- C++ Library - <set>
- C++ Library - <stack>
- C++ Library - <unordered_map>
- C++ Library - <unordered_set>
- C++ Library - <vector>
- C++ Library - <algorithm>
- C++ Library - <iterator>
- The C++ Advanced Library
- C++ Library - <any>
- C++ Library - <barrier>
- C++ Library - <bit>
- C++ Library - <chrono>
- C++ Library - <cinttypes>
- C++ Library - <clocale>
- C++ Library - <condition_variable>
- C++ Library - <coroutine>
- C++ Library - <cstdlib>
- C++ Library - <cstring>
- C++ Library - <cuchar>
- C++ Library - <charconv>
- C++ Library - <cfenv>
- C++ Library - <cmath>
- C++ Library - <ccomplex>
- C++ Library - <expected>
- C++ Library - <format>
- C++ Library - <future>
- C++ Library - <flat_set>
- C++ Library - <flat_map>
- C++ Library - <filesystem>
- C++ Library - <generator>
- C++ Library - <initializer_list>
- C++ Library - <latch>
- C++ Library - <memory_resource>
- C++ Library - <mutex>
- C++ Library - <mdspan>
- C++ Library - <optional>
- C++ Library - <print>
- C++ Library - <ratio>
- C++ Library - <scoped_allocator>
- C++ Library - <semaphore>
- C++ Library - <source_location>
- C++ Library - <span>
- C++ Library - <spanstream>
- C++ Library - <stacktrace>
- C++ Library - <stop_token>
- C++ Library - <syncstream>
- C++ Library - <system_error>
- C++ Library - <string_view>
- C++ Library - <stdatomic>
- C++ Library - <variant>
- C++ STL Library Cheat Sheet
- C++ STL - Cheat Sheet
- C++ Programming Resources
- C++ Programming Tutorial
- C++ Useful Resources
- C++ Discussion
C++ istream::readsome() function
The C++ std::istream::readsome() function is used to read the specific number of characters from a input stream into a buffer, without blocking. It reads up to the specified limit or the number of available characters, whichever is smaller.
Unlike read(), which waits to fill the buffer completely, readsome() returns immediately with the available data.
Syntax
Following is the syntax for std::istream::readsome() function.
streamsize readsome (char* s, streamsize n);
Parameters
- s − It indicates the pointer to an array where the extracted characters are stored.
- n − It indicates the maximum number of characters to extract.
Return Value
This function returns the number of characters stored.
Exceptions
If an exception is thrown, the object is in a valid state.
Data races
Modifies the elements in the array pointed by s and the stream object.
Example
Let's look at the following example, where we are going to consider the bsic usage of readsome() function.
#include <iostream>
#include <sstream>
int main()
{
    std::istringstream x("Tp, TutorialsPoint");
    char a[5];
    x.readsome(a, 4);
    a[5] = '\0';
    std::cout << "Result : " << a << std::endl;
    return 0;
}
Output
Output of the above code is as follows −
Result : Tp,
Example
Consider the following example, where we are going to read partial data from std::istringstream.
#include <iostream>
#include <sstream>
int main()
{
    std::istringstream a("Hello Namaste");
    char b[6];
    a.readsome(b, sizeof(b) - 1);
    b[a.gcount()] = '\0';
    std::cout << "First read: " << b << std::endl;
    a.readsome(b, sizeof(b) - 1);
    b[a.gcount()] = '\0';
    std::cout << "Second read: " << b << std::endl;
    return 0;
}
Output
Following is the output of the above code −
First read: Hello Second read: Nama