#include<string>
#include<stdlib.h>
#include<stdio.h>
#include<iostream>
using namespace std;
int main()
{
//string 初始化
string s1 = "ywb";
string s2(s1);
string s3 = s2;
string s4("yangwen");
string s5(10, 'c');
cout << s1 << " " << s2 << " " << s3 << " " << s4 << " " << s5 << endl;
//string 一部分函数的使用
string str("yangwenbin");
int length = str.length();//求取字符串长度
int length1 = str.size(); //求取字符串长度
cout << length << " " << length1 << endl;
for (int i = 0; i < length1; i++)
{
cout << str.at(i) << " " ; //返回字符串第i个位置的字符
}
cout << endl;
cout << *str.begin() << endl; //返回字符串的首字符
cout << *(str.end() - 1) << endl;; //返回字符串的尾元素
if (!str.empty()) //判断字符串是否为空
{
cout << "i am not empty" << endl;;
}
str.resize(length + 10, 'a'); //重新分配空间,将多余的十个空间分配a
cout << str << endl;;
str.clear(); //清除字符串
if (str.empty()) //判断字符串是否为空
{
cout << "i am empty" << endl;;
}
str.append("ywb");
cout << str << endl;
str.append(" hell0");//append 在string后插入字符串
cout << str;
system("pause");
}
相关文章
- C#委托(delegate)的常用方式- 委托的定义 // 委托的核心是跟委托的函数结构一样 public delegate string SayHello(string c); public delegate string SayHello(string c);:定义了一个公共委托类型 SayHello,该委托接受一个 string 类型的参数 c,并返回一个 string 类型的值。 Main 方法 static void Main(string args) { // 本质上其实就是把方法当作委托的参数 SayHello sayC = new SayHello(SayChinese); Console.WriteLine(sayC("欢迎大家")); SayHello sayE = new SayHello(SayEgnlish); Console.WriteLine(sayE("Welcome to")); // 简单的写法:必须类型一样 SayHello s1 = SayChinese; SayHello s2 = SayEgnlish; Console.WriteLine(s1("好好好")); Console.WriteLine(s2("Gooood")); // 最推荐 SayHello ss1 = con => con; Console.WriteLine(ss1("niiiice")); // 匿名委托:一次性委托 SayHello ss3 = delegate(string s) { return s; }; Console.WriteLine(ss3("说中国话")); } 常规实例化委托 SayHello sayC = new SayHello(SayChinese);:创建了一个 SayHello 委托的实例 sayC,并将 SayChinese 方法作为参数传递给委托的构造函数。 Console.WriteLine(sayC("欢迎大家"));:通过委托实例调用 SayChinese 方法,并输出结果。 同理,SayHello sayE = new SayHello(SayEgnlish); 和 Console.WriteLine(sayE("Welcome to")); 是对 SayEgnlish 方法的委托调用。 简化的委托赋值方式 SayHello s1 = SayChinese; 和 SayHello s2 = SayEgnlish;:当委托类型和方法签名一致时,可以直接将方法赋值给委托变量,无需使用 new 关键字。 Console.WriteLine(s1("好好好")); 和 Console.WriteLine(s2("Gooood"));:通过委托实例调用相应的方法。 使用 Lambda 表达式实例化委托 SayHello ss1 = con => con;:使用 Lambda 表达式创建委托实例 ss1,con => con 表示接受一个参数 con 并返回该参数本身。 Console.WriteLine(ss1("niiiice"));:通过委托实例调用 Lambda 表达式。 匿名委托 SayHello ss3 = delegate(string s) { return s; };:使用匿名委托创建委托实例 ss3,delegate(string s) { return s; } 是一个匿名方法,直接在委托实例化时定义了方法体。 Console.WriteLine(ss3("说中国话"));:通过委托实例调用匿名方法。 委托引用的方法定义 public static string SayChinese(string content) { return content; } public static string SayEgnlish(string content) { return content; } public static string SayChinese(string content) 和 public static string SayEgnlish(string content):定义了两个静态方法,分别接受一个 string 类型的参数 content,并返回该参数本身。这两个方法的签名与 SayHello 委托一致,可以被 SayHello 委托引用。 常规的委托实例化、简化的赋值方式、Lambda 表达式和匿名委托。委托在 C# 中是一种强大的机制,它允许将方法作为参数传递,实现了代码的灵活性和可扩展性。
- C++类重载函数的function和bind使用
- Visual C++中min()和max()函数的使用
- FreeNOS中C++源码部分相关类构造函数以及方法函数的初始化过程(六)
- C++构造函数和析构函数,以及构造函数特殊成员变量和函数的初始化
- C/C++中经常使用的字符串处理函数和内存字符串函数
- 什么是C++虚函数、虚函数的作用和使用方法
- 为什么在c++ 11中使用非成员的开始和结束函数?
- c++错误:使用Qt和QVariant,没有从指针到指针引用的匹配函数调用。
- C++回调函数的理解和使用教程