文件和流
1.fstream库:
ofstream 该数据类型表示输出文件流,用于创建文件并向文件写入信息。
ifstream 该数据类型表示输入文件流,用于从文件读取信息。
fstream 该数据类型通常表示文件流,且同时具有 ofstream 和 ifstream 两种功能,这意味着它可以创建文件,向文件写入信息,从文件读取信息。
2.操作:
a.打开文件
void open(const char *filename, ios::openmode mode);
ios::app 追加模式。所有写入都追加到文件末尾。
ios::ate 文件打开后定位到文件末尾。
ios::in 打开文件用于读取。
ios::out 打开文件用于写入。
ios::trunc 如果该文件已经存在,其内容将在打开文件之前被截断,即把文件长度设为 0。
b.关闭文件
void close();
c.写入文件:<<
outfile << data << endl;// 向文件写入用户输入的数据
d.读取文件: >>
infile >> data; // 从文件读取数据,
异常处理
1.关键字:
throw: 当问题出现时,程序会抛出一个异常。这是通过使用 throw 关键字来完成的。
catch: 在您想要处理问题的地方,通过异常处理程序捕获异常。catch 关键字用于捕获异常。
try: try 块中的代码标识将被激活的特定异常。它后面通常跟着一个或多个 catch 块。
2.抛出异常
double division(int a, int b)
{
if( b == 0 )
{
throw "Division by zero condition!";//c除数为0时,抛出异常
}
return (a/b);
}
3.捕获异常
try
{
// 保护代码
}catch( ExceptionName e )
{
// 处理 ExceptionName 异常的代码
}
动态内存
1.分类
栈:在函数内部声明的所有变量都将占用栈内存。
堆:这是程序中未使用的内存,在程序运行时可用于动态分配内存。
2.new和delete
new:可以为任意的数据类型动态分配内存
delete:释放内存
double* pvalue = NULL; // 初始化为 null 的指针
pvalue = new double; // 为变量请求内存
*pvalue = 29494.99; // 在分配的地址存储值
delete pvalue; // 释放内存
3.数组的动态分配
int *array=new int [m];// 动态分配,数组长度为 m
delete [] array;//释放内存
模板
1.定义:
模板是泛型编程的基础,泛型编程即以一种独立于任何特定类型的方式编写代码。
模板是创建泛型类或函数的蓝图或公式
2.函数模板
template <typename T>//template声明开始进行反省编程,typename 用于声明泛型编程 T是一种类型,可以被参数化
inline T const& Max (T const& a, T const& b)
{
return a < b ? b:a;
}
3.类模板
template <class type> class class-name {
}
template <class T>
class Stack {
private:
vector<T> elems; // 元素
public:
void push(T const&); // 入栈
void pop(); // 出栈
T top() const; // 返回栈顶元素
bool empty() const{ // 如果为空则返真
return elems.empty();
}
};
预处理器
1.定义:
一些指令,指示编译器在实际编译之前所需完成的预处理
2.#define预处理
创建符号常量,符号常量成为宏
#include <iostream>
using namespace std;
#define PI 3.14159//常量3.14159
3.参数宏
#include <iostream>
using namespace std;
#define MIN(a,b) (a<b ? a : b)//MIN为带参数的宏
4.#和##运算符
#会将内容转换为用引号引起来的字符串
#define MKSTR( x ) #x
int main ()
{
cout << MKSTR(HELLO C++) << endl;//输出结果为 HELLO C++,预处理把HELLO C++转换为“HELLO C++”
return 0;
}
##连接两个令牌
#define CONCAT( x, y ) x ## y//x,y为令牌,用##连接