学习C++的第四天

1、头文件中的 #ifndef/#define/#endif 防止该头文件被重复引用”
//文件路径名:el_1\hello.h

#ifndef _HELLO /////如果没有定义 _HELLO文件

#define _HELLO /////////////那么定义 _HELLO文件

void Hello(void); ////全局函数声明

#endif

2、头文件一般用于存放函数原型

3、类本质上是C语言中结构体的扩充,类中不但可以包含数据成员,还可以包含函数成员,并规定了对类中成员的三级访问权限

在public中声明的成员可以在程序中自己进行访问

在private和protected中声明的成员可以被 此类的成员函数 及 声明为友元的函数所访问

在protected中声明的成员可以被此类派生的类所访问,而在private中声明的成员则不能被此类派生的类所访问

4、

/////rectangle.h////类的声明放在头文件中

class Rectangle  /////定义一个Rectangle 类
{
private:
int length , width , height;   ////长方体的长宽高
public:
Rectangle(int len,int wd,int ht); ////构造函数。。。。。。。构造函数名与类名相同
virtual~Rectangle(void){}     /////析构函数。。。。。。。。析构函数主要用于含有指针的数据成员中释放动态数据成员
int Volume(void);  ///返回长方体体积的函数-----------------------------改动为int Volume(Rectangle oRectangle)
};

///////rectangle.cpp////////类的实现放在源文件中

# include"rectangle.h"

Rectangle::Rectangle(int len, int wd, int ht)
{
length = len;
width = wd;
height = ht;
}

int Rectangle::Volume(void)   -------------------------改为int Rectangle::Volume(Rectangle oRectangle)
{
return length*width*height;----------------------------改为 return oRectangle.length*oRectangle.width*oRectangle.height;
}

///////main.cpp///////////主函数

# include<stdlib.h>
# include<iostream>
# include"rectangle.h" ////提供类Rectangle的声明
using namespace std;

int main(void)
{
Rectangle a(6,8,9);      利用构造函数 构造一个长方体a   此时传入len=6 wd=8 ht=9 然后再传给length  width height

int v = a.Volume();  因为属于Rectangle类 所以需要a.     利用length width height 计算体积 -------------改为a.Volume(a);
cout<<v<<endl;
system("pause");
return 0;
}

改完后等式仍会成立

5、关于 友元

/////rectangle.h////类的声明放在头文件中

class Rectangle
{
private:
int length , width , height;
public:
Rectangle(int len,int wd,int ht);
virtual~Rectangle(void){}
friend int Volume(Rectangle oRectangle);///////加了个friend 意味着该函数并不属于Rectangle类 
};

///////rectangle.cpp////////类的实现放在源文件中

# include"rectangle.h"

Rectangle::Rectangle(int len, int wd, int ht)
{
length = len;
width = wd;
height = ht;
}

int Volume(Rectangle oRectangle) ///////友元函数 已经在Rectangle类中声明过------区别在于该函数不属于Rectangle类
{
return oRectangle.length*oRectangle.width*oRectangle.height;
}

///////main.cpp///////////主函数

# include<stdlib.h>
# include<iostream>
# include"rectangle.h"
using namespace std;

int main(void)
{
Rectangle a(6,8,9);

int v = Volume(a);因为不属于Rectangle类,所以不需要a.
cout<<v<<endl;
system("pause");
return 0;
}

具体大概有下面两种情况需要使用友元函数:(1)运算符重载的某些场合需要使用友元。(2)两个类要共享数据的时候。

1.2.1优点:能够提高效率,表达简单、清晰。

1.2.2缺点:友元函数破环了封装机制,尽量不使用成员函数,除非不得已的情况下才使用友元函数。

6、c++的一大特性就是重载(overload),通过重载可以把功能相似的几个函数合为一个,使得程序更加简洁、高效。在c++中不止函数可以重载,运算符也可以重载。由于一般数据类型间的运算符没有重载的必要,所以运算符重载主要是面向对象之间的。

7、C++的参数传递(传给函数)

<1>传值方式:是默认方式,在调用函数时,将实参的值传递给函数局部存储相应参数的副本,函数对副本操作,只改变副本的值,而不会修改实参的值

<2>引用方式:引用方式需要在形参声明时参数名前加上符号&,在调用函数时,被传递的不是实参的值,而是实参的地址,函数通过地址存取实参。C语言通过指针实现。

将数组作为值参传递时,由于数组名实际表示数组的起始存储地址,传递的是数据第一个元素的地址,这样对数组元素的修改本质是对实参数组元素的修改

void swap(int &a,int &b)------------用引用&传递方式b实现
{
int t;
t = a;
a = b;
b = t;
}--------------------------------------对应swap(u,v)---------------int a=1 ;int &ra = a; 则ra=1;-------ra = ra-1;cout<<a;输出0   引用的值改变能改变实参的值

void swap(int *a,int *b)------------用指针传递方式实现
{
int t;
t = *a;
*a = *b;
*b = t;
}--------------------------------------对应swap(&u,&v)

8、DEVC++出现打开文件失败的情况  有可能是32位机子然后却选择了64位的解决方法(右上角)

9、exit()

虽然现在大多数平台下,直接在 main() 函数里面 return 可以退出程序。但是在某些平台下,在 main() 函数里面 return 会导致程序永远不退出(因为代码已经执行完毕,程序却还没有收到要退出的指令)。换句话说,为了兼容性考虑,在特定的平台下,程序最后一行必须使用 exit() 才能正常退出,这是 exit() 存在的重要价值。

0表示程序已经正常执行完毕,而非0值则表示有错误发生,至于非0值具体为多少则由开发者自己定义,比如1代表输入错误,2代表计算错误之类的

10、有关C++的动态存储分配

通常定义变量(或对象),编译器在编译时都可以根据该变量(或对象)的类型知道所需内存空间的大小,从而系统在适当的时候为他们分配确定的存储空间。这种内存分配称为静态存储分配;

有些操作对象只在程序运行时才能确定,这样编译时就无法为他们预定存储空间,只能在程序运行时,系统根据运行时的要求进行内存分配,这种方法称为动态存储分配。所有动态存储分配都在堆区中进行。

当程序运行到需要一个动态分配的变量或对象时,必须向系统申请取得堆中的一块所需大小的存贮空间,用于存贮该变量或对象。当不再使用该变量或对象时,也就是它的生命结束时,要显式释放它所占用的存贮空间,这样系统就能对该堆空间进行再次分配,做到重复使用有限的资源。

c++中使用new分配的存储单元必须用delete进行释放

new命令的使用格式:

new 被建立对象的数据类型

new 被建立对象的数据类型[分配存储单元个数]------数组

new命令返回指向被建立对象的指针

delete命令的使用格式:

delete 指向被释放对象的指针

delete []指向被释放对象数组的指针

11、在C++中类与结构的区别在于:在结构中默认的访问权限是public  而在类中默认的访问权限是private。除此之外,类与结构是等价的

12、算法应具有以下几种性质:正确性、具体性、有限性、确定性、可读性、健壮性(能对非法数据处理 不应死机或出现异常结果)

时间: 2024-10-10 20:50:54

学习C++的第四天的相关文章

学习php的第四天

今天是学习php的第四天.由于花了一天的时间来装一个系统,而我对这个也并不是很了解,所以就不再赘述.只学习了如何设置链接. 首先是几个定义..表示当前所在目录,src图片地址.加载超链接 <a href=...>.text-decoration意为链接装饰,用于去除下划线. 下面是代码.我用昨天的导航条为基础,给每个标题都设置了链接.代码如下. <html> <head> <title></title> <style> div{hei

20145320《Java程序设计》第3周学习总结(第四章)

20145320<Java程序设计>第3周学习总结(第四章) 教材学习内容总结 对象(Object):存在的具体实体,具有明确的状态和行为 类(Class):具有相同属性和行为的一组对象的集合,用于组合各个对象所共有操作和属性的一种机制 从类看对象:类定义可以视为一个具有类似特性与共同行为的对象的模板,可用来产生对象 从对象看类:类的产生,是从少数实例,推广到大量相似实例的抽象化过程(abstraction) 类是对象的设计图,对象是类的实例,生成对象要先定义类 4.1 类与对象 定义类使用c

马哥学习笔记二十四——分布式复制快设备drbd

DRBD: 主从 primary: 可执行读.写操作 secondary: 文件系统不能挂载 DRBD: dual primay, 双主(基于集群文件系统的高可用集群) 磁盘调度器:合并读请求,合并写请求: Procotol:drbd数据同步协议 A: Async, 异步  数据发送到本机tcp/ip协议栈 B:semi sync, 半同步  数据发送到对方tcp/ip协议 C:sync, 同步  数据到达对方存储设备 DRBD Source: DRBD资源 资源名称:可以是除了空白字符外的任意

义隆单片机学习笔记之(四) 编程及烧录

工具说明: 1.UIDE,编程环境 2.UWriter:烧录软件 下载地址: (见官网) 一 UIDE  1.1 创建工程: 1.2 选择型号: 1.3 编程及编译 二 UWriter 2.1 安装 (Serial number在购买烧录器的时候,从代理经销商处获得!) 2.2 选择目标芯片  2.3 配置选择 (注:由于是OTP,很多功能都是在配置的时候指定,所以这里非常重要.晶振.时钟的选择,延时程序要与之对应: 是否需要保护等,根据自己的需要而定) 编译之后生成的.map文件,详细的描述了

Android学习笔记(十四)——在运行时添加碎片(附源码)

在运行时添加碎片 点击获取源码 将UI分割为多个可配置的部分是碎片的优势之一,但其真正强大之处在于可在运行时动态地把它们添加到活动中. 1.使用上一篇创建的Fragments项目,在main.xml文件中注释掉两个<fragment>元素: 2.在FragmentActivity.java中添加下面的代码: FragmentManager fragmentManager = getSupportFragmentManager();//向活动添加碎片 FragmentTransaction fr

quick-cocos2d-x 学习系列之十四 测试用例

quick-cocos2d-x 学习系列之十四 测试用例 定义变量,创建13个场景名字 local items = { "framework.helper", "framework.native", "framework.display", "framework.crypto", "framework.network", "framework.luabinding", "fra

django学习之Model(四)MakingQuery

上一篇写到MakingQuey中的filter,本篇接着来. 10)-扩展多值的关系 如果对一个ManyToManyField或ForeignKey的表进行filter过滤查询的话,有2中方法可以用.分别是: #1 Blog.objects.filter(entry__headline__contains='Lennon', entry__pub_date__year=2008) #2 Blog.objects.filter(entry__headline__contains='Lennon')

jQuery学习之路(四)之过滤选择器

今天是第四课主要学习过滤选择器 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>lesson4 过滤选择器</title> <link rel="stylesheet" type="text/css" href="css/lesson.css" ></link>

SpringMVC轻松学习-其他常用(四)

Spring MVC 3.0 深入 核心原理 1.      用户发送请求给服务器.url:user.do 2.      服务器收到请求.发现DispatchServlet可以处理.于是调用DispatchServlet. 3.      DispatchServlet内部,通过HandleMapping检查这个url有没有对应的Controller.如果有,则调用Controller. 4.      Controller开始执行. 5.      Controller执行完毕后,如果返回字

UI学习笔记---第十四天数据持久化

一.沙盒机制 每个应用程序位于文件系统的严格限制部分 每个应用程序只能在为该程序创建的文件系统中读取文件 每个应用程序在iOS系统内斗放在了统一的文件夹目录下 沙盘路径的位置 1. 通过Finder查找程序沙盘相对路径 ~/Library/Application Support/iPhone Simulator 2. 通过代码查找程序沙盘相对路径 NSSearchPathForDirectoriesInDomains(NSSearchPathDirectory directory,NSSearc