【C++学习笔记一】C++类和对象详解

类定义是以关键字class开头,后面跟类的名称。主体是包含在一对花括号中。类定义后必须跟着一个分号或一个声明列表

类的对象的公共数据成员可以使用直接成员访问运算符.来访问。需要注意的是,私有的成员和受保护的成员不能直接使用成员访问运算符来访问

类成员函数

类的成员函数是指把定义和原型写在类定义内部的函数。类成员函数是类的一个成员,他可以操作类的任意对象,可以访问对象中的所有成员。

成员函数可以定义在类定义内部,或者单独使用范围解析运算符::来定义,在类定义中定义的成员函数把函数声明为内联的,即使没有使用inline标识符。声明必须写在类的内部。

在类外定义的格式为:

数据类型 类名::方法名(参数列表) {}

类访问修饰符

数据封装是面向对象编程的一个重要特点,它防止函数直接访问类类型的内部成员。类成员的访问限制是通过在类主体内部对各个区域标记访问修饰符public private protected来指定的。

一个类可以有多个访问修饰符标记区域,每个标记区域在下一个标记区域开始之前或者遇到类主体结束右括号之前都是有效的

成员和类的默认访问修饰符是private

  • 公有public:公有成员在程序中类的外部是可访问的。您可以不适用任何成员函数来设置和获取公有变量的值。
  • 私有private:已有成员变量或函数在类的外部是不可访问的,甚至是不可查看的,只有类和友元函数可以访问私有成员。默认情况下,类对所有成员都是私有的。
    实际操作中,我们一般会在私有区域定义数据,在公有区域定义相关的函数,以便在类的外部也可以调用这些函数。
  • 保护protected:保护成员变量或函数与私有成员十分相似,但有一点不同,保护成员在派生类(即子类)中是可访问的。

对于一个空类,编译器默认产生4个成员函数:默认构造函数、析构函数、拷贝构造函数和赋值函数。

还有关于继承中访问权限问题:传送门

类构造函数&析构函数

类的构造函数时类的一种特殊的成员函数,他会在每次创建类的新对象时执行。
构造函数的名称与类名是完全相同的,并且不会返回任何返回类型,也不会返回void,构造函数可用于为某些成员变量设置初始值。如果需要,构造函数也可以带有参数。

当类中未定义构造函数时,编译器会自动假设存在两个默认构造函数。

类名:类名() {}
类名:类名(const 类名&a){} //没有什么用

如果自己定义了构造函数,则默认的构造函数不会存在。

构造函数可以被重载。

可以使用初始化列表来初始化字段,例如:

class C
{T X,Y,Z;C();
}
C::C(T a,T b,T c):X(a),Y(b),Z(c)
{...
}

类的析构函数是类的一种特殊的成员函数,他会在每次删除所创建的对象时执行。析构函数的名称与类对 名称是完全相同的,只是在前面加了~作为前缀,他不会返回任何值,也不能带任何参数。

析构函数不能重载,如果没有写析构函数,C++会自动帮我们写一个析构函数。

拷贝构造函数

拷贝构造函数是一种特殊的构造函数,在创建对象时,是使用同一类中之前创建的对象来初始化新创建的对象。拷贝构造函数通常用于

  • 复制对象把它作为参数传递给函数
  • 复制对象,并从函数返回这个对象
  • 通过使用另一个同类型的对象来初始化新建的对象(拷贝初始化)

如果类没有定义拷贝构造函数,编译器会自行定义一个,如果类带有指针变量,并由动态分配内存,则它必须有一个拷贝构造函数(否则会引发错误)。
最常见的形式如下:

classname (const classname &obj)
{//主体
}

这里对拷贝初始化进行进一步的说明:

A x(y); //直接初始化,如果是类类型将调用构造函数
A x=y; //拷贝初始化,如果是类类型将调用拷贝构造函数

值包含类类型成员或者内置类型(不包含指针类型)成员的类无须显式地定义拷贝构造函数也可以进行拷贝。当类的成员函数包含指针或者是成员表示在构造函数中分配的其他资源时,就必须定义拷贝构造函数。

友元函数

友元函数是定义在类外部,但是有权访问类的所有私有成员和保护成员,如果不是static成员则需要对象作为参数,如果访问static成员则不需要参数的函数,尽管友元函数的原型有在类的定义中出现过,但是友元函数并不是成员函数。
友元可以是一个函数,该函数称为友元函数;友元可以是一个类,该类称为友元类。在这种情况下,整个类及其所有成员都是友元。如果要声明函数为一个友元函数,需要在类定义中该函数原型前使用关键字friend.

class A
{friend 返回类型 函数名B(参数列表);
};
返回类型 B(参数列表)//请注意,A不是任何类的成员函数
{}
int main()
{A a; B(参数列表);//对友元函数的调用不需要对象和类
}

声明类B的所有成员为另一个类A的友元则需要在A的定义专用加上以下声明:

class A
{...friend class B;
}

同样在友元类中我们也可以通过对象参数访问保护和私有成员。

内联函数

内联函数通常与类一起使用,如果一个函数是内联的,那么在编译时,编译器会把该函数的代码副本放置在每个调用该函数的地方。对内联函数进行修改都要重新编译函数的所有客户端,因为编译器需要更换一次所有的代码。

如果想要把一个函数定义为内联函数,则需要在函数定义前面放置关键字inline如果已定义的函数多于十行,编译器会忽略inline限定符

在类定义中的函数都是内联函数,即使没有使用内联函数。

  • 在内联函数内不允许使用循环语句和开关语句

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/383834.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言实现的简单的线程池

http://www.linuxidc.com/Linux/2013-01/77619.htm 有时我们会需要大量线程来处理一些相互独立的任务,为了避免频繁的申请释放线程所带来的开销,我们可以使用线程池。下面是一个C语言实现的简单的线程池。 头文件: 1: #ifndef THREAD_POOL_H_…

C++获取当前时间

可以使用windowsAPI直接获取。 例如&#xff1a; #include<windows.h> #include<cstdio>using namespace std;int main() {SYSTEMTIME now;GetLocalTime(&now);printf("现在是%02d时%02d分%02d秒\n",now.wHour,now.wMinute,now.wSecond);printf(&…

成员函数后面加上const的作用

const表示成员函数不会修改类中的数据成员。 规则&#xff1a; 在类中被const 声明的函数只能访问const 函数&#xff0c;而非const 函数可以访问任意成员函数。在成员函数中不管数据是否具有const 属性&#xff0c;编译器检查的的是是否有修改&#xff08;赋值&#xff0c;自…

简单Linux C线程池

http://www.cnblogs.com/venow/archive/2012/11/22/2779667.html 大多数的网络服务器&#xff0c;包括Web服务器都具有一个特点&#xff0c;就是单位时间内必须处理数目巨大的连接请求&#xff0c;但是处理时间却是比较短的。在传统的多线程服务器模型中是这样实现的&#xff1…

C++创建对象:栈和堆的区别

首先我们应该了解栈和堆的差别&#xff1a; 详细信息&#xff1a;传送门 栈相当于函数自带的存储空间&#xff0c;在windows下一般为2M,在Linux下一般为8M&#xff0c;存取速度稍微快一点。堆是系统的空间&#xff0c;相对较大&#xff0c;一般为2G&#xff0c;效率稍微慢一点…

IO多路复用之poll总结

http://www.cnblogs.com/Anker/p/3261006.html 1、基本知识 poll的机制与select类似&#xff0c;与select在本质上没有多大差别&#xff0c;管理多个描述符也是进行轮询&#xff0c;根据描述符的状态进行处理&#xff0c;但是poll没有最大文件描述符数量的限制。poll和select同…

【C++学习笔记二】C++继承

继承 继承允许我们一句另一个类来定义一个类&#xff0c;这使得继承和维护一个程序变得更加容易&#xff0c;也达到了重用代码功能和提高执行效率的效果。 一般格式为&#xff1a; class 派生类名 :访问修饰符 基类名{};其中访问修饰符是public protected private中的一个&a…

处理大并发之二 对epoll的理解,epoll客户端服务端代码

http://blog.csdn.net/wzjking0929/article/details/51838370 序言&#xff1a; 该博客是一系列的博客&#xff0c;首先从最基础的epoll说起&#xff0c;然后研究libevent源码及使用方法&#xff0c;最后研究nginx和node.js&#xff0c;关于select,poll这里不做说明&#xff0c…

C++基类指针指向派生类(指针)

我们常用基类指针指向派生类对象来实现多态性。 私有继承不允许基类指针指向派生类 基类指针只能访问到基类中含有的公有成员。 当用基类指针指向派生类对象在动态分配堆上内存的时候&#xff0c;析构函数必须是虚函数! 成员如果是数据成员的话访问的是基类的版本&#xff…

C++虚继承中构造函数和析构函数顺序问题以及原理

多重继承的问题&#xff1a;多个类B,C,…继承同一个类A导致如果X继承了B,C,…那么在X中将还有多个A中成员的拷贝&#xff0c;如果想要访问A中的成员如果不加名字空间将会导致二义性&#xff0c;这种拷贝大多是没有实际意义的&#xff0c;为了避免这种空间浪费&#xff0c;C有虚…

一个简单的linux线程池

http://blog.csdn.net/wzjking0929/article/details/20312675 线程池&#xff1a;简单地说&#xff0c;线程池 就是预先创建好一批线程&#xff0c;方便、快速地处理收到的业务。比起传统的到来一个任务&#xff0c;即时创建一个线程来处理&#xff0c;节省了线程的创建和回收的…

【C++学习笔记三】C++多态、抽象(接口)

当类之间存在多种层次结构&#xff0c;并且类之间通过继承关联时就会用到多态。 虚函数在子类中的覆盖版本和该函数在基类中的原始版本必须有相同的函数签名、函数名、形参名、常属性。如果返回值为非类类型&#xff0c;则必须相同&#xff0c;如果是类类型A的指针或者引用&am…

C++重载和重写的条件以及重写后对基类函数的覆盖

重载&#xff1a;同一个类中名字相同&#xff0c;参数列表不同的方法构成重载函数&#xff0c;和返回值没有关系。这就意味着就算返回值不同&#xff0c;只要名字相同参数列表相同编译器还是会报错&#xff0c;觉得一函数被定义了两次。 重写&#xff1a;派生类中只要函数名字…

C++静态成员和静态方法

在类中&#xff0c;静态成员可以实现多个对象之间共享数据&#xff0c;同时保证了安全性。静态数据对该类的所有对象是公有的&#xff0c;存储一处供所有对象使用。 注意&#xff1a; 静态成员定义时需要在前面加上关键字static静态成员必须初始化且必须在类外进行&#xff0…

基于epoll的简单的http服务器

http://blog.csdn.net/fangjian1204/article/details/34415651 http服务器已经可以处理并发连接&#xff0c;支持多个客户端并发访问&#xff0c;每个连接可以持续读写数据&#xff0c;当然&#xff0c;这只是一个简单的学习例子&#xff0c;还有很多bug&#xff0c;发表出来只…

C++单例模式简单实现

有时候我们需要某个类只能被实例化一次&#xff0c;并且其他类都可以访问到这个类&#xff0c;就需要这种设计模式。 例如我们想要做个资源管理器&#xff0c;显然这个管理器只能有一个。 这种模式有很多实现方式&#xff0c;这里介绍最简单的一种&#xff0c;想要了解更多可…

Linux C++ 实现线程池

http://blog.csdn.net/qq_25425023/article/details/53914609 线程池中的线程&#xff0c;在任务队列为空的时候&#xff0c;等待任务的到来&#xff0c;任务队列中有任务时&#xff0c;则依次获取任务来执行&#xff0c;任务队列需要同步。 Linux线程同步有多种方法&#xff…

C++制表符

制表符的转义字符为\t&#xff0c;一般情况下长度为8个空格&#xff0c;这里的8个指的是从上一个字符串的开头开始算&#xff0c;往后数8个&#xff0c;不够的话就补空格。 如果前面的字符串的长度大于等于8个&#xff0c;例如前面字符串的长度为x,那么就会补(8-x%8)个空格 例…

C++派生类含有成员对象构造函数析构函数顺序

参考博客&#xff1a;传送门1 当类中含有对象成员时&#xff1a; 类的构造函数要包含对成员对象的初始化&#xff0c;如果构造函数的成员初始化列表没有包含对成员对象的初始化&#xff0c;系统会自动调用成员对象的无参构造函数。顺序上&#xff1a;先调用成员对象的构造函数…

c,c++中字符串处理函数strtok,strstr,strchr,strsub

http://blog.csdn.net/wangqing_12345/article/details/51760220 1&#xff0c;字符串切割函数 函数原型&#xff1a;char *strtok(char *s, char *delim); 函数功能&#xff1a;把字符串s按照字符串delim进行分割&#xff0c;然后返回分割的结果。 函数使用说&#xff1a; 1…