C/C++(C++封装)
封装
当单一变量无法完成描述需求的时候,结构体类型解决了这一问题。可以将多个类型打包成一体,形成新的类型。这是 c 语言中封装的概念。但是,新类型并不包含,对数据类的操作。所的有操作都是通过函数的方式,去其进行封装。
对一组数据变量组进行结合形成结构体--初步的封装。
C语言的封装风格,数据放到一起找包Struct,然后把数据以引用或者指针的方式传给行为。
#include <iostream>
using namespace std;
struct Date
{
int year;
int month;
int day;
};
void init(Date &d)
{
cout<<"year,month,day:"<<endl;
cin>>d.year>>d.month>>d.day;
}
void print(Date & d)
{
cout<<"year month day"<<endl;
cout<<d.year<<":"<<d.month<<":"<<d.day<<endl;
}
bool isLeapYear(Date & d)
{
if((d.year%4==0&& d.year%100 != 0) || d.year%400 == 0)
return true;
else
return false;
}
int main()
{
Date d;
init(d);
print(d);
if(isLeapYear(d))
cout<<"leap year"<<endl;
else
cout<<"not leap year"<<endl;
return 0;
}
C++ 认为c封装不彻底。
1.数据和行为没有分离。
2.没有权限控制。
封装的特点:对内数据开放,逻辑抽象,对外提供接口。
C++增加权限控制,private protected public 数据和行为在一起,对内开放,对外提供接口。
过程:类 -> 类对象 ->对象。对象调用行为完成需求。
class Date
{
protect://属性,成员变量
int year;
int month;
int day;
public://行为,成员函数
void init()
{
cin>>year;
cin>>month;
cin>>day;
}
void print()
{
cout<<"year:"<<"month:"<<"day"<<endl;
cout<<year<<":"<<month<<":"<<day<<endl;
}
}
int main()
{
Date d;
d.init();
d.print();
return 0;
}
class Date
{
protect://属性,成员变量
int year;
int month;
int day;
public://行为,成员函数
void init();
void print();
}
void Date:: init()//防止冲突
{
cin>>year;
cin>>month;
cin>>day;
}
void Date:: print()
{
cout<<"year:"<<"month:"<<"day"<<endl;
cout<<year<<":"<<month<<":"<<day<<endl;
}
int main()
{
Date d;
d.init();
d.print();
return 0;
}
c++多文件中的管理:
date.h:
#ifndef DATE_H
#define DATE_H
using namespace Spac
{
class Date
{
private:
int year;
int month;
int day;
public:
void init();
void print();
int getYear();
bool isLeapYear();
}
}
#endif
class文件:date.cpp
#include<iostream>
#include "date.h"
using namespace std;
using namespace Space
{
void Date:: init()
{
cin>>year;
cin>>month;
cin>>day;
}
void Date:: print()
{
cout<<"year:"<<"month:"<<"day"<<endl;
cout<<year<<":"<<month<<":"<<day<<endl;
}
}
main.cpp
#include<iostrem>
#include "date.h"
using namespace std;
using namespace Space;
int main()
{
Date d;
d.init();
d.print();
return 0;
}
应用栈的实现:
C:
#include<stdio.h>
#include<stdlib.h>
typedef struct stack
{
char space[1024];
int top;
}Stack;
void init(Stack *s)
{
s->top = 0;
memset(s->space,0,1024);
}
int isEmpty(Stack * s)
{
return s->top == 0;
}
int isFull(Stack *s)
{
return s->top == 1024;
}
char pop(Stack *s)
{
return s.space[--s.top];
}
void push(Stack * s,char c)
{
s.space[s.top++] = c;
}
int main()
{
Stack st;
init(&st);
if(!isFull)
push(&st,'a');
if(!isFull)
push(&st,'b');
if(!isFull)
push(&st,'c');
if(!isFull)
push(&st,'d');
if(!isFull)
push(&st,'e');
while(!isEmpty(&st))
printf("%c\n",pop(&st));
return 0;
}
C++:
#include <iostream>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
using namespace std;
class Stack
{
public:
void init();
bool isEmpty();
bool isFull();
void push(int data);
int pop();
private:
int space[1024];
int top;
};
void Stack::init()
{
memset(space,0,sizeof(space));
top = 0;
}
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];
}
int main()
{
Stack s;
s.init();
if(!s.isFull())
s.push(10);
if(!s.isFull())
s.push(20);
if(!s.isFull())
s.push(30);
if(!s.isFull())
s.push(40);
if(!s.isFull())
s.push(50);
while(!s.isEmpty())
cout<<s.pop()<<endl;
return 0;
}
个文件分离管理:
stack.h(class文件)
#ifndef STACK_H
#define
class Stack
{
public:
void init();
bool isEmpty();
bool isFull();
void push(int data);
int pop();
private:
int space[1024];
int top;
};
#endif
stack.cpp:
#include<iostream>
#inlcude "stack.h"
#include<stdlib.h>
#include<string.h>
void Stack::init()
{
memset(space,0,sizeof(space));
top = 0;
}
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;
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++链表的实现:
class List
{
private:
Node * head;
public:
void initList();
void insertList();
void traverseList();
void deleteNode(Node * pfind);
Node * searchList(int find);
void sortList();
void destroy();
};
void List:: initList()
{
head = new Node;
head->next = NULL;
}
void List:: insertList(int d)
{
Node * cur = new Node;
cur->data = d;
cur->next = head->next;
head->next = cur;
}
void List:: traverseList()
{
Node * ph = head->next;
while(ph != NULL)
{
cout<<ph->data<endl;
ph = ph->next;
}
}
void List:: deleteNode(Node * pfind);
Node * List:: searchList(int find);
void List:: sortList();
void List:: destroy();
int main()
{
List list;
list.init();
for(int i = 0;i < 10;i++)
{
list.insertList(i);
}
list.traverseList();
return 0;
}
C/C++(C++封装)的更多相关文章
- [C#] 简单的 Helper 封装 -- RegularExpressionHelper
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- iOS开发之App间账号共享与SDK封装
上篇博客<iOS逆向工程之KeyChain与Snoop-it>中已经提到了,App间的数据共享可以使用KeyChian来实现.本篇博客就实战一下呢.开门见山,本篇博客会封装一个登录用的SD ...
- Ajax实现原理,代码封装
都知道实现页面的异步操作需要使用Ajax,那么Ajax到是怎么实现异步操作的呢? 首先需要认识一个对象 --> XMLHttpRequest 对象 --> Ajax的核心.它有许多的属性和 ...
- 用C语言封装OC对象(耐心阅读,非常重要)
用C语言封装OC对象(耐心阅读,非常重要) 本文的主要内容来自这里 前言 做iOS开发的朋友,对OC肯定非常了解,那么大家有没有想过OC中NSInteger,NSObject,NSString这些对象 ...
- 【知识必备】RxJava+Retrofit二次封装最佳结合体验,打造懒人封装框架~
一.写在前面 相信各位看官对retrofit和rxjava已经耳熟能详了,最近一直在学习retrofit+rxjava的各种封装姿势,也结合自己的理解,一步一步的做起来. 骚年,如果你还没有掌握ret ...
- 对百度WebUploader开源上传控件的二次封装,精简前端代码(两句代码搞定上传)
前言 首先声明一下,我这个是对WebUploader开源上传控件的二次封装,底层还是WebUploader实现的,只是为了更简洁的使用他而已. 下面先介绍一下WebUploader 简介: WebUp ...
- 封装集合(Encapsulate Collection)
封装就是将相关的方法或者属性抽象成为一个对象. 封装的意义: 对外隐藏内部实现,接口不变,内部实现自由修改. 只返回需要的数据和方法. 提供一种方式防止数据被修改. 更好的代码复用. 当一个类的属性类 ...
- CSharpGL(29)初步封装Texture和Framebuffer
+BIT祝威+悄悄在此留下版了个权的信息说: CSharpGL(29)初步封装Texture和Framebuffer +BIT祝威+悄悄在此留下版了个权的信息说: Texture和Framebuffe ...
- CSharpGL(7)对VAO和VBO的封装
CSharpGL(7)对VAO和VBO的封装 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码中包含10多个独立的Demo,更适合入门参考 ...
- Swift -- 对AFN框架的封装
Swift -- 对AFN框架的封装 一.封装AFN的目的 简单的说: 解耦 日常工作中,我们一般都不会去直接使用AFNetWorking来直接发送网络请求,因为耦合性太强,假设有多个控制器都使用AF ...
随机推荐
- javascript取前n天的日期两种方法
方法一: var d = new Date(); d = new Date(d.getFullYear(),d.getMonth(),d.getDate()-n); 方法二: var now = ne ...
- MySQL锁定状态查看命令
1 show processlist; SHOW PROCESSLIST显示哪些线程正在运行.您也可以使用mysqladmin processlist语句得到此信息.如果您有SUPER权限,您可以看到 ...
- Qt之QPushButton
简述 前面章节我们分享过Qt之QAbstractButton,讲解了QAbstractButton的基本用法,本节着重讲解QPushButton. 简述 常用状态 效果 源码 QSS 更多参考 关于Q ...
- Qt之QStackedLayout
简述 QStackedLayout继承自QLayout. QStackedLayout类提供了多页面切换的布局,一次只能看到一个界面. QStackedLayout可用于创建类似于QTabWidget ...
- leetCode解题报告5道题(七)
题目一:Interleaving String Given s1, s2, s3, find whether s3 is formed by the interleaving of s1 and s2 ...
- 小米净水器与小区过滤价格水对照.xls
总结:要是一天用水量为7升下面.还是用小区的过滤水为好,合算. 假设过滤水需求量大,可能小米的净水器比較好.当然,小区的要天天去接.要求风雨无阻的. 这点小米的随用随接就更好. 注意一点,小米的还要用 ...
- Unity 内置Shader变量、辅助函数等
一:标准库里的常用.cginc文件 HLSLSupport.cginc - (automatically included) Helper macros and definitions for cro ...
- bzoj1831: [AHOI2008]逆序对(DP+双精bzoj1786)
1831: [AHOI2008]逆序对 Description 小可可和小卡卡想到Y岛上旅游,但是他们不知道Y岛有多远.好在,他们找到一本古老的书,上面是这样说的: 下面是N个正整数,每个都在1~K之 ...
- 桌面出现removable storage devices文件夹无法删除解决办法
今天桌面突然出现 removable storage devices 文件夹,且没有删除选项. 解决办法:往电脑里插一下u盘文件夹就会自动消失了.
- ipad mini2 升级9.0.2后解锁白屏解决
解锁白屏是个什么现象?就是当你用手指滑动解锁后出现输入密码的界面后,1秒之内屏幕变白,中间一个黑色的苹果,几秒之后重新回到滑动解锁的界面.我出现这个现象不是因为升级了9.0.2,而是升级了9.0.2之 ...