C++解析二
C++ 类访问修饰符
数据封装是面向对象编程的一个重要特点,它防止函数直接访问类类型的内部成员。类成员的访问限制是通过在类主体内部对各个区域标记 public、private、protected 来指定的。关键字 public、private、protected 称为访问修饰符。一个类可以有多个 public、protected 或 private 标记区域。每个标记区域在下一个标记区域开始之前或者在遇到类主体结束右括号之前都是有效的。成员和类的默认访问修饰符是 private。
class Base {
public: // 公有成员
protected: // 受保护成员
private: // 私有成员
};
公有(public)成员
公有成员在程序中类的外部是可访问的。您可以不使用任何成员函数来设置和获取公有变量的值,如下所示:
#include <iostream>
using namespace std;
class Line
{
public:
double length;
void setLength(double len);
double getLength(void );
}; double Line::getLength(void)
{
return length ;
} void Line::setLength( double len )
{
length = len;
} int main( )
{
Line line;
line.setLength(6.0);
cout << "Length of line : " << line.getLength() <<endl;
line.length = 10.0;
cout << "Length of line : " << line.length <<endl;
return ;
}
编译并执行:
Length of line :
Length of line :
私有(private)成员
私有成员变量或函数在类的外部是不可访问的,甚至是不可查看的。只有类和友元函数可以访问私有成员。
默认情况下,类的所有成员都是私有的。例如在下面的类中,width 是一个私有成员,这意味着,如果您没有使用任何访问修饰符,类的成员将被假定为私有成员:
class Box
{
double width;
public:
double length;
void setWidth( double wid );
double getWidth( void );
};
实际操作中,我们一般会在私有区域定义数据,在公有区域定义相关的函数,以便在类的外部也可以调用这些函数,如下所示:
#include <iostream>
using namespace std; class Box
{
public:
double length;
void setWidth( double wid );
double getWidth( void ); private:
double width;
}; double Box::getWidth(void)
{
return width ;
} void Box::setWidth( double wid )
{
width = wid;
} int main()
{
Box box; box.length = 10.0; //length is public
cout << "Length of box : " << box.length <<endl; //box.width = 10.0; // Error: the width is private
box.setWidth(10.0); // member function to set the width
cout << "Width of box : " << box.getWidth() <<endl; return ;
}
编译并执行:
Length of box :
Width of box :
保护(protected)成员
保护成员变量或函数与私有成员十分相似,但有一点不同,保护成员在派生类(即子类)中是可访问的。
现在您可以看到下面的实例中,我们从父类 Box 派生了一个子类 smallBox。下面的实例与前面的实例类似,在这里 width 成员可被派生类 smallBox 的任何成员函数访问。
#include <iostream>
using namespace std; class Box
{
protected:
double width;
}; class SmallBox:Box // SmallBox 是派生类
{
public:
void setSmallWidth( double wid );
double getSmallWidth( void );
}; // 子类的成员函数
double SmallBox::getSmallWidth(void)
{
return width ;
} void SmallBox::setSmallWidth( double wid )
{
width = wid;
} int main( )
{
SmallBox box; // 使用成员函数设置宽度
box.setSmallWidth(5.0);
cout << "Width of box : "<< box.getSmallWidth() << endl; return ;
}
编译并执行:
Width of box :
继承中的特点
有public, protected, private三种继承方式,它们相应地改变了基类成员的访问属性。
基类 public 成员,protected 成员,private 成员的访问属性在派生类中分别变成:public, protected, private
但无论哪种继承方式,下面两点都没有改变:
1. private 成员只能被本类成员(类内)和友元访问,不能被派生类访问;
2. protected 成员可以被派生类访问。
public继承
#include <iostream>
#include <assert.h>
using namespace std; class A{
public:
int a;
A() {
a1 = ;
a2 = ;
a3 = ;
a = ;
} void fun() {
cout << a << endl; //right
cout << a1 << endl; //right
cout << a2 << endl; //right
cout << a3 << endl; //right
}
public:
int a1;
protected:
int a2;
private:
int a3;
}; class B : public A{
public:
int a;
B(int i) {
A();
a = i;
}
void fun() {
cout << a << endl; //right, public成员
cout << a1 << endl; //right, 基类的public成员,在派生类中仍是public成员
cout << a2 << endl; //right,基类的protected成员,在派生类中仍是protected,可以被派生类访问
// cout << a3 << endl; //wrong,基类的private成员,不能被派生类访问
}
}; int main() {
B b();
cout << b.a << endl;
cout << b.a1 << endl; //right
// cout << b.a2 << endl; //wrong, 类外不能访问protected成员
// cout << b.a3 << endl; //wrong, 类外不能访问private成员
return ;
}
编译输出:
10
11
protected继承
#include <iostream>
#include <assert.h>
using namespace std;
class A{
public:
int a;
A(){
a1 = ;
a2 = ;
a3 = ;
a = ;
}
void fun(){
cout << a << endl; //正确
cout << a1 << endl; //正确
cout << a2 << endl; //正确
cout << a3 << endl; //正确
}
public:
int a1;
protected:
int a2;
private:
int a3;
};
class B : protected A{
public:
int a;
B(int i){
A();
a = i;
}
void fun(){
cout << a << endl; //正确,public成员。
cout << a1 << endl; //正确,基类的public成员,在派生类中变成了protected,可以被派生类访问。
cout << a2 << endl; //正确,基类的protected成员,在派生类中还是protected,可以被派生类访问。
// cout << a3 << endl; //错误,基类的private成员不能被派生类访问。
}
}; int main(){
B b();
cout << b.a << endl; //正确。public成员
//cout << b.a1 << endl; //错误,public成员不能在类外访问。
//cout << b.a2 << endl; //错误,protected成员不能在类外访问。
//cout << b.a3 << endl; //错误,private成员不能在类外访问。
return ;
}
编译输出:
10
private继承
#include <iostream>
#include <assert.h>
using namespace std;
class A{
public:
int a;
A(){
a1 = ;
a2 = ;
a3 = ;
a = ;
}
void fun(){
cout << a << endl; //正确
cout << a1 << endl; //正确
cout << a2 << endl; //正确
cout << a3 << endl; //正确
}
public:
int a1;
protected:
int a2;
private:
int a3;
};
class B : private A{
public:
int a;
B(int i){
A();
a = i;
}
void fun(){
cout << a << endl; //正确,public成员。
cout << a1 << endl; //正确,基类public成员,在派生类中变成了private,可以被派生类访问。
cout << a2 << endl; //正确,基类的protected成员,在派生类中变成了private,可以被派生类访问。
// cout << a3 << endl; //错误,基类的private成员不能被派生类访问。
}
};
int main(){
B b();
cout << b.a << endl; //正确。public成员
// cout << b.a1 << endl; //错误,private成员不能在类外访问。
// cout << b.a2 << endl; //错误, private成员不能在类外访问。
// cout << b.a3 << endl; //错误,private成员不能在类外访问。
return ;
}
编译输出:
10
注意:在类里面不写是什么类型,默认是 private 的。
include <iostream>
using namespace std;
class Line{
int a;
};
int main() {
Line line;
line.a = ;
cout<<line.a<<endl;
}
这个是会报错的,应该改成:
class Line{
public:
int a;
};
C++解析二的更多相关文章
- C#使用zxing,zbar,thoughtworkQRcode解析二维码,附源代码
最近做项目需要解析二维码图片,找了一大圈,发现没有人去整理下开源的几个库案例,花了点时间 做了zxing,zbar和thoughtworkqrcode解析二维码案例,希望大家有帮助. zxing是谷歌 ...
- Java生成与解析二维码
1.下载支持二维码的jar包qrcode.jar和qrcode_swetake.jar, 其中qrcode_swetake.jar用于生成二维码,rcode.jar用于解析二维码,jar包下载地址(免 ...
- java 生成和解析二维码
public class QRCode { /** * 解析二维码(QRCode) * @param imgPath * @return */ public static String decoder ...
- java代码生成二维码以及解析二维码
package com.test; import java.awt.Color; import java.awt.Graphics2D; import java.awt.image.BufferedI ...
- asp.net C#生成和解析二维码代码
类库文件我们在文件最后面下载 [ThoughtWorks.QRCode.dll 就是类库] 使用时需要增加: using ThoughtWorks.QRCode.Codec;using Thought ...
- Fixflow引擎解析(二)(模型) - BPMN2.0读写
Fixflow引擎解析(四)(模型) - 通过EMF扩展BPMN2.0元素 Fixflow引擎解析(三)(模型) - 创建EMF模型来读写XML文件 Fixflow引擎解析(二)(模型) - BPMN ...
- java二维码之利用谷歌的zxing生成二维码,解析二维码
生成二维码 @RequestMapping("/123") public void test(HttpServletRequest request,HttpServletRespo ...
- ZXing 生成、解析二维码图片的小示例
概述 ZXing 是一个开源 Java 类库用于解析多种格式的 1D/2D 条形码.目标是能够对QR编码.Data Matrix.UPC的1D条形码进行解码. 其提供了多种平台下的客户端包括:J2ME ...
- Java生成、解析二维码
今天遇到需求,使用Java生成二维码图片,网搜之后,大神们早就做过,个人总结一下. 目标:借助Google提供的ZXing Core工具包,使用Java语言实现二维码的生成和解析. 步骤如下: 1.m ...
- (转)ZXing解析二维码
1 ZXing解析二维码 上一篇文件已经说过如何用ZXing进行生成二维码和带图片的二维码,下面说下如何解析二维码 二维码的解析和生成类似,也可以参考google的一个操作类 BufferedImag ...
随机推荐
- 记录flask使用模板时出现的“Internal Server Error”错误
在看<Flask Web开发实战:入门.进阶与原理解析(李辉著 )>时照着书上的代码抄了一遍,然后运行时发现一直出现以下的错误 书上的源代码如下 watchlist.html <he ...
- d3.select(this)不能用箭头函数
d3中典型的数据绑定片段 const items = svg.selectAll('g') .data(gdfs,(d)=> d.name); const enter = items.enter ...
- 基于QT的中国象棋
基于QT的中国象棋,可实现人人对战,人机对战,联网对战,可显示棋谱,可悔棋. 还有一些小毛病,我之后会找空把这个DEMO重新修改一下上传 链接:https://pan.baidu.com/s/1-eM ...
- gulp自动化打包工具
/** * Created by hasee on 2016/7/5. */var gulp = require('gulp');var sass = require('gulp-sass');//容 ...
- Python全栈开发-Day5-常用模块学习
本节大纲: 模块介绍 time &datetime模块 random os sys shutil shelve xml处理 pyyaml处理 configparser hashlib re正则 ...
- HTML第七章总结
Getting started with CSS 前言 CSS 的 rule 作者做了一个非常形象的比喻,将 CSS 必做 renovate the house,在这里,CSS 包括了三个部分: Se ...
- English trip M1 - PC1 Are you a Model? 你是模特吗? Teacher:Taylor
In this lesson you will learn to talk about jobs. 课上内容(Lesson) What's your partner name? Her name is ...
- DPDK 16.04/16.11.2 默认tx offload是关闭的引起tx vlan offload无效
打开IXGBE调试日志发发现:tx使用ixgbe_xmit_pkts_vec,默认tx offload无效了PMD: ixgbe_set_tx_function(): Using simple tx ...
- find xss
from :http://blog.sina.com.cn/s/blog_68d342d90100nh7b.html 什么是XSS跨站攻击: http://baike.baidu.com/view/5 ...
- linux中的软、硬链接
linux中的软.硬链接 硬链接 硬链接(hard link),如果文件B是文件A的硬链接,则A的inode节点号与B的inode节点号相同,即一个inode节点对应两个不同的文件名,两个文件名指向同 ...