/*

//多继承
#include <iostream>
using namespace std; class Sofa
{
public:
Sofa();
~Sofa(); void sit() {
cout<<"sit!"<<endl;
} void setWeight(int w) {
this->weight = w;
} int getWeight() {
return this->weight;
} void showWeight() {
cout<<this->weight<<endl;
} private: int weight; }; Sofa::Sofa()
{
cout<<"Sofa,构造!"<<endl;
} Sofa::~Sofa()
{
cout<<"Sofa,析构!"<<endl;
} class Bed
{
public:
Bed();
~Bed(); void lie() {
cout<<"lie!"<<endl;
} void setWeight(int w) {
this->weight = w;
} int getWeight() {
return this->weight;
} void showWeight() {
cout<<this->weight<<endl;
} private: int weight;
}; Bed::Bed()
{
cout<<"Bed,构造!"<<endl;
} Bed::~Bed()
{
cout<<"Bed,析构!"<<endl;
} class Sofabed : public Bed, public Sofa
{
public:
Sofabed();
~Sofabed(); void showWeight() { Sofa::showWeight();
cout<<"&&"<<endl;
Bed::showWeight(); } private: }; Sofabed::Sofabed()
{
cout<<"Sofabed,构造!"<<endl;
} Sofabed::~Sofabed()
{
cout<<"Sofabed,析构!"<<endl;
} int main () { Sofabed myfur;
myfur.sit();
myfur.lie(); // myfur.setWeight(12); // super的名字有冲突。不行。
myfur.Sofa::setWeight(12); // 要写 [obj.classname::function(12)] ;
myfur.Sofa::showWeight();
myfur.Bed::setWeight(99);
myfur.Bed::showWeight(); // sofa & bed 的 member 是两个不一样的。 // 也可以在 derived class 里,overload 名字冲突的函数
myfur.showWeight(); system("pause");
return 0; } //多继承
#include <iostream>
using namespace std; class CB0
{
public:
CB0() {
cout<<"CB0,构造!"<<endl;
};
~CB0() {
cout<<"CB0,析构!"<<endl;
}; void fun() {
cout<<"CB0::fun()"<<endl;
} void fun(int i) {
cout<<"CB0::fun(int i) "<<endl;
} }; class CD0 : public CB0
{
public:
CD0() {
cout<<"CD0,构造!"<<endl;
};
~CD0() {
cout<<"CD0,析构!"<<endl;
}; void fun(int i) {
cout<<"CD0::fun(int i) "<<endl;
}
}; int main () { CB0 * obj1 = new CD0;
obj1->fun();
obj1->fun(0); CD0 obj2;
obj2.fun(0); // 只有这一个了! system("pause");
return 0;
} //多继承
#include <iostream>
using namespace std; class CA
{ public:
CA(int a):x(a) {
cout<<"CA构造函数\n";
}
~CA() {cout<<"CA析构函数\n";}
int x; private: }; class CB : public CA
{
public:
CB(int a, int b):CA(a),y(b){
cout<<"CB构造函数\n";
}
~CB() {
cout<<"CB析构函数\n";
}
int y; private: }; class CC : public CA
{
public:
CC(int a, int b):CA(a) {
this->z = b;
cout<<"CC 构造\n";
};
~CC() {
cout<<"CC 析构\n";
};
int z; private: }; class CD : public CB, public CC
{
public:
CD(int a , int b, int c, int d,int e) : CC(c,d),CB(a,b) {
cout<<"CD 构造\n";
this->w = e;
}
~CD() {
cout<<"CD 解构\n";
} void ShowVal() {
cout << "x=" << CB::x << " y=" << y;
cout << " x=" << CC::x << " z=" << z;
cout << " w=" << w << endl;
} private:
int w;
}; void fun1() { CD cd1(1,2,3,4,5); // 按理说 cb的x 和 cc的x 其实是一样的。并不是[后一个值,把前一个值覆盖掉!]
cout<<"xxxxxxxxxxxxxxxxxxxxxxxxxx"<<endl;
cd1.ShowVal(); // 但事实上不一样! // 避免这种情况,用【虚继承】!!!!!
// 【虚基类】!!!!!!!!!!!!! } int main() { fun1(); system("pause");
return 0; } //多继承
#include<iostream>
using namespace std; class Child1
{
public:
Child1() :a(0), b(0), c(0) { cout << "child 构造\n"; }
~Child1()
{
cout << "child 析构,,,\n";
}
void c1_print()
{
cout << "a b c is" << a << " " << b << " " << c << endl;
} int a;
int b;
int c;
};
class Child2
{
public:
Child2() :a(1), b(2), c(3) { cout << "child 构造\n"; }
~Child2()
{
cout << "child 析构,,,\n";
}
void c2_print()
{
cout << "a b c is" << a << " " << b << " " << c << endl;
}
int a;
int b;
int c;
};
class Child3 : public Child1, public Child2
{
public:
Child3() : Child1(),Child2(), b(20), c(30) { cout << "child 构造\n"; }
~Child3()
{
cout << "child 析构,,,\n";
}
void c3_print()
{
//cout << "a b c is" << a << " " << b << " " << c << endl;
}
int a;
int b;
int c;
};
int main()
{ Child3 c3;
c3.a = 123;
//c3.Child1::a = 123;
//c3.c1_print(); return 0;
} //多线程
#include "iostream"
#include "thread"
using namespace std; void functionw()
{
cout<<"hello world"<<endl;
} int main()
{ thread t(functionw); //t()内为要在此线程执行的方法
t.join(); //t加入主线程,主线程等待他执行完毕再执行
//t.detach(); //并发执行,和主线程同时执行,可能导致主线程执行完毕它 // 没有机会执行,并且被detach的不能在join,除非加判断入下 // if(t.joinable())
// {
// t.join();
// }
cout<<"住县城"<<endl;
return 0;
} //多线程
#include "iostream"
#include "thread"
using namespace std; void functionw()
{
for(int i=0;i<10;i++)
{
cout<<"form t,i love u"<<endl;
}
} int main()
{
thread t(functionw);//线程执行的另一种方式
try
{
for(int i=0;i<10;i++)
{
cout<<"form main,i love u"<<endl;
}
}
catch(...)
{
t.join();
throw; //保证t和main有一个执行
}
} //向量
#include <iostream>
#include <vector>
using namespace std;
int main()
{
vector<int> iVec;
cout << "容器 大小为: " << iVec.size() << endl;//取得大小
cout << "容器 容量为: " << iVec.capacity() << endl; //1个元素, 容器容量为1
iVec.push_back(1);//在后面存入一个数值
cout << "容器 大小为: " << iVec.size() << endl;
cout << "容器 容量为: " << iVec.capacity() << endl; //2个元素, 容器容量为2
iVec.push_back(2);
cout << "容器 大小为: " << iVec.size() << endl;
cout << "容器 容量为: " << iVec.capacity() << endl; //3个元素, 容器容量为4
iVec.push_back(3);
cout << "容器 大小为: " << iVec.size() << endl;
cout << "容器 容量为: " << iVec.capacity() << endl; //4个元素, 容器容量为4
iVec.push_back(4);
iVec.push_back(5); cout << "\n容器 大小为: " << iVec.size() << endl;
cout << "容器 容量为: " << iVec.capacity() << endl; //5个元素, 容器容量为8
iVec.push_back(6);
cout << "容器 大小为: " << iVec.size() << endl;
cout << "容器 容量为: " << iVec.capacity() << endl; //6个元素, 容器容量为8
iVec.push_back(7);
cout << "容器 大小为: " << iVec.size() << endl;
cout << "容器 容量为: " << iVec.capacity() << endl; //7个元素, 容器容量为8
iVec.push_back(8);
cout << "容器 大小为: " << iVec.size() << endl;
cout << "容器 容量为: " << iVec.capacity() << endl; //8个元素, 容器容量为8
iVec.push_back(9);
cout << "容器 大小为: " << iVec.size() << endl;
cout << "容器 容量为: " << iVec.capacity() << endl; //9个元素, 容器容量为16
// vs2005/8 容量增长不是翻倍的,如
// 9个元素 容量9
// 10个元素 容量13
//测试effective stl中的特殊的交换 swap()
cout << "当前vector 的大小为: " << iVec.size() << endl;
cout << "当前vector 的容量为: " << iVec.capacity() << endl;
vector<int>(iVec).swap(iVec);
cout << "临时的vector<int>对象 的大小为: " << (vector<int>(iVec)).size() << endl;
cout << "临时的vector<int>对象 的容量为: " << (vector<int>(iVec)).capacity() << endl;
cout << "交换后,当前vector 的大小为: " << iVec.size() << endl;
cout << "交换后,当前vector 的容量为: " << iVec.capacity() << endl;
return 0;
} //vector迭代器
#include <iostream>
#include <vector>
using namespace std;
int main(){
int a[6]={1,2,3,4,5,6};
vector<int> b;
vector<int> c(a,a+4);
for(vector<int>::iterator it=c.begin();it<c.end();it++){
b.push_back(*it);
}
for(vector<int>::iterator it=b.begin();it<b.end();it++){
cout<<*it<<endl;
}
} #include <string>
#include <vector>
#include <iostream>
using namespace std; int main()
{
vector<int>obj;//创建一个向量存储容器 int
for(int i=0;i<10;i++) // push_back(elem)在数组最后添加数据
{
obj.push_back(i);
cout<<obj[i]<<",";
} for(int i=0;i<5;i++)//去掉数组最后一个数据
{
obj.pop_back();
} cout<<"\n"<<endl; for(int i=0;i<obj.size();i++)//size()容器中实际数据个数
{
cout<<obj[i]<<",";
} return 0;
} //重载+
#include<iostream>
using namespace std;
class A
{
private:
int a;
public:
A();
A(int n);
A operator+(const A & obj);
A operator+(const int b);
friend A operator+(const int b, A obj);
void display();
} ;
A::A()
{
a=0;
}
A::A(int n)//构造函数
{
a=n;
}
A A::operator +(const A& obj)//重载+号用于 对象相加
{
return this->a+obj.a;
}
A A::operator+(const int b)//重载+号用于 对象与数相加
{
return A(a+b);
}
A operator+(const int b, A obj)
{
return obj+b;//友元函数调用第二个重载+的成员函数 相当于 obj.operator+(b);
}
void A::display()
{
cout<<a<<endl;
}
int main ()
{
A a1(1);
A a2(2);
A a3,a4,a5;
a1.display();
a2.display(); int m=1;
a3=a1+a2;//可以交换顺序,相当月a3=a1.operator+(a2);
a3.display(); a4=a1+m;//因为加了个友元函数所以也可以交换顺序了。
a4.display(); a5=m+a1;
a5.display();
} //重载+运算符
#include <iostream>
using namespace std; class Box
{
double length; // 长度
double width; // 宽度
double height; // 高度
public: double getVolume(void)
{
return length * width * height;
}
void setLength( double len )
{
length = len;
} void setwidth( double bre )
{
width = bre;
} void setHeight( double hei )
{
height = hei;
} //改写部分 2018.09.05
//重载 + 运算符,用于把两个 Box 对象相加
//因为其是全局函数,对应的参数个数为2。
//当重载的运算符函数是全局函数时,需要在类中将该函数声明为友员。
friend Box operator+(const Box& a, const Box& b); }; Box operator+(const Box& a, const Box& b)
{
Box box;
box.length = a.length + b.length;
box.width = a.width + b.width;
box.height = a.height + b.height;
// cout << box.length << "--" << box.width << "--" << box.height << endl;
return box;
} // 程序的主函数
int main( )
{ Box Box1; // 声明 Box1,类型为 Box
Box Box2; // 声明 Box2,类型为 Box
Box Box3; // 声明 Box3,类型为 Box
double volume = 0.0; // 把体积存储在该变量中 // Box1 详述
Box1.setLength(6.0);
Box1.setwidth(7.0);
Box1.setHeight(5.0); // Box2 详述
Box2.setLength(12.0);
Box2.setwidth(13.0);
Box2.setHeight(10.0); // Box1 的体积
volume = Box1.getVolume();
cout << "Volume of Box1 : " << volume <<endl; // Box2 的体积
volume = Box2.getVolume();
cout << "Volume of Box2 : " << volume <<endl; // 把两个对象相加,得到 Box3
Box3 = Box1 + Box2; // Box3 的体积
volume = Box3.getVolume();
cout << "Volume of Box3 : " << volume <<endl; return 0;
} //虚继承
#include <iostream>
using namespace std;
//基类 class D
{
public:
D(){cout<<"D()"<<endl;}
~D(){cout<<"~D()"<<endl;}
protected:
int d;
}; class B:virtual public D
{
public:
B(){cout<<"B()"<<endl;}
~B(){cout<<"~B()"<<endl;}
protected:
int b;
}; class A:virtual public D
{
public:
A(){cout<<"A()"<<endl;}
~A(){cout<<"~A()"<<endl;}
protected:
int a;
}; class C:public B, public A
{
public:
C(){cout<<"C()"<<endl;}
~C(){cout<<"~C()"<<endl;}
protected:
int c;
}; int main()
{
cout << "Hello World!" << endl;
C c; //D, B, A ,C
cout<<sizeof(c)<<endl;
return 0;
} //继承
#include <iostream> using namespace std; // 基类
class Shape
{
public:
void setWidth(int w)
{
width = w;
}
void setHeight(int h)
{
height = h;
}
protected:
int width;
int height;
}; // 派生类
class Rectangle: public Shape
{
public:
int getArea()
{
return (width * height);
}
}; int main(void)
{
Rectangle Rect; Rect.setWidth(5);
Rect.setHeight(7); // 输出对象的面积
cout << "Total area: " << Rect.getArea() << endl; return 0;
} //继承
#include <iostream>
using namespace std;
// 基类 Shape
class Shape
{
public:
void setWidth(int w)
{
width = w;
}
void setHeight(int h)
{
height = h;
}
protected:
int width;
int height;
}; // 基类 PaintCost
class PaintCost
{
public:
int getCost(int area)
{
return area * 70;
}
}; // 派生类
class Rectangle: public Shape, public PaintCost
{
public:
int getArea()
{
return (width * height);
}
}; int main(void)
{
Rectangle Rect;
int area; Rect.setWidth(5);
Rect.setHeight(7); area = Rect.getArea(); // 输出对象的面积
cout << "Total area: " << Rect.getArea() << endl; // 输出总花费
cout << "Total paint cost: $" << Rect.getCost(area) << endl; return 0;
} //内联函数
#include <iostream>
using namespace std;
inline int Max(int x, int y)
{
return (x > y)? x : y;
} // 程序的主函数
int main( )
{ cout << "Max (20,10): " << Max(20,10) << endl;
cout << "Max (0,200): " << Max(0,200) << endl;
cout << "Max (100,1010): " << Max(100,1010) << endl;
return 0;
} #include <iostream>
using namespace std;
class Box
{
public:
// 构造函数定义
Box(double l=2.0, double b=2.0, double h=2.0)
{
cout <<"Constructor called." << endl;
length = l;
breadth = b;
height = h;
}
double Volume()
{
return length * breadth * height;
}
int compare(Box box)
{
return this->Volume() > box.Volume();
}
private:
double length; // Length of a box
double breadth; // Breadth of a box
double height; // Height of a box
}; int main(void)
{
Box Box1(3.3, 1.2, 1.5); // Declare box1
Box Box2(8.5, 6.0, 2.0); // Declare box2
if(Box1.compare(Box2))
{
cout << "Box2 is smaller than Box1" <<endl;
}
else
{
cout << "Box2 is equal to or larger than Box1" <<endl;
}
return 0;
} #include <iostream>
using namespace std;
class Box
{
public:
// 构造函数定义
Box(double l=2.0, double b=2.0, double h=2.0)
{
cout <<"Constructor called." << endl;
length = l;
breadth = b;
height = h;
}
double Volume()
{
return length * breadth * height;
}
private:
double length; // Length of a box
double breadth; // Breadth of a box
double height; // Height of a box
}; int main(void)
{
Box Box1(3.3, 1.2, 1.5); // Declare box1
Box Box2(8.5, 6.0, 2.0); // Declare box2
Box *ptrBox; // Declare pointer to a class.
// 保存第一个对象的地址
ptrBox = &Box1;
// 现在尝试使用成员访问运算符来访问成员
cout << "Volume of Box1: " << ptrBox->Volume() << endl;
// 保存第二个对象的地址
ptrBox = &Box2;
// 现在尝试使用成员访问运算符来访问成员
cout << "Volume of Box2: " << ptrBox->Volume() << endl;
return 0;
} //变量调用构造函数
#include <iostream>
using namespace std; class Cpoint{
public:
static int value;
static int num;
Cpoint(int x,int y){
xp=x;yp=y;
value++;
cout << "调用构造:" << value << endl;
} ~Cpoint(){num++; cout << "调用析构:" << num << endl;} private:
int xp,yp;
}; int Cpoint::value=0;
int Cpoint::num=0;
class CRect{
public:
CRect(int x1,int x2):mpt1(x1,x2),mpt2(x1,x2){
cout << "调用构造\n";
}
~CRect(){cout << "调用析构\n";}
private:
Cpoint mpt1,mpt2;
}; int main()
{
CRect p(10,20);
cout << "Hello, world!" << endl;
return 0;
} #include <iostream>
using namespace std;
class Box
{
public:
static int objectCount;
// 构造函数定义
Box(double l=2.0, double b=2.0, double h=2.0)
{
cout <<"Constructor called." << endl;
length = l;
breadth = b;
height = h;
// 每次创建对象时增加 1
objectCount++;
}
double Volume()
{
return length * breadth * height;
}
private:
double length; // 长度
double breadth; // 宽度
double height; // 高度
}; // 初始化类 Box 的静态成员 其实是定义并初始化的过程
int Box::objectCount = 0;
//也可这样 定义却不初始化
//int Box::objectCount;
int main(void)
{
Box Box1(3.3, 1.2, 1.5); // 声明 box1
Box Box2(8.5, 6.0, 2.0); // 声明 box2 // 输出对象的总数
cout << "Total objects: " << Box::objectCount << endl; return 0;
} #include <iostream> using namespace std; class Box
{
public:
static int objectCount;
// 构造函数定义
Box(double l=2.0, double b=2.0, double h=2.0)
{
cout <<"Constructor called." << endl;
length = l;
breadth = b;
height = h;
// 每次创建对象时增加 1
objectCount++;
}
double Volume()
{
return length * breadth * height;
}
static int getCount()
{
return objectCount;
}
private:
double length; // 长度
double breadth; // 宽度
double height; // 高度
}; // 初始化类 Box 的静态成员
int Box::objectCount = 0; int main(void)
{ // 在创建对象之前输出对象的总数
cout << "Inital Stage Count: " << Box::getCount() << endl; Box Box1(3.3, 1.2, 1.5); // 声明 box1
Box Box2(8.5, 6.0, 2.0); // 声明 box2 // 在创建对象之后输出对象的总数
cout << "Final Stage Count: " << Box::getCount() << endl; return 0;
} #include <iostream>
using namespace std; int main()
{
int i,j,k; // p[2][3][4] int ***p;
p = new int **[2];
for(i=0; i<2; i++)
{
p[i]=new int *[3];
for(j=0; j<3; j++)
p[i][j]=new int[4];
} //输出 p[i][j][k] 三维数据
for(i=0; i<2; i++)
{
for(j=0; j<3; j++)
{
for(k=0;k<4;k++)
{
p[i][j][k]=i+j+k;
cout<<p[i][j][k]<<" ";
}
cout<<endl;
}
cout<<endl;
} // 释放内存
for(i=0; i<2; i++)
{
for(j=0; j<3; j++)
{
delete [] p[i][j];
}
}
for(i=0; i<2; i++)
{
delete [] p[i];
}
delete [] p;
return 0;
} #include <iostream> // cout
#include <algorithm> // unique, distance
#include <vector> // vector
using namespace std;
bool myfunction (int i, int j) {
return (i==j);
} int main () {
int myints[] = {10,20,20,20,30,30,20,20,10}; // 10 20 20 20 30 30 20 20 10
vector<int> myvector (myints,myints+9); // using default comparison:
vector<int>::iterator it;
it = unique (myvector.begin(), myvector.end()); // 10 20 30 20 10 ? ? ? ?
// ^
for (it=myvector.begin(); it!=myvector.end(); ++it)
cout << ' ' << *it;
cout << '\n';
myvector.resize( distance(myvector.begin(),it) ); // 10 20 30 20 10 // using predicate comparison:
unique (myvector.begin(), myvector.end(), myfunction); // (no changes) // print out content:
cout << "myvector contains:";
for (it=myvector.begin(); it!=myvector.end(); ++it)
cout << ' ' << *it;
cout << '\n'; return 0;
} #include <iostream>
#include <vector>
#include <algorithm> typedef unsigned long U32; typedef vector < U32 > VectorType; int add(VectorType *pVector ,U32 m)
{
if(NULL == pVector)
{
return -1;
} pVector->push_back(m); //添加元素到末尾//无返回值 return 0;
} int remove(VectorType *pVector ,U32 m)
{
if(NULL == pVector)
{
return -1;
} VectorType::iterator iVector = find(pVector->begin(), pVector->end(), m); if(iVector != pVector->end())
{
pVector->erase(iVector); //参数只能是迭代器
cout<<" erase success "<< m<<endl;
}
else
{
cout<<" not find in pVector"<< m<<endl;
} return 0;
} int remove_last_one(VectorType *pVector )
{
if(NULL == pVector)
{
cout<<"pVector is NULL,(remove_last_one)"<<endl;
return -1;
} if(pVector->empty())
{
cout<<"pVector is empty , remove_last_one"<<endl;
return -1;
} pVector->pop_back(); //删除最后一个元素
return 0;
} int remove_all(VectorType *pVector )
{
if(NULL == pVector)
{
cout<<"pVector is NULL,(remove_all)"<<endl;
return -1;
} #if 0
VectorType::iterator iVector = pVector->begin();//;find(pVector->begin(), pVector->end(), m); while(iVector != pVector->end())
{
cout<<" remove_all a "<< (*iVector)<<endl;
iVector = pVector->erase(iVector);
cout<<" remove_all b "<< (*iVector)<<endl;
} #endif //这种做法导致大量的移动操作,但好处是如果元素是指针,我们可以先把内存
//释放了再删除
//erase的返回值是指向删除元素的下一个元素的迭代器指针 #if 1
while(pVector->size() != 0)
{
//pop_back方法无返回值
pVector->pop_back();//删除操作避免大量移动的方法,如果元素有申请堆栈的内存,不可用此方法
}
#endif
#if 0
//以下方法不可行 VectorType::iterator iVector = pVector->end();//;find(pVector->begin(), pVector->end(), m); while(iVector != pVector->begin())
{
cout<<" remove_all a "<< (*iVector)<<endl;
iVector = pVector->erase(iVector);
cout<<" remove_all b "<< (*iVector)<<endl;
}
#endif
return 0;
} void dump(VectorType *pVector)
{
if(NULL == pVector)
{
cout<<"pVector is NULL"<<endl;
return ;
} if(pVector->empty()) //判断是否为空
{
cout<<"pVector is empty"<<endl;
return ;
} VectorType::iterator iVector = pVector->begin();
while(iVector != pVector->end())
{
cout<<" dump "<< (*iVector)<<endl;
++iVector;
} return ;
} int find(VectorType *pVector ,U32 m,int *pnFlag)
{
if(NULL == pVector || NULL == pnFlag)
{
return -1;
} *pnFlag = 0;
VectorType::iterator iVector = find(pVector->begin(), pVector->end(), m);
if(iVector != pVector->end())
{
cout<<" find success "<< m<<endl;
*pnFlag = 1;
return 0;
}
else
{
cout<<" not find in pVector"<< m<<endl;
return -1;
}
} int insert_one(VectorType *pVector ,U32 val, int iPlace)
{
int i = 0;
if(NULL == pVector || iPlace < 0)
{
cout<<"insert_one param error"<<endl;
return -1;
} VectorType::iterator iVector = pVector->begin();
while(iVector != pVector->end())
{
//cout<<" dump "<< (*iVector)<<endl;
if(i == iPlace)
{
iVector = pVector->insert(iVector , val); //此时insert的返回值是迭代器,插入成功后iVector指向插入的位置
cout<<" insert_one after iVector point "<< (*iVector)<<endl;
return 0;
} i++;
++iVector;
} iVector = pVector->insert(pVector->end() , val); return 0;
} int print_size(VectorType *pVector)
{
if(NULL == pVector)
{
cout<<"pVector is NULL"<<endl;
return -1;
} if(pVector->empty()) //判断是否为空
{
cout<<"pVector is empty (get_size)"<<endl;
} cout<<"pVector capacity: "<< pVector->capacity() << " size:"<<pVector->size()<<endl; return 0;
} int main()
{
VectorType vArray(20);//初始化20个元素的容器
int nFlag =0; vArray.clear();//把容器的里的元素全部清掉 //添加元素
add(&vArray,5);
add(&vArray,4);
add(&vArray,3);
add(&vArray,2);
add(&vArray,1);
add(&vArray,0); //插入一个元素 值为6
U32 val = 6;
int place = 2;
insert_one(&vArray, val, place); //打印capatity size
print_size(&vArray); dump(&vArray); //删除末尾元素
remove_last_one(&vArray); print_size(&vArray); U32 element = 1;
find(&vArray ,element,&nFlag); remove(&vArray ,element);
find(&vArray ,element,&nFlag); element = 8;
//移除元素element
remove(&vArray ,element); //查找element
find(&vArray ,element,&nFlag); //移除所有元素
remove_all(&vArray); dump(&vArray); print_size(&vArray); vector < U32 >().swap(vArray);//销毁向量的做法 print_size(&vArray); }
*/

c++ demo code的更多相关文章

  1. penpyxl basic function demo code

    Openpyxl basic function demo code demo code: #!/usr/bin/env python # -*- coding: utf-8 -*- "&qu ...

  2. RAD Studio Demo Code和几个国外FMX网站 good

    FireMonkey X –  Amazing overview of FireMonkey FMX Feeds – All your FireMonkey news in one place FMX ...

  3. ps2keyboard demo code for 8052

    #pragma code symbols debug objectextend #include <reg51.h> /* special function register declar ...

  4. ( ! ) Parse error: syntax error, unexpected '' (T_ENCAPSED_AND_WHITESPACE), expecting identifier (T_STRING) or variable (T_VARIABLE) or number (T_NUM_STRING) in D:\demo\code\yolo\index\index.php on li

    sql语句为:$sql="select count(*) from com where a_id=$v['id']"; 出现以下错误: 原因: 变量没有用花括号引起来 改为:  $ ...

  5. npm install 安装报错:npm ERR! EPERM npm ERR! -4048 npm ERR! Error: EPERM: operation not permitted, unlink 'D:\test\demo\code\materialT\node_modules\.staging'

    更新项目依赖包,删除掉package-lock.json.node_modules,运行npm install,报如上错误信息,查询资料说是没有权限,本人用管理员身份打开powershell,运行np ...

  6. swagger demo code

    //Application 开启注解 @EnableSwagger2public class Application { public static void main(String[] args) ...

  7. 创建简单的表单Demo

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. react context toggleButton demo

    //toggleButton demo: //code: //1.Appb.js: import React from 'react'; import {ThemeContext, themes} f ...

  9. Google Summer of Code 2017 经验谈

    Google Summer of Code (GSoC) 2018 又要开始了. 如果想实现你心中的开源梦想, 用代码让世界变得更美好. 参加GSoC可能是你进入开源的世界最好途径. GSoC是什么 ...

随机推荐

  1. 使用隔离级别read committed隐式解决并发冲突

    1.使用rc的弊端:出现不可重复读 Oracle不可重复读 Oracle丢失修改 Oracle幻读 任何数据库的update  insert  delete都加排它锁 sql server的selec ...

  2. static的用法详解

    一.静态类 [1] 仅包含静态成员. [2] 静态类的本质,是一个抽象的密封类,所以不能被继承,也不能被实例化.也就是说,不能使用 new 关键字创建静态类类型的变量. [4] 不能包含实例构造函数. ...

  3. 什么是实体关系图(ERD)? 转

    https://www.visual-paradigm.com/cn/guide/data-modeling/what-is-entity-relationship-diagram/#erd-data ...

  4. docker系列七之Dockerfile

    Dockerfile 一. Dockerfile是什么   Dockerfile是docker中镜像文件的的描述文件,说的直白点就是镜像文件到底是由什么东西一步步构成的.例如我们在淘宝上买了一件商品, ...

  5. Flutter 自定义绘制 View

    在 Flutter 中自定义 View 有两种方式: 组合已有控件 自定义绘制 如何自定义绘制 有两个类做这件事情: CustomPaint :会在绘制阶段提供一个 Canvas 画布 CustomP ...

  6. linux物理地址和虚拟地址定义

    线性地址(Linear Address) 是逻辑地址到物理地址变换之间的中间层 如果启用了分页机制,那么线性地址可以再经过变换以产生一个物理地址:如果没有启用分页机制,那么线性地址直接就是物理地址 分 ...

  7. redis slot 槽点

    Redis 集群中内置了 16384 个哈希槽,当需要在 Redis 集群中放置一个 key-value 时,redis 先对 key 使用 crc16 算法算出一个结果,然后把结果对 16384 求 ...

  8. 【Struts2】Json插件使用

    一.使用步骤 1.1 引入依赖 1.2 在struts.xml文件中配置 一.使用步骤 1.1 引入依赖 <!-- https://mvnrepository.com/artifact/org. ...

  9. Image Processing and Analysis_8_Edge Detection:Design of steerable filters for feature detection using canny-like criteria ——2004

    此主要讨论图像处理与分析.虽然计算机视觉部分的有些内容比如特 征提取等也可以归结到图像分析中来,但鉴于它们与计算机视觉的紧密联系,以 及它们的出处,没有把它们纳入到图像处理与分析中来.同样,这里面也有 ...

  10. PHP通过iconv将字符串从GBK转换为UTF8字符集

    PHP通过iconv将字符串从GBK转换为UTF8字符集的方法,需要的朋友可以参考下. 1. iconv()介绍 iconv函数可以将一种已知的字符集文件转换成另一种已知的字符集文件.例如:从GB23 ...