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++解析二的更多相关文章

  1. C#使用zxing,zbar,thoughtworkQRcode解析二维码,附源代码

    最近做项目需要解析二维码图片,找了一大圈,发现没有人去整理下开源的几个库案例,花了点时间 做了zxing,zbar和thoughtworkqrcode解析二维码案例,希望大家有帮助. zxing是谷歌 ...

  2. Java生成与解析二维码

    1.下载支持二维码的jar包qrcode.jar和qrcode_swetake.jar, 其中qrcode_swetake.jar用于生成二维码,rcode.jar用于解析二维码,jar包下载地址(免 ...

  3. java 生成和解析二维码

    public class QRCode { /** * 解析二维码(QRCode) * @param imgPath * @return */ public static String decoder ...

  4. java代码生成二维码以及解析二维码

    package com.test; import java.awt.Color; import java.awt.Graphics2D; import java.awt.image.BufferedI ...

  5. asp.net C#生成和解析二维码代码

    类库文件我们在文件最后面下载 [ThoughtWorks.QRCode.dll 就是类库] 使用时需要增加: using ThoughtWorks.QRCode.Codec;using Thought ...

  6. Fixflow引擎解析(二)(模型) - BPMN2.0读写

    Fixflow引擎解析(四)(模型) - 通过EMF扩展BPMN2.0元素 Fixflow引擎解析(三)(模型) - 创建EMF模型来读写XML文件 Fixflow引擎解析(二)(模型) - BPMN ...

  7. java二维码之利用谷歌的zxing生成二维码,解析二维码

    生成二维码 @RequestMapping("/123") public void test(HttpServletRequest request,HttpServletRespo ...

  8. ZXing 生成、解析二维码图片的小示例

    概述 ZXing 是一个开源 Java 类库用于解析多种格式的 1D/2D 条形码.目标是能够对QR编码.Data Matrix.UPC的1D条形码进行解码. 其提供了多种平台下的客户端包括:J2ME ...

  9. Java生成、解析二维码

    今天遇到需求,使用Java生成二维码图片,网搜之后,大神们早就做过,个人总结一下. 目标:借助Google提供的ZXing Core工具包,使用Java语言实现二维码的生成和解析. 步骤如下: 1.m ...

  10. (转)ZXing解析二维码

    1 ZXing解析二维码 上一篇文件已经说过如何用ZXing进行生成二维码和带图片的二维码,下面说下如何解析二维码 二维码的解析和生成类似,也可以参考google的一个操作类 BufferedImag ...

随机推荐

  1. [原][osgEarth][JSBSim]重新整理使用JSBSim飞机动力模拟的使用

    JSBSim是一个模拟飞机飞行空气动力学的,这些都不用深入理解,只要知道自己程序怎么和JSBSim交互就行了 我使用的是JSBSim-Win32-0.9.13 原理:改写jsbsim的FGInput ...

  2. 学习笔记24—win10环境下python版libsvm的安装

    1.前言 由于毕业设计需要用到libsvm,所以最近专心于配置libsvm,曾经尝试过在matlab中安装,但是没有成功.最终在Python环境中完成安装. 2.LIBSVM介绍 LIBSVM 是台湾 ...

  3. 学习笔记3—matlab中load特殊用法

    1.在matlab中 ,infro.mat中存有很多子矩阵(比如:mean_FA.mat, mean_e1.mat和 mean_e2.mat),调出某一个矩阵时,命令行为:load([path,'\' ...

  4. Go使用protobuf

    WIN7 + Go1.9.2+protobuf3.5.1 1.首先定义一个用于测试的proto文件test.proto,内容如下: syntax = "proto3"; packa ...

  5. idataway_前端代码规范

    1.前后端json对接的规范. 前后端的json代码规范 result ={ success:”true”,//true表示成功,false表示失败. data:{}, //数据 errorCode: ...

  6. win10如何一键开启关闭windows Defender(亲测有效)

    win10如何一键开启关闭windows Defender(亲测有效) 一.总结 一句话总结:各种找资料如何开启关闭都没用,直接下载软件简单方便 软件 因为我关windows defender是用的一 ...

  7. springboot---->错误: 找不到或无法加载主类

    刚开始是往上面箭头指出的方向去找问题的原因,但是试了各种方法后问题还是没有解决,于是乎我把焦点转去查看eclipsede控制台处: 主要的错误提示如下: Archive for required li ...

  8. 练习 配置WCF服务

    http://blog.csdn.net/suntanyong88/article/details/8203572   目录(?)[+] 1OrderTrackWindowsKZT   控制台应用 程 ...

  9. Selenium自动化测试框架入门整理

    ​​关注嘉为科技,获取运维新知 本文主要针对Selenium自动化测试框架入门整理,只涉及总体功能及框架要点介绍说明,以及使用前提技术基础要求整理说明.作为开发人员.测试人员入门参考. 本文参考:Se ...

  10. drf 认证、权限、限流、过滤、排序、分页器

    认证Authentication 准备工作:(需要结合权限用) 1. 需要使用到登陆功能,所以我们使用django内置admin站点并创建一个管理员. python manage.py creates ...