C++深入讲解namespace与string关键字的使用

来自:网络
时间:2022-05-21
阅读:
目录

namespace

首先声明:在C++中支持三种域局部域,名字空间,类域。

1.为什么使用namespace

在C++中可能会出现这样的情况:我们正在编写一个名为myj()函数的代码,但是另一个可用的库,它也具有相同的myj()函数。现在编译器无法知道代码中使用的myj()函数是哪个版本。

所以namespace就是用来克服这个困难,并被用作额外的信息来区分类似的函数、类、变量等等,它们在不同的库中具有相同的名称。使用名称空间,你可以定义定义名称的上下文。

本质上,名称空间定义了一个范围。

2.namespace的定义

  • 命名空间将全局作用域分成不同的部分
  • 不同命名空间中的标识符可以同名而不会发生冲突
  • 命名空间可以发生嵌套
  • 全局作用域也叫默认命名空间

举例说明:

//1.普通的命名空间
namespace myj
{
	int g _max = 10;
	int g_min = 0;
	int my_add(int a,int b){ return a+b;}
}
//2.名字空间域可分层嵌套,同样有分层屏蔽作用
namespace Primer
{
	double pi = 3.1415926535898;
	double my_add(double a,double b) {return a + b;}
	namespace Matrix
	{
		char my_max(char a,char b) { return a>b? a:b;}
	}
}
//3.同一个工程中允许存在多个相同名称的命名空间
//编译器最后会合成同一个命名空间中。
namespace myj
{
	float pi = 3.14;
	int my_sub(int a,int b)
	{
		my_min = a - b;
		return my_min;
	}
}

3.namespace的使用

  • 加名字空间及作用域限定符
  • 使用using将名字空间中成员引入
  • 使用using namespace名字空间名称引入
#include <stdio.h>
#include <iostream>
namespace First 
{
	int i = 0;
}
namespace Second
{
	int i = 1;
 
	namespace Internal //嵌套命名空间
	{
		struct P  //嵌套命名空间
		{
			int x;
			int y;
		};
	}
}
int main()
{
	using namespace First; //使用整个命名空间
	using Second::Internal::P;  //使用嵌套的命名空间
 
	printf("First::i = %d\n", i);
	printf("Second::i = %d\n", Second::i);  //使用命名空间中的变量
	p = { 2, 3 };
	printf("p.x = %d\n", p.x);
	printf("p.y = %d\n", p.y);
	system("pause");
	return 0;
}

4.使用using指示符

标准C++库中的所有组件都是在一个被称为std的名字空间中声明和定义的。在采用标准C++的平台上使用标准C++库中的组件,只要写一个using指示符:

using namespace std;

就可以直接使用标准C++库中的所有成员。

string

1.string的定义及初始化

定义string的方式跟基本数据类型相同,只需要在string后跟上变量名

string s;

初始化:

string str = "yyds";

2.访问string的内容

  • 通过下标访问,s[i]表示字符串s中下标位i的元素

如果要读入和输出整个字符串,则只能使用cin和cout

如果一定要用printf来输出string,可以用c_str()函数将string类型转换为字符数组进行输出。

printf("%s",str.c_str());
  • 通过迭代器访问

因为string不像其他STL容器那样需要参数,因此可以直接如下定义:

string::iterator it;

这样就得到了迭代器it,并且可以通过*it来访问string里的每一位

3.常用函数

1.operator+

连接两个字符串或者一个字符串和一个字符。

2.compare operator

两个string类型可以直接使用==、!=、<、<=、>、>=比较大小,比较规则是字典序。

3.length()/size()两者返回string的长度,即存放的字符数。

4.insert(pos,string)

在pos号位置插入字符串string

5.insert(it,it2,it3)

it为原字符串的欲插入位置,it2和it3为待插字符串的首位迭代器,用来表示串[it2,it3)将被插在it的位置上。

6.erase()

删除单个元素,str.erase(it)用于删除单个元素,it为需要删除的元素的迭代器。 删除一个区间内的所有元素。

7.clear()

用以清空string中的数据。

8.substr()

substr(pos,len)返回从pos号位开始、长度为len的字串。

9.string::npos

一个常数,其本身的值为-1,但由于是unsigned_int 类型,因此实际上也可以认为是unsigned_int类型的最大值4294967295。 string::npos用以作为find函数匹配时的返回值。

10.find()

str.find(str2),当str2是str的子串时,返回其在str中第一次出现的位置;如果str2不是str的子串,那么返回string::npos。 str.find(str2,pos),从str的pos号位开始匹配str2,返回值与上相同。

11.replace()

str.replace(pos,len,str2)把str从pos号位开始、长度为len的子串替换为str2 str.replace(it1,it2,str2)把str的迭代器[it1,it2)范围的字串替换为str2

12.assign()

str.assign(str.rbegin(),str.rend())可以实现字符串翻转。

返回顶部
顶部