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操作系统,它能同时运行几个程序(独立运行的程序又称之为进程),对于同一个程序,它又可以分成若干个独立的执行流,我们称之为线程,线程 ...
随机推荐
- DC综合简单总结(2)
DC综合简单总结(2) 建立时间和保持时间和数据输出延时时间 一.概念 建立时间和保持时间都是针对触发器的特性说的. 建立时间(Tsu:set up time) 是指在触发器的时钟信号上升沿到来以前, ...
- 20165221 《网络对抗技术》EXP2:后门原理与实践
20165221 <网络对抗技术>EXP2:后门原理与实践 实验任务 任务一:使用netcat获取主机操作Shell,cron启动 (0.5分) 任务二:使用socat获取主机操作Shel ...
- Mac环境下Scrapy的安装
直接命令安装: $ easy_install scrapy 从 GitHub 安装: $ git clonehttps://github.com/scrapy/scrapy.git $ cd scra ...
- CSS 实现滚动进度条效果
参考:https://www.w3cplus.com/css/pure-css-create-scroll-indicator.html 前言:细化总结.参考的文章作者已经写的很详细了.这里在从初学者 ...
- Jenkins的配置从节点中默认没有Launch agent via Java Web Start选项问题
Jenkins的配置从节点中默认没有Launch agent via Java Web Start,如下图所示,而这种启动方式在Windows上是最方便的. 如何设置才能让出来呢? 1:打开" ...
- oracle wallet使用与维护
oracle wallet使用与维护2015年05月26日 17:58:55 SilenceRiver 阅读数:1614oracle wallet使用与维护---oracle无密码登录分类: Orac ...
- newSoft
Email:kefu007@vip.qq.com CADソフト Siemens PLM NX 1847 (64ビット) 日本語版 KeyCreator Ver.15.5 (64ビット)日本語版 MYP ...
- Flask路由&视图
1 路由 1.1app.url_map 查看所有路由 from flask import Flask app = Flask(__name__) @app.route('/') def hello_ ...
- 企业面试必会shell
企业面试题1: 使用for循环在/oldboy目录下通过随机小写10个字母加固定字符串oldboy批量创建10个html文件,名称例如为: [root@oldboy oldboy]# sh /serv ...
- [原创]基于Zynq PS与PL之间寄存器映射 Standalone & Linux 例程
基于Zynq PS与PL之间寄存器映射 Standalone & Linux 例程 待添加完善中