C++ 初步
c++新特性:
1. 初始化方法:
复制初始化 int x=1024;
直接初始化 int x (1024);
2.变量随用随定义
3.增加bool数据类型
输入输出:
cout<<x;
cin>>x>>y;
cout<<oct<<x<<endl; //oct为8进制,dec为十进制,hex为16进制
cout<<boolalpha<<y<<endl; //输出布尔型数据
命名空间:
namespace A
{
int x=0;
void f1();
void f2();
}
A::x A::f1()
引用:变量的别名
int a=3;
int &b=a; 引用必须初始化
b=10;
结构体类型的引用:
typedef struct
{
int x;
int y;
}Coor;
Coor c1;
Coor &c=c1;
c.x;
指针类型的引用:
类型 *&指针引用名=指针;
int a=10;
int *p=&a;
int *&q=p;
*q=20; //a=20;
引用做函数参数:
void fun(int &a,int &b)
{
int c=0;
c=a;
a=b;
b=c;
}
int x=10,y=20;
fun(x,y);
const:
函数参数默认值:函数括号内最右端的变量必须有默认值 ,无实参用默认值,否则覆盖。
函数重载:在相同作用域下,有同名函数,参数个数和类型不同。
内联函数: 编译时将函数体内代码和实参代替函数调用语句。效率高,有条件
关键字:inline
内存管理:
申请:new int *p=new int; 释放:delete p;
块内存: int *arr=new int[10]; delete []arr;
注意事项:c语言:*malloc(),free()。
if(NULL==p){ // 申请失败 } delete p; p=NULL;
类:
对象实例化:
1.从栈实例化对象:class TV{ .... } TV tv; TV tv[20];
2.从堆实例化: TV *p =new TV(); delete p;
对象成员的访问:
1. 栈: tv.type=0; tv.func();
2.堆: p->tyoe=0; p->func(); delete p; p=NULL;
数据类型:
1.string:
#include<string>
初始化:string s1; s1为空串
string s2("ABC");
string s3(s2); 将s3初始化为s2的一个副本
string s4(n,'c'); 将s4初始化为字符‘c’的n个副本
常用操作: s.empty(), s.size() , s[n], = , + , == , !=
数据封装:
#include<stdlib.h>
#include<iostream>
#include<string>
using namespace std; class Student
{
public:
void setName(string _name)
{
m_strName=_name;
}
string getName()
{
return m_strName;
}
void setGender(string _gender)
{
m_strGender=_gender;
}
string getGender()
{
return m_strGender;
}
int getScore()
{
return m_iScore;
}
void initScore()
{
m_iScore=;
}
void study(int _score)
{
m_iScore+=_score;
}
private:
string m_strName;
string m_strGender;
int m_iScore;
}; int main(void)
{
Student stu;
stu.initScore();
stu.setName("hhhh");
stu.setGender("F");
stu.study();
stu.study(); cout<<stu.getName()<<" "<<stu.getGender()<<" "<<stu.getScore()<<endl; return ;
}
内联函数:inline
类内定义:类内定义的函数会优先转换为内联函数
类外定义:1.同文件类外定义
#include<stdlib.h>
#include<iostream>
#include<string>
using namespace std; class Teacher
{
public:
void setName(string _name);
string getName();
void setGender(string _gender);
string getGender();
void setAge(int _age);
int getAge();
void teach();
private:
string m_strName;
string m_strGender;
int m_iAge;
}; void Teacher::setName(string _name){
m_strName=_name;
}
string Teacher::getName()
{
return m_strName;
}
void Teacher::setGender(string _gender){
m_strGender=_gender;
}
string Teacher::getGender(){
return m_strGender;
}
void Teacher::setAge(int _age){
m_iAge=_age;
}
int Teacher::getAge(){
return m_iAge;
}
void Teacher::teach(){
cout<<"teaching!...."<<endl;
} int main(void)
{
Teacher t;
t.setName("Kongzi");
t.setGender("M");
t.setAge();
cout<<t.getName()<<" "<<t.getGender()<<" "<<t.getAge()<<endl;
t.teach();
return ;
}
2.分文件类外定义
//teacher.h /*
* teacher.h *
* Created on: 2017年7月12日
* Author: rmbp
*/
#include <string>
using namespace std; class Teacher
{
public:
void setName(string _name);
string getName();
void setGender(string _gender);
string getGender();
void setAge(int _age);
int getAge();
void teach();
private:
string m_strName;
string m_strGender;
int m_iAge;
}; //teacher.cpp
/*
* teacher.cpp
*
* Created on: 2017年7月12日
* Author: rmbp
*/
#include "teacher.h"
#include<iostream>
using namespace std; void Teacher::setName(string _name){
m_strName=_name;
}
string Teacher::getName()
{
return m_strName;
}
void Teacher::setGender(string _gender){
m_strGender=_gender;
}
string Teacher::getGender(){
return m_strGender;
}
void Teacher::setAge(int _age){
m_iAge=_age;
}
int Teacher::getAge(){
return m_iAge;
}
void Teacher::teach(){
cout<<"teaching!...."<<endl;
} //hello.cpp
#include<stdlib.h>
#include<iostream>
#include<string> #include "teacher.h"
using namespace std; int main(void)
{
Teacher t;
t.setName("Kongzi");
t.setGender("M");
t.setAge();
cout<<t.getName()<<" "<<t.getGender()<<" "<<t.getAge()<<endl;
t.teach();
return ;
}
内存分区:
栈区:系统控制
堆区:程序员控制
全局区:存储全局变量和静态变量
常量区:字符串,常量
代码区:存储逻辑代码的的二进制
构造函数:在对象实例化时被自动调用,与类名同名,没有返回值,可以重载,只用到一个构造函数,用户没有创建时系统自动创建。
//teacher.h
#include <string>
using namespace std; class Teacher
{
public:
Teacher();
Teacher(string name,int age); //可以初始化参数值 void setName(string _name);
string getName();
void setAge(int _age);
int getAge();
private:
string m_strName;
string m_strGender;
int m_iAge;
}; //teacher.cpp #include "teacher.h"
#include<iostream>
using namespace std; Teacher::Teacher()
{
m_strNme="JIM";
m_iAge=;
cout<<"Teacher()"<<endl;
}
Teacher::Teacher(string name,int age){
m_strNme=name;
m_iAge=age;
cout<<"Teacher(string name,int age)"<<endl;
} void Teacher::setName(string _name){
m_strName=_name;
}
string Teacher::getName()
{
return m_strName;
}
void Teacher::setAge(int _age){
m_iAge=_age;
}
int Teacher::getAge(){
return m_iAge;
} //hello.cpp
#include<stdlib.h>
#include<iostream>
#include<string> #include "teacher.h"
using namespace std; int main(void)
{
Teacher t1;
Teacher t2("Merry",); cout<<t1.getName()<<" "<<t1.getAge()<<endl;
cout<<t2.getName()<<" "<<t2.getAge()<<endl; return ;
}
默认构造函数:在对象实例化时不需要传递参数
构造函数初始化列表:先于构造函数执行,只能用于构造函数,可以同时初始化多个数据
class Student
{
public:
Student():m_strName("JIM"),m_iAge(){}
private:
string m_strName;
int m_iAge;
};
必要性:
class Circle
{
public:
Circle():m_dPi(3.14){} //不能用构造函数,const
private:
const double m_dPi;
}
//teacher.h
#include <string>
using namespace std; class Teacher
{
public:
Teacher(string name="JIM",int age=,int m=); void setName(string _name);
string getName();
void setAge(int _age);
int getAge();
int getMax();
private:
string m_strName;
int m_iAge;
const int m_iMax;
}; //teacher.cpp #include "teacher.h"
#include<iostream>
using namespace std; Teacher::Teacher(string name,int age,int m):m_strName(name),m_iAge(age),m_iMax(m)
{
cout<<"Teacher(string name,int age)"<<endl;
} void Teacher::setName(string _name){
m_strName=_name;
}
string Teacher::getName()
{
return m_strName;
}
void Teacher::setAge(int _age){
m_iAge=_age;
}
int Teacher::getAge(){
return m_iAge;
}
int Teacher::getMax(){
return m_iMax;
} //hello.cpp
#include<stdlib.h>
#include<iostream>
#include<string> #include "teacher.h"
using namespace std; int main(void)
{
Teacher t1("merry",); cout<<t1.getName()<<" "<<t1.getAge()<<" "<<t1.getMax()<<endl; return ;
}
拷贝构造函数: 类名(const 类名& 变量名)
1.当没有自定义拷贝构造函数则系统系统自动生成一个默认的拷贝构造函数。
2.当采用直接初始化或复制初始化实例化对象时系统自动调用拷贝构造函数。
无参构造函数,有参构造函数(参数带默认值)--》默认构造函数
系统自动生成普通构造函数和拷贝构造函数。不能重载。
//teacher.h Teacher(const Teacher& tea);
//.... //teacher.cpp
teacher::Teacher(const Teacher &tea){
cout<<"Teacher(const Teacher &tea)"<<endl;
} //hello.cpp
int main(void)
{
Teacher t1;
Teacher t2=t1;
Teacher t3(t1); //....
}
//hello.cpp void test(Teacher t)
{
} int main(void)
{
Teacher t1; //构造函数
test(t1); //拷贝构造函数 //....
}
析构函数:~类名(),不允许加任何参数,系统自动产生,在对象销毁时自动调用。没有返回值,没有参数不能重载
//teacher.h /*
* teacher.h *
* Created on: 2017年7月12日
* Author: rmbp
*/
#include <string>
using namespace std; class Teacher
{
public:
Teacher(string name="JIM",int age=); //构造
Teacher(const Teacher &tea); //拷贝构造
~Teacher(); //析构函数
void setName(string _name);
string getName();
void setAge(int _age);
int getAge();
private:
string m_strName;
int m_iAge;
}; //teacher.cpp #include "teacher.h"
#include<iostream>
using namespace std; Teacher::Teacher(string name,int age):m_strName(name),m_iAge(age)
{
cout<<"Teacher(string name,int age)"<<endl;
}
Teacher::Teacher(const Teacher &tea)
{
cout<<"Teacher(const Teacher &tea)"<<endl;
}
Teacher:~Teacher()
{
cout<<"~Teacher()"<<endl;
}
void Teacher::setName(string _name){
m_strName=_name;
}
string Teacher::getName()
{
return m_strName;
}
void Teacher::setAge(int _age){
m_iAge=_age;
}
int Teacher::getAge(){
return m_iAge;
} //hello.cpp
#include<stdlib.h>
#include<iostream>
#include<string> #include "teacher.h"
using namespace std; int main(void)
{
Teacher t1;
//Teacher *p=new Teacher();
//delete p; Teacher t2(t1);
return ;
}
C++ 初步的更多相关文章
- 移动端之Android开发的几种方式的初步体验
目前越来越多的移动端混合开发方式,下面列举的大多数我都略微的尝试过,就初步的认识写个简单的心得: 开发方式 开发环境 是否需要AndroidSDK 支持跨平台 开发语言&技能 MUI Win+ ...
- CSharpGL(29)初步封装Texture和Framebuffer
+BIT祝威+悄悄在此留下版了个权的信息说: CSharpGL(29)初步封装Texture和Framebuffer +BIT祝威+悄悄在此留下版了个权的信息说: Texture和Framebuffe ...
- Android自定义View初步
经过上一篇的介绍,大家对于自定义View一定有了一定的认识,接下来我们就以实现一个图片下显示文字的自定义View来练习一下.废话不多说,下面进入我们的正题,首先看一下我们的思路,1.我们需要通过在va ...
- 初步认识Node 之Node为何物
很多人即便是在使用了Node之后也不知道它到底是什么,阅读完本文你应该会有一个初步的.具体的概念了. Node的目标 提供一种简单的构建可伸缩网络程序的方法.那么,什么是可伸缩网络程序呢?可伸缩 ...
- [入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二)
[入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二) Date 周六 10 一月 2015 By 钟谢伟 Category website develop ...
- 基于C/S架构的3D对战网络游戏C++框架_05搭建系统开发环境与Boost智能指针、内存池初步了解
本系列博客主要是以对战游戏为背景介绍3D对战网络游戏常用的开发技术以及C++高级编程技巧,有了这些知识,就可以开发出中小型游戏项目或3D工业仿真项目. 笔者将分为以下三个部分向大家介绍(每日更新): ...
- Azure底层架构的初步分析
之所以要写这样的一篇博文的目的是对于大多数搞IT的人来说,一般都会对这个topic很感兴趣,因为底层架构直接关乎到一个公有云平台的performance,其实最主要的原因是我们的客户对此也非常感兴趣, ...
- CozyRSS开发记录14-RSS源管理初步完工
CozyRSS开发记录14-RSS源管理初步完工 1.添加源的响应 DialogHost.Show有几个版本的重载,加一个DialogClosingEventHandler参数.我们让添加源对话框的添 ...
- 初步了解CPU
了解CPU By JackKing_defier 首先说明一下,本文内容主要是简单说明CPU的大致原理,所需要的前提知识我会提出,但是由于篇幅我不会再详细讲解需要的其他基础知识.默认学过工科基础课. ...
- Windows多线程多任务设计初步(转)
Windows多线程多任务设计初步 [前言:]当前流行的Windows操作系统,它能同时运行几个程序(独立运行的程序又称之为进程),对于同一个程序,它又可以分成若干个独立的执行流,我们称之为线程,线程 ...
随机推荐
- Grunt 一个专为JavaScript提供的构建工具
新手最好找个视频来看看, Grunt的配置及使用(压缩合并js/css) - 每天都记录一点点! - CSDN博客https://blog.csdn.net/playboyanta123/articl ...
- AppCan
启动服务 将app程序寄宿在计算机上,在计算机上调试:访问服务地址,将appToken值复制一下 在浏览器输入192.168.2.102:3000/appToken的值/文件路径后即可调试 入口文件 ...
- 堆,set,优先队列
当我们需要高效的完成以下操作时: 1.插入一个元素 2.取得最小(最大)的数值,并且删除 能够完成这种操作的数据结构叫做优先队列 而能够使用二叉树,完成这种操作的数据结构叫做堆(二叉堆) 堆与优先队列 ...
- 医学图像数据(二)——TCIA完整数据集下载方式
1. 构建下载环境 l TCIA数据集下载文件为.jnlp格式(JNLP(Java Network Launching Protocol )是java提供的一种可以通过浏览器直接执行java应用程序 ...
- 题解-HAOI2018全套
去冬令营转了一圈发现自己比别人差根源在于刷题少,见过的套路少(>ω<) 于是闲来无事把历年省选题做了一些 链接放的都是洛谷的,bz偷懒放的也是链接 AM.T1 奇怪的背包 Problem ...
- 使用docker中mysql镜像
1.拉取mysql镜像 docker pull mysql:5.6 2.运行mysql的镜像生成一个正在运行的容器,可以通过docker contain ls得到容器的id信息 docker run ...
- hdu2181 简单搜索
题意: 一个规则的实心十二面体,它的 20个顶点标出世界著名的20个城市,你从一个城市出发经过每个城市刚好一次后回到出发的城市. Input前20行的第i行有3个数,表示与第i个城市相邻的3个城市.第 ...
- 移动端添加横向滚动条&隐藏
添加横向滚动条ul { display: flex; overflow-x: auto; overflow-y: hidden; white-space: nowrap; }隐藏滚动条,保留滚动效果 ...
- django orm 及常用参数
一些说明: 表myapp_person的名称是自动生成的,如果你要自定义表名,需要在model的Meta类中指定 db_table 参数,强烈建议使用小写表名,特别是使用MySQL作为后端数据库时. ...
- python读取uti-8格式ini配置文件出现UnicodeDecodeError: 'gbk' codec can't decode byte 0xba in position 367: illegal multibyte sequence错误解决方法
出现这种错误只需要在read下添加encoding='utf-8' 如: from configparser import ConfigParser cf = ConfigParser() cf.re ...