c++:C++标准库学习iostream

2024-06-22 02:36
文章标签 c++ 学习 标准 iostream

本文主要是介绍c++:C++标准库学习iostream,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基础介绍

  • C程序可以通过__cplusplus符号是否预定义来判断当前是gcc还是g++编译
    __cplusplus的值是long int类型的,值表示当前编译程序的C++编译器的版本号。
 cout << "__cpulspuls :" << __cplusplus << endl;
  • C++文件名的常用后缀:源文件(.cpp .cxx .cc .c .c++),头文件(.hpp .hxx .h)

  • C++更建议的头文件包含形式不是<stdio.h>这样,而是这样
    要点:C++的标准库的头文件是没有后缀名的

  • C++标准库介绍
    (1)C标准库即为C++标准库的一部分,完全继承并以C++方式重写,位于std命名空间中
    (2)C++面向对象库,如string、iostream等,位于std命名空间中
    (3)C++ STL标准模板库,如vector、map等,位于std命名空间中

iostream的cout使用

基本使用
(1)cout即标准输出,对应stdout
(2)cout定义在std命名空间中,要按三种使用方法来用
(3)结合<<符号(流操作符)进行输出,可多节连接
(4)cout涉及的头文件有 <bits/ios_base.h>
(5)cout本质上是ostream(iostream的派生类)的一个对象
(6)流操作符<<本质上是左移运算符在iostream中的运算符重载

  int val = 19;cout << "__cpulspuls :" << __cplusplus << endl;cout << "__cpulspuls :0x" << hex << __cplusplus << "--" << val << "--" << dec<< val << endl;double dl = 1.23456789;cout << "dl :" << dl << endl;cout << "dl :" << setprecision(3) << dl << endl;
  int i = 110;cout << i << endl;cout << dec << i << endl;cout << oct << i << endl;cout << hex << i << endl;cout << setiosflags(ios::uppercase);//使输出的字母(如十六进制中的 A-F)大写cout << hex << i << endl;cout << setbase(8) << i << endl;//表示接下来输出的数字将以八进制格式输出
	double i = 1314.1415926;cout << i << endl;cout << setprecision(3) << i << endl;//设置输出的精度为3位有效数字cout << setprecision(9) << i << endl;//设置输出的精度为9位有效数字cout << setiosflags(ios::fixed);//设置流的格式为固定小数点表示法cout << i << endl;cout << fixed << setprecision(3) << i << endl;//设置小数点后的位数为3cout << setprecision(9) << fixed <<  i << endl;//设置输出的精度为9位有效数字
  double i = 1314.1415926;double j = 42;double k = -42.0;// 原始输出cout << i << endl;cout << j << endl;cout << k << endl;cout << "使用 setprecision(3) 和 showpoint" << endl;//setprecision(3) 在 defaultfloat 模式下显示3位有效数字,showpoint 强制显示小数点cout << setprecision(3) << showpoint;cout << i << endl;cout << j << endl;cout << k << endl;cout << "使用 setprecision(9), fixed 和 showpoint" << endl;//设置为固定小数点模式并显示9位小数,showpoint 强制显示小数点cout << setprecision(9) << fixed << showpoint;cout << i << endl;cout << j << endl;cout << k << endl;cout << "使用 showpos, showpoint 和 fixed" << endl;//showpos 强制显示正号fixed 和 showpoint 使得数字以固定小数点模式显示,setprecision(3) 显示3位小数cout << showpos << fixed << showpoint;cout << setprecision(3);cout << i << endl;cout << j << endl;cout << k << endl;
  int a = 42;double b = 3.14159;string str = "Hello";// 默认显示cout << "Default display:" << endl;cout << a << endl;cout << b << endl;cout << str << endl;// 设置宽度为10, 右对齐 (默认)cout << "\nRight aligned with width 10:" << endl;cout << setw(10) << a << endl;cout << setw(10) << b << endl;cout << setw(10) << str << endl;// 设置宽度为10, 左对齐cout << "\nLeft aligned with width 10:" << endl;cout << left << setw(10) << a << endl;cout << left << setw(10) << b << endl;cout << left << setw(10) << str << endl;// 设置宽度为10, 内部对齐cout << "\nInternal aligned with width 10:" << endl;cout << internal << setw(10) << a << endl;cout << internal << setw(10) << b << endl;cout << internal << setw(10) << str << endl;// 设置宽度为15, 内部对齐cout << "\nInternal aligned with width 15:" << endl;cout << internal << setw(15) << a << endl;cout << internal << setw(15) << b << endl;cout << internal << setw(15) << str << endl;// 设置宽度为10, 填充字符为 '*'cout << "\nRight aligned with width 10 and fill '*':" << endl;cout << setfill('*') << right << setw(10) << a << endl;cout << setfill('-') << right << setw(10) << b << endl;cout << setfill('#') << right << setw(10) << str << endl;

iostream的cin使用

输入数字

  int a, b;cout << "Enter two numbers: ";cin >> a >> b;cout << "The numbers you entered are " << a << " and " << b << endl;cout << "a + b =  " << a + b << endl;

十六进制输入数字

  int a, b;cout << "Enter two numbers: ";cin >> hex >> a >> b;cout << "The numbers you entered are " << a << " and " << b << endl;cout << "a + b =  " << a + b << endl;return 0;

输入字符串

   string name;cout << "Enter your full name: ";getline(cin, name);cout << "Your full name is " << name << endl;return 0;

输入错误检查

   int number;cout << "Enter a number: ";cin >> number;if (cin.fail()) {cout << "Invalid input." << endl;cin.clear(); // 清除错误状态cin.ignore(1000, '\n'); // 忽略错误输入} else {cout << "You entered " << number << endl;}

总结

理解学习C++的三个层次
理解iostream的cout 、cin使用方法

学习记录,侵权联系删除。
来源:朱老师物联网大课堂

这篇关于c++:C++标准库学习iostream的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1083042

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

C++读写word文档(.docx)DuckX库的使用详解

《C++读写word文档(.docx)DuckX库的使用详解》DuckX是C++库,用于创建/编辑.docx文件,支持读取文档、添加段落/片段、编辑表格,解决中文乱码需更改编码方案,进阶功能含文本替换... 目录一、基本用法1. 读取文档3. 添加段落4. 添加片段3. 编辑表格二、进阶用法1. 文本替换2

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基