C/C++(C++类与对象)
构造器(constructor)
1.与类名相同,无返回,被系统生成对象时自动调用,用于初始化。
2.可以有参数,构造器的重载,有默认参数。重载和默认参数不能同时出现,但是一定要包含标配(无参数的构造器),为了对象的午无参创建。
3.如果未提供任何构造器,系统默认提供一个无参的构造器。如果提供,则不再生成默认构造器。
#ifndef STACK_H
#define
class Stack
{
public:
Stack()//构造器,
{
top = 0;
space = new char[size];
}
Stack(int size = 100)//构造器与构造器之间是重载的关系
{
top = 0;
space = new char[size];
_size = size;
}
public:
//void init();
bool isEmpty();
bool isFull();
void push(int data);
int pop();
private:
int space[1024];
int top;
int _size;
};
#endif
stack.cpp:
#include<iostream>
#inlcude "stack.h"
#include<stdlib.h>
#include<string.h>
bool Stack::isEmpty()
{
return top == 0;
}
bool Stack::isFull()
{
return top == 1024;
}
void Stack::push(int data)
{
space[top++] = data;
}
int Stack::pop()
{
return space[--top];
}
main.cpp
#include<iostream>
#include "stack.h"
using namespace std;
int main()
{
Stack s;
Stack s2(100);
//s.init();
for(char v = "a";!st.isFull()&& v != 'z'+1;v++)
{
st.push(v);
}
while(!s.isEmpty())
cout<<s.pop()<<endl;
return 0;
}
析构器(destructor)"~"
1.~与类名相同,无参,无返回。
2.对象消失的时候,自动被调用,用于对象销毁是的处理工作。
3.如果未提供任何构造器,系统会自动生成一个空析构器。
#ifndef STACK_H
#define
class Stack
{
public:
Stack()//构造器,
{
top = 0;
space = new char[size];
}
Stack(int size = 100)//构造器与构造器之间是重载的关系
{
top = 0;
space = new char[size];
_size = size;
}
~Stack()
{
delete sapce;//适合于new生成的空间
}
public:
//void init();
bool isEmpty();
bool isFull();
void push(int data);
int pop();
private:
int space[1024];
int top;
int _size;
};
#endif
#include<iostream>
#include "stack.h"
using namespace std;
int main()
{
Stack s;
Stack s2(100);
//s.init();
for(char v = "a";!st.isFull()&& v != 'z'+1;v++)
{
st.push(v);
}
while(!s.isEmpty())
cout<<s.pop()<<endl;
return 0;
}
C:
struct Stu
{
char *name;
int age;
}
int main()
{
Stu *ps = (Stu*)malloc(sizeof(Stu));
ps->name = (char *)malloc(100);//给name也要申请空间
strcpy(ps->name,"xxx");
free(ps->name);//释放的时候也要从里向外释放。
free(ps);
return 0;
}
C++:
class Stu
{
char *name;
int age;
public:
Stu()
{
name = new char[100];
}
~Stu()
{
delete []name;//释放构造器中new出来的空间
}
}
int main()
{
Stu *ps = new Stu;
strcpy(ps->name,"assassin");
delete ps;//释放上述new出的空间
return 0;
}
/*
Stu *p = new Stu;生成八个字节的空间,p指向8个字节,Stu的构造器生成100个字节,name指向这100个字节。delete ps,调用了析构函数,析构函数先释放100个字节的空间,再释放掉8个字节的空间。
*/
自实现string类
main.cpp
#include <iostream>
#include "myString.h"
using namespace std;
int main()
{
string s; //char * _str = "";
string s2 = "assassin"; //char * str = "xxxx";
cout<<s.c_str()<<endl;
cout<<s2.c_str()<<endl;
String ss;
String sss = "intelwisd";
cout<<ss.c_str()<<endl;
cout<<sss.c_str()<<endl;
return 0;
}
myString.h:
#ifndef STRING_H
#define STRING_H
class String
{
public:
String();
String(const char *s);
char * c_str();//利用此函数输出
private:
char * _str;
};
#endif // STRING_H
myString.cpp
#include<iostream>
#include "string.h"
#include "myString.h"
using namespace std;
String::String()
{
_str = new char[1];
*_str = '\0';//字符
}
String::String(const char *s)
{
int len = strlen(s);
_str = new char[len+1];
strcpy(_str,s);
}
char * String::c_str()
{
return _str;
}
改进:
myString.h文件
#ifndef STRING_H
#define STRING_H
#if 0
class String
{
public:
String();
String(const char *s);
char * c_str();
private:
char * _str;
};
#endif
class String
{
public:
//String();
String(const char *s = NULL);//无参的形式包含在里面
char * c_str();
~String();
private:
char * _str;
};
#endif // STRING_H
myString.cpp文件:
#include<iostream>
#include "string.h"
#include "myString.h"
using namespace std;
#if 0
String::String()
{
_str = new char[1];
*_str = '\0';//字符
}
String::String(const char *s)
{
int len = strlen(s);
_str = new char[len+1];
strcpy(_str,s);
}
#endif
String::String(const char *s)
{
if(s == NULL)
{
_str = new char[1];
*_str = '\0';
}else{
int len = strlen(s);
_str = new char[len+1];
strcpy(_str,s);
}
}
char * String::c_str()
{
return _str;
}
String::~String()
{
delete []_str;
}
main.cpp:文件
#include <iostream>
#include "myString.h"
using namespace std;
int main()
{
string s; //char * _str = "";
string s2 = "assassin"; //char * str = "xxxx";
cout<<s.c_str()<<endl;
cout<<s2.c_str()<<endl;
String ss;
String sss("intelwisd");
cout<<ss.c_str()<<endl;
cout<<sss.c_str()<<endl;
return 0;
}
string *ps = new string("assassin");
delete ps;
string *ps1 = new string("assassin1");
delete ps1;

ps指向new生成一个四个字节的空间char *,char *指向一串字符。delete ps时,先释放掉内部一串字符,再释放掉char *。
C/C++(C++类与对象)的更多相关文章
- Java编程里的类和对象
像我们搞计算机这块的,都知道这么一件事,当前的计算机编程语言主要分为两大块,一为面向过程,二为面向对象.Java就是一门纯面向对象的语言.学习了一个月左右的Java,在下对于Java当中的类和对象有了 ...
- Python - 类与对象的方法
类与对象的方法
- C++基础知识(5)---类和对象
终于把C++中的基础在前面的几篇博客中总结完了,可能还有一些语法还没有总结到,没关系,以后用到了再查资料就好.类是C++中的一个非常重要的概念,这是区别你使用的C++到底是面向过程还是面向对象的一个重 ...
- 简述JavaScript对象、数组对象与类数组对象
问题引出 在上图给出的文档中,用JavaScript获取那个a标签,要用什么办法呢?相信第一反应一定是使用document.getElementsByTagName('a')[0]来获取.同样的,在使 ...
- 前端学PHP之面向对象系列第一篇——类和对象
× 目录 [1]类 [2]成员属性[3]成员方法[4]对象[5]成员访问[6]this 前面的话 面向对象程序设计(OOP)是一种计算机编程架构.计算机程序由单个能够起到子程序作用的单元或对象组成,为 ...
- Objective-C Runtime 运行时之一:类与对象
Objective-C语言是一门动态语言,它将很多静态语言在编译和链接时期做的事放到了运行时来处理.这种动态语言的优势在于:我们写代码时更具灵活性,如我们可以把消息转发给我们想要的对象,或者随意交换一 ...
- [Java入门笔记] 面向对象编程基础(一):类和对象
什么是面向对象编程? 我们先来看看几个概念: 面向过程程序设计 面向过程,是根据事情发展的步骤,按进行的顺序过程划分,面向过程其实是最为实际的一种思考方式,可以说面向过程是一种基础的方法,它考虑的是实 ...
- 解析Java类和对象的初始化过程
类的初始化和对象初始化是 JVM 管理的类型生命周期中非常重要的两个环节,Google 了一遍网络,有关类装载机制的文章倒是不少,然而类初始化和对象初始化的文章并不多,特别是从字节码和 JVM 层次来 ...
- 02OC的类和对象
这章重点介绍OC的类以及对象,由于C语言是面向过程语言,而OC只是对于C语言多了一些面向对象的特性,所以OC相对于其他面向对象语言,例如C#.Java等没有那么多的语法特性,所以差别还是比较大的. 一 ...
- swift基础:第六部分:类与对象
http://reactnative.cn/docs/0.24/getting-started.html#content(react Native 开发文档) 互联网这个时代,你松懈一天,就会有很多很 ...
随机推荐
- 在android中,编译的项目使用到第三方jar的导入方法 终极版!
1,在android系统环境中编译自己的项目时,往往会用到第三方jar包.这些jar包在eclipse中加入编译,一路畅通,由于eclipse已经帮助你配置好了.可是当把这个项目复制到系统环境中编译时 ...
- php函数in_array奇怪现象
$k = 0; $fieldArr = array('tt', 'bb'); if ( in_array( $k, $fieldArr)) { echo '1'; } 按理来说,是不会输出1的,可是最 ...
- 大浪淘沙,JSP终将死去
首先讲明,我不是标题党. 这纯属我个人的意见.勿喷. 先来讲讲JSP是怎么出现的吧. 在早期的WEB中,JS.CSS远未成熟,技术慷慨向并不明白!因为前端语言的匮乏.各家大公司都推出基于后端的模板语言 ...
- System Databases in SQL Server
https://docs.microsoft.com/en-us/sql/relational-databases/databases/system-databases SQL Server incl ...
- Codeforces434D 网络流
思路: 题意:有n<=50个点,每个点有xi有[li, ri]种取值,-100 <= li <= ri <= 100,并且给定m<=100条边,每条边为u,v,d表示xu ...
- 二维码扫描ZXing简化
最近项目中有需要用到二维码扫描功能,于是查了相关资料,也没有过多地研究ZXing源码,只是有了最简单的功能,因为下载大牛的demo已经完全实现了功能,只是对其中的扫描线做了更改,需要的朋友可以直接使用 ...
- Functor& Monad解读
整体上代表封装的概念,重点是函数的封装,及函数运行的上下文环境.trait Functor[F[_]] Functor:代表整体封装: F[_]:代表封装后的目标域. A.B:代表普通的对象:f:代表 ...
- 阿里云slb上传证书错误
阿里云上传证书错误 今天在阿里云给slb上传新买的证书,传的过程中报错了,如下: 网上找了半天没找到,鼠标放在错误哪行行首,会报一个错 大意就是一行最多64个字符,我检查了下,报错这行是68个字符,于 ...
- NodeJS学习笔记 进阶 (11)Nodejs 进阶:调试日志打印:debug模块
个人总结:读完这篇文章需要5分钟,讲解了debug模块的使用 摘选自网络 前言 在node程序开发中时,经常需要打印调试日志.用的比较多的是debug模块,比如express框架中就用到了.下文简单举 ...
- MPI对道路车辆情况的Nagel-Schreckenberg 模型进行蒙特卡洛模拟
平台Ubuntu 16.04,Linux下MPI环境的安装见链接:https://blog.csdn.net/lusongno1/article/details/61709460 据 Nagel-Sc ...