string 类
#include <iostream>
#include <string>
using namespace std;
int main()
{
string s1,s2;
cin>>s1>>s2;
cout<<s1<<s2<<endl;
return 0
}
如果相对string对象中的每个字符做点儿 什么操作,目前最好的办法是使用C++11新提供的一种语句:范围for(range for)语句。这种语句遍历给定序列中的每个元素并对序列中的每个值执行某种操作,其语法形式是:
for (declaration :expression)
statement
#include <iostream>
#include <string>
using namespace std;
int main()
{
//string s1,s2;
//cin>>s1>>s2;
//cout<<s1<<s2<<endl;
string str( "some string");
for( auto c:str)
cout<<c<<endl;
return 0;
}
使用基于for语句处理每个字符是一个好的方式,要想访问string对象中的字符有两种方式:一种是使用下标,另外一种是使用迭代器;
#include <iostream>
#include <string>
using namespace std;
int main()
{
string s("some string");
if(!s.empty()) //确保确实有字符需要输出;
s[0] = toupper(s[0]); //将字符“some string”中第一个字符s改成大写;
cout<<s[0]<<endl<<s<<endl; //输出大写S,以及改完以后的字符串“Some string”;
return 0;
}
标准库类型vector
标准库类型vector表示对象的集合,其中所有的对象的结合都相同;
以vector 为例,提供额外的是vector内所存放对象的类型;
vector <int> ivec; //ivec 保存int类型的对象;
vector<Sales_item> Sales_vec;//保存Sale_item类型的对象;
vector<vector<string>> file;//该向量的元素vector对象;
vector初始化
可以用vector对象容纳的元素数量和所有元素的同意的初始值来初始化vector对象:
vector<int> ivec(10,-1)//10个int类型的元素,每个都被初始化为-1;
vector<string> svec(10,"hi !");//10个string类型的元素,每个都被初始化为"hi!";
vector<int> ivec(10);//10个元素,每个都被初始化为0;
vector<string> svec(10);//10个元素,每个都是空string对象;
vector<int> v1{10};//v1有一个元素,这个元素的值是10;
#include <iostream>
#include <vector>
#include <string>
using namespace std;
int main()
{
vector<int> ivec;
int i;
cout<< "请输入数字(输入-1退出)\n" ;
while(1)
{
cin>>i;
if(i == -1)
break;
ivec.push_back(i);
}
if(ivec.empty())
{
cout<< "this vector is empty "<<endl;
return -1;
}
else if (ivec.size() == 1)
{
cout<< "没有相邻的元素" <<endl;
return -2;
}
else
{
for( decltype(ivec.size()) i = 0;i != ivec.size()-1;++i)
cout<< "相邻两个整数的和:" <<ivec[i] + ivec[i+1]<<endl;
}
int x = 0;
int y = ivec.size()-1;
while(1)
{
if(x > y)
break;
cout<<ivec[x]+ivec[y]<<endl;
x++;
y--;
}
return 0;
}
迭代器(iterator)
迭代器类型
1)类似于指针,迭代器也提供了对对象的间接访问,和指针不一样的是,或缺迭代器不是使用取地址符,有迭代器的类型同时拥有返回迭代器的成员。
auto b = v.begin(),e = v.end(); //由编译器决定b和e的类型,b表示v的第一个元素,e表示v尾元素的下一位置
2)就想不知道string和vector的size_type成员,到底是什么类型一样,一般来说我们也不知道(其实也无需知道)迭代器的精确类型,而实际上那些拥有迭代器的标准库类型使用iterator和const_iterator来表示迭代器的类型:
vector<int> ::iterator it;//it 能读写vector<int>的元素;
string::iterator it2;//it2能读写string对象中的字符;
vector<int>::const_iterator it3;//it3只能读元素,不能写元素;
string::const_iterator it4;//it4只能读字符,不能写字符
结合解引用和成员访问操作
解引用迭代器获得迭代器所指的对象,如果该对象的类型恰好是类,就有可能希望进一步访问它的成员。例如,对一个由字符串组成的vector对象来说,要想检查元素是否为空,令it是该vector对象的迭代器,只需检查it所指字符串是否为空就可以,代码如下:
(*it).empty();//解引用it,然后调用结果对象的empty成员;
*it.empty();//错误:试图访问it的名为empty的成员,但it是个迭代器,没有empty成员;
范围for语句
如果想对string对象中的每个字符做点儿什么操作,目前最好的办法就是使用C++11新标准提供的一种语句:范围for语句。
举个稍微复杂点的例子,使用范围for语句和ispunct函数来统计string对象中标点符号的个数:
string s("Hello World!!!");
//punct_cnt的类型和s.size的返回类型一样;
decltype(s.size()) punct_cnt = 0;
for(auto c : s)
if(ispunct(c))
++punct_cnt;
cout<<punct_cnt<<" punctuation characters in "<<s<<endl;
输出结果为:3 punctuation characters in Hello World!!!
string 类
#include <iostream>
#include <string>
using namespace std;
int main()
{
string s1,s2;
cin>>s1>>s2;
cout<<s1<<s2<<endl;
return 0
}
如果相对string对象中的每个字符做点儿 什么操作,目前最好的办法是使用C++11新提供的一种语句:范围for(range for)语句。这种语句遍历给定序列中的每个元素并对序列中的每个值执行某种操作,其语法形式是:
for (declaration :expression)
statement
#include <iostream>
#include <string>
using namespace std;
int main()
{
//string s1,s2;
//cin>>s1>>s2;
//cout<<s1<<s2<<endl;
string str( "some string");
for( auto c:str)
cout<<c<<endl;
return 0;
}
使用基于for语句处理每个字符是一个好的方式,要想访问string对象中的字符有两种方式:一种是使用下标,另外一种是使用迭代器;
#include <iostream>
#include <string>
using namespace std;
int main()
{
string s("some string");
if(!s.empty()) //确保确实有字符需要输出;
s[0] = toupper(s[0]); //将字符“some string”中第一个字符s改成大写;
cout<<s[0]<<endl<<s<<endl; //输出大写S,以及改完以后的字符串“Some string”;
return 0;
}
标准库类型vector
标准库类型vector表示对象的集合,其中所有的对象的结合都相同;
以vector 为例,提供额外的是vector内所存放对象的类型;
vector <int> ivec; //ivec 保存int类型的对象;
vector<Sales_item> Sales_vec;//保存Sale_item类型的对象;
vector<vector<string>> file;//该向量的元素vector对象;
vector初始化
可以用vector对象容纳的元素数量和所有元素的同意的初始值来初始化vector对象:
vector<int> ivec(10,-1)//10个int类型的元素,每个都被初始化为-1;
vector<string> svec(10,"hi !");//10个string类型的元素,每个都被初始化为"hi!";
vector<int> ivec(10);//10个元素,每个都被初始化为0;
vector<string> svec(10);//10个元素,每个都是空string对象;
vector<int> v1{10};//v1有一个元素,这个元素的值是10;
#include <iostream>
#include <vector>
#include <string>
using namespace std;
int main()
{
vector<int> ivec;
int i;
cout<< "请输入数字(输入-1退出)\n" ;
while(1)
{
cin>>i;
if(i == -1)
break;
ivec.push_back(i);
}
if(ivec.empty())
{
cout<< "this vector is empty "<<endl;
return -1;
}
else if (ivec.size() == 1)
{
cout<< "没有相邻的元素" <<endl;
return -2;
}
else
{
for( decltype(ivec.size()) i = 0;i != ivec.size()-1;++i)
cout<< "相邻两个整数的和:" <<ivec[i] + ivec[i+1]<<endl;
}
int x = 0;
int y = ivec.size()-1;
while(1)
{
if(x > y)
break;
cout<<ivec[x]+ivec[y]<<endl;
x++;
y--;
}
return 0;
}
迭代器(iterator)
迭代器类型
1)类似于指针,迭代器也提供了对对象的间接访问,和指针不一样的是,或缺迭代器不是使用取地址符,有迭代器的类型同时拥有返回迭代器的成员。
auto b = v.begin(),e = v.end(); //由编译器决定b和e的类型,b表示v的第一个元素,e表示v尾元素的下一位置
2)就想不知道string和vector的size_type成员,到底是什么类型一样,一般来说我们也不知道(其实也无需知道)迭代器的精确类型,而实际上那些拥有迭代器的标准库类型使用iterator和const_iterator来表示迭代器的类型:
vector<int> ::iterator it;//it 能读写vector<int>的元素;
string::iterator it2;//it2能读写string对象中的字符;
vector<int>::const_iterator it3;//it3只能读元素,不能写元素;
string::const_iterator it4;//it4只能读字符,不能写字符
结合解引用和成员访问操作
解引用迭代器获得迭代器所指的对象,如果该对象的类型恰好是类,就有可能希望进一步访问它的成员。例如,对一个由字符串组成的vector对象来说,要想检查元素是否为空,令it是该vector对象的迭代器,只需检查it所指字符串是否为空就可以,代码如下:
(*it).empty();//解引用it,然后调用结果对象的empty成员;
*it.empty();//错误:试图访问it的名为empty的成员,但it是个迭代器,没有empty成员;
范围for语句
如果想对string对象中的每个字符做点儿什么操作,目前最好的办法就是使用C++11新标准提供的一种语句:范围for语句。
举个稍微复杂点的例子,使用范围for语句和ispunct函数来统计string对象中标点符号的个数:
string s("Hello World!!!");
//punct_cnt的类型和s.size的返回类型一样;
decltype(s.size()) punct_cnt = 0;
for(auto c : s)
if(ispunct(c))
++punct_cnt;
cout<<punct_cnt<<" punctuation characters in "<<s<<endl;
输出结果为:3 punctuation characters in Hello World!!!
- 我的Java开发学习之旅------>工具类:将播放器的进度值转换成相应的时间格式
在我的博客<我的Java开发学习之旅------>Java 格式化类(java.util.Formatter)基本用法,地址:http://blog.csdn.net/ouyang_pen ...
- java学习之路--String类的基本方法
String类常见的功能 获取 1.1 字符串中包含的字符数,也就是获取字符串的长度:int length(); 1.2 根据位置获取某个位置上的字符:char charAt(int index) 1 ...
- 我的Java开发学习之旅------>工具类:Java使用正则表达式分离出字符串中的中文和英文
今天看到一个工具类使用正则表达式将一大段字符串中的中文和英文都分离出来了,在此记录一下,读者可以收藏! import java.util.ArrayList; import java.util.Col ...
- 我的Java开发学习之旅------>工具类:Java获取字符串和文件进行MD5值
ps:这几天本人用百度云盘秒传了几部大片到云盘上,几个G的文件瞬秒竟然显示"上传成功"!这真让我目瞪口呆,要是这样的话,那得多快的网速,这绝对是不可能的,也许这仅是个假象.百度了一 ...
- 笔记-JavaWeb学习之旅5
CP30的演示 package cn.itcast.datasourcejdbc; import com.mchange.v2.c3p0.ComboPooledDataSource; import j ...
- 笔记-JavaWeb学习之旅19
Redis:redis是一款高性能的NOSQL系列的非关系型数据库 NOSQL: Not Only SQL ,意即"不仅仅是SQL",是一项全新的数据库理念,泛指非关系型数据库 r ...
- 笔记-JavaWeb学习之旅16
增强对象的功能 动态代理:在内存中形成代理类 实现步骤: 代理对象和真实对象实现相同的接口 代理对象 = Proxy.newProxyInstance(); 使用代理对象调用真实对象的方法 增强方法 ...
- 笔记-JavaWeb学习之旅10
Servlet server applet运行在服务器端的小程序,servlet就是一个接口,定义了Java类被浏览器访问到的规则(Java类重写这个接口,就可以被浏览器(tomcat)识别) Ser ...
- 笔记-JavaWeb学习之旅13
验证码案列 昨天晚上出现的500错误原因在于验证码没有获取到,获取验证码是应该获取的是共享域中的验证码,而我把获取值得键给写成了jsp中的键,而不是内存生成图片中,然后把图片上传到共享域中的键.这两个 ...
- 笔记-JavaWeb学习之旅12
会话技术 Cookie:客户端会话技术,将数据保存到客户端 package com.data.Cookie; import javax.servlet.ServletException; import ...
随机推荐
- python补全用法,windows环境和linux环境
一.windows中python tab具体如下: 1.python3环境装好后,初始环境是没有装readline模块的,先装它. pip install pyreadline 2.在在python的 ...
- Spring mvc 使用RestController 和 Controller
1.RestController相当于Controller和ResponseBody两个注解功能的结合体 2.只有Controller 返回的结果是 视图,一个页面 . 这个要自己写相关的 hello ...
- 01.html大致主体格式
<!DOCTYPE html> 不是HTML标签,就是文档声明标签 告诉浏览器使用哪种html版本来显示网页,其必须在文档中的最前面位置,要放在<html>标签之前, < ...
- Python练习--简单练习(一看就能写出来的代码)
两数之和 数字的阶乘 求圆的面积 (输入半径,求解圆的面积) 求区间内所有素数的和 求前N个数字的平方和
- Tars-Java网络编程源码分析
作者:vivo 互联网服务器团队- Jin Kai 本文从Java NIO网络编程的基础知识讲到了Tars框架使用NIO进行网络编程的源码分析. 一.Tars框架基本介绍 Tars是腾讯开源的支持多语 ...
- Solon2 接口开发: 强化 Gateway 模式
一般可以从这几方面对 Gateway 模式进行强化: 定制异常状态码 定制基类 将一些处理独立封装成类 接口只返回数据部份,异常状态用抛 强化之后,具体的网关即简单,又功能强大.同时会对团队开发形成一 ...
- 南昌航空大学-软件学院-22206104-段清如-JAVA第一次Blog作业
南昌航空大学-软件学院-22206104-段清如-JAVA第一次Blog作业 前言: 这个学期才开始接触java,到现在一个多月的时间,已经差不多可以写出一些基本的简单的程序了.对比上个学期学习的C语 ...
- 字符串常见API(charCodeAt\fromCharCode)
1.myStr.charCodeAt(num) 返回指定位置的字符的Unicode(是字符编码的一种模式)编码. 2.String.fromCharCode() String的意思就是不能用自己定义的 ...
- 保持唯一性,请停止使用【python3 内置hash() 函数】
问题: 如图,用hash() 筛重时竟然出现了重复. 如下图: hash字符串时,同一窗口的是一致的,不同窗口结果竟然不同. 原因: python的字符串hash算法并不是直接遍历字符串每个字符去计算 ...
- 通俗易懂的spring事务的传播机制讲解!
spring事务理解 前提两个都是事务的方法,并且两个方法会进行调用,调用方统一使用required 举例有两个方法: required 如果当前上下文存在事务,被调用方则加入该调用方的事务,没有的话 ...