好的,我已经了解了您的问题。请问您需要我为您解答什么问题呢?
第 19 章 特殊工具与技术 标签: C++Primer 学习记录 运行时类型识别 枚举类型 类成员指针 ---- ---- 19.1 控制内存分配 当使用一条 new表达式时string *sp = new string("value");,实际执行了三步操作。 第一步,new表达式调用一个名为 operator new的标准库函数,来分配一块足够大的,原始的,未命名的内存空间,以便存储特定类型的对象(或者对象的数组)。 第二步,编译器运行相应的构造函数,以构造这些对象,并为其传入初始值。 第三步
将这篇文章在作业部落中的链接放置于此,对格式有轻微强迫的童鞋,请移步这里。 第 19 章 特殊工具与技术 标签: C++Primer 学习记录 运行时类型识别 枚举类型 类成员指针 ---- 第 19 章 特殊工具与技术 19.1 控制内存分配 19.2 运行时类型识别 19.3 枚举类型 19.4 类成员指针 19.5 嵌套类 19.6 union:一种节省空间的类 19.7 局部类 19.8 固有的不可移植的特性 ---- 19.1 控制内存分配 当使用一条 new表达式时string *sp =
重载这两个运算符与重载其他运算符的过程大不相同。想要真正重载new和delete的方法,首先要对new表达式和delete表达式的工作机制足够了解:
被const修饰的变量是不能改变的 const修饰变量时,必须在声明变量的同时给出初始化(类中的const成员变量不一样)
这一章介绍了平时可能不太会用到的C++特性,内容比较杂。其中有类似枚举,联合,局部类这样之前就用过的特性,也有类成员指针,局部类这样新了解的特性。其中个人觉得19.1对new和delete的讨论很重要,19.2的RTTI介绍也扩展了我们编码的自由度,最后19.8的位域让我们可以更方便地进行位运算。
数组(array)是一种数据格式,能够存储多个同类型的值。每个值都存储在一个独立的数组元素中,计算机在内存中依次存储数组的各个元素。
以#号开头的都是编译预处理指令,它们不是C语言的成分,但是C程序离不开它们,#define用来定义一个宏,程序在预处理阶段将用define定义的来内容进行了替换。因此在程序运行时,常量表中并没有用define定义的常量,系统不为它分配内存。define定义的常量,预处理时只是直接进行了替换,,它用来将一个标识符定义为一个字符串,该标识符被称为宏名,被定义的字符串称为替换文本。,因此在编译时它不对宏的定义进行检查,作用域不影响对常量的访问 。它的常量值只能是字符串或数字。 该命令有两种格式:一种是简单的常量宏定义, 另一种是带参数的宏定义。
For循环的另一形式: 先定义一个函数,例如int p[100];然后for(auto a:p),:的左面定义一个变量,右边则是数组的名字,这条语句的意思便是将p数组的所有的元素输出来。作用就是可以在不知道数组的大小的时候将数组中所有的元素输出。 指针:定义指针变量:指针的类型 指针名;使指针指向一个变量: 指针名=&变量名;变量的类型和指针的类型应该相同,此时*指针就相当与这个变量,例如 int *a=&m; *a=k;则是将k的值赋给m;另外还可以定义指向指针的指针:例如int**p=*a; 定义const指针: 1.coonst 类型 *指针;此时指针所指向的可以是一个整型变量,也可以是一个常变量,但不能通过这个指针来改变对应的变量的值,但是变量本身可以改变(不通过指针)。 2. 类型 const 指针;这种方式定义的指针地址只能是固定的不可以再进行改变。 3. .const 类型const 指针:指针指向的内存不能改变,并且指针指向的值不能进行改变。动态对象:动态对象不像静态对象,动态对象是没有名字的,通过指针间接操作。 new 定义变量:int *p=new 动态对象的类型(其中动态对象的初始值);删除时:delete 指针;定义数组:int *p=new int[100];删除:delete [] 指针;定义指针:需要调用头文件删除之后的指针不可以在进行使用。 引用: 左值引用 &代表左值引用,左值引用的是表达式结束后仍存在的值,既是左值引用的必有地址,左值引用时可以引用变量,但变量必须先进行定义。例如 int a=1;int&p=a; 右值引用: &&代表的是右值引用,右值引用可以引用表达式或者是具体的某个值,例如0;此类都是无法取址的,像例如a++是右值引用,而像++a则是左值引用。 结构体: 定义的方式:Struct 结构体名字 { 结构体成员 };切记最后有一个;。定义一个结构体变量直接可以 结构体名字 变量名。输入输出时要通过指针来输出结构体中的各元素;例如:struct kl{ Int a; };输出时则是cout<<kl.a;联合: 联合的定义方式与结构体相似,用union代替struct。但是联合应用时只可使用一个成员。 枚举: 定义时使用enum定义的是不限定作用域的枚举,而enum class或enum struct定义的则是限定作用域的枚举,限定作用域的优点是可以在不同的作用域内设定同样的成员名字,而不限定作用域的枚举则不能这样。 定义时例如:enum light{red,green,yellow};默认的这三个的值是0,1,2;也可以自己设定枚举中成员的值;例 enum light{red=2,green=6,yellow=88};枚举的其中一个用处可以在switch中使用,case后面所跟得值也可以是枚举定义的成员,从而更明了表示一种可能。 数组: 定义方式1 数组类型 数组名[数组大小]; 2 数组类型 数组名[]={数组中元素}; 3 char 数组名[]=”字符串”; 数组包括的元素为字符串中的字符和最后一个元素\0;切记一个数组不可以被另一个数组初始化。多为数组的初始化也可以,类似于一维数组的初始化方式。通过for语句和数组元素的下标访问数组元素时可以定义下标为size_t类型,然后通过for循环的方式访问数组中的所有元素。for(int e:数组名)这种方式来访问数组中的所有元素,若要改变数组中所有的元素需将语句修改为for(int &e:数组名)。也可以通过指针来访问数组的元素,定义数组的时候数组名的地址自定义为数组中第一个元素的地址,则访问数组的所有元素时可以通过for(int p=a;p<p+10;p++) { Cout<<*p; } decltype关键字可以提取变量的类型来定义另一个变量的类型, 例:int a; decltype(a) l;这样l的类型就和a的类型是相同的。 也可以通过迭代器来访问数组中的每一个元素。头文件是,有两个关键词,begin(),end(),括号内是数组名。 字符串 Char类型的字符串在头文件有几个函数, strlen()返回字符串的长度。Strcmp(p1,p2)判断p1,p2的关系,若等于则返回0,大于则返回正值,小于则返回负值。 Strcat(p1,p2)将后者附加到前者后面,并返回前者的值。 Strcpy(p1,p2)将后者复制到前者后面,并返回前者的值。 String:头文件。定义:string n;若是定义相同的多个元素组成的字符串,则可以string l(n,’l’);函数:getline(is,s)通过输入流把其中的一行输入到s中。 s.empty()判断字符串s 是否为空。s.size();返回s中字符个数。 s.c.str() 将字符串转换为字符数组。s
本文最后更新于2022年02月26日,已超过2天没有更新。如果文章内容或图片资源失效,请留言反馈,我会及时处理,谢谢!
与int a,b;类似,定义完成后,student1和student2即为struct Student类型的变量。
本书介绍的“后台开发”指的是“服务端的网络程序开发”,从功能上可以具体描述为:服务器收到客户端发来的请求数据,解析请求数据后处理,最后返回结果。
成员指针概述: 当初始化一个这样的指针时,我们令其指向类的某个成员,但是不指定该成员所属的对象 直到使用成员指针时,才提供成员所属的对象 成员指针是指可以指向类的非静态成员的指针 一般情况下,指针指向一个对象,但是成员指针指向的是类的成员,而不是类的所创建出的对象 类的静态成员不属于任何对象,因此无需特殊的指向静态成员的指针,指向静态成员的指针与普通指针没有任何区别 成员指针的类型囊括了类的类型以及成员的类型: 下面我们定义一个类,作为本文讲解的基础: class Screen { public: type
struct Student { int age; struct Student stu; };
注意:函数就是功能。每一个函数用来实现一个特定的功能。函数的名字应反映出它代表的功能,这样代码的可读性会大大提升
相信在坐的很多人,都在学Python,对于Python来说有self,类比到C++中就是this指针,那么下面一起来深入分析this指针在类中的使用!
//C#文件流写文件,默认追加FileMode.Append string msg = “okffffffffffffffff”; byte[] myByte = System.Text.Encoding.UTF8.GetBytes(msg); using (FileStream fsWrite = new FileStream(@”D:\1.txt”, FileMode.Append)) { fsWrite.Write(myByte, 0, myByte.Length); }; //c#文件流读文件 using (FileStream fsRead = new FileStream(@”D:\1.txt”, FileMode.Open)) { int fsLen = (int)fsRead.Length; byte[] heByte = new byte[fsLen]; int r = fsRead.Read(heByte, 0, heByte.Length); string myStr = System.Text.Encoding.UTF8.GetString(heByte); Console.WriteLine(myStr); Console.ReadKey(); }
引入: 有时需要将不同类型的数据组合成一个有机的整体,以便于引用。 例如,一个学生有学号、姓名、性别、年龄、地址等属性,需要定义int num; char name[20]; char sex; int age; int char addr[30];等属性,如下:
1.程序运行知识 1.1 内存布局和分配方式 C程序的内存布局如下: 静态存储区:存储全局变量和static变量,通常在程序编译期间已经分配好了。 BSS段:存放未初始化的static变量和全局变量
介绍 作为Android开发人员,会java是必须的,但是一般从事android业务逻辑开发的对C/C++的了解估计仅限于大学里不走心的课程。。。所以参考视频和资料小结一下JNI所需的c语言知识~ 基本数据类型 数据类型 boolean byte char short int long double float void signed unsigned java 1 1 2 2 4 8 8 4 无 无 C 无 无 1 2 4 4 8 4 有符号 无符号 sizeof()函数是用来测量某个类型所占的字节
**************************************************************************************************************************************************************************************************************** 操作符解释: 1,算术操作符: ‘+’、‘-’、‘*’、‘/’、‘%’ %取模操作符只能用于整数, /除法操作符,两个操作数均是整数时为整数除法,有一个是浮点数则执行浮点数除法。 如:int a = 6/5;//->a==1 double b = 6/5;//->b==1.000000 double c = 6.0/5//->c==1.200000,即实际运算与定义的储存类型无关 2,移位操作符 左移‘<<’、右移‘>>’ 左移操作符: 如: int a=2; int b = a << 1;//a向左移动一位,结果存入变量b中,结果b为4 正整数2在内存中存放的补码为: 00000000000000000000000000000010 向左移动一位,左边的首位0去掉,右边的缺一位补0:00000000000000000000000000000100 ->4(十进制) 右移操作符: 右移时分为算数右移和逻辑右移。 算数右移:右边丢弃,左边补符号位。 逻辑右移:右边丢弃,左边补0。 如:int a = -10; int b = a >> 1;//a向右移动一位,结果存入变量b中 正整数10在内存中的补码为11111111111111111111111111110110//若为负数则原码与补码不同。 算术右移: 11111111111111111111111111111011 ->-5 逻辑右移: 01111111111111111111111111111011 ->2,147,483,643 对移位操作符移动负数位,这时C语言未定义的,不要使用。 3,位操作符 按位与‘&’、按位或‘|’、按位异或‘^’ 位解释为二进制的一位。 &按位与,全为1时结果才为1,其他情况结果均为0 如:int a = 3;// 00000000000000000000000000000011 int b = 5;// 00000000000000000000000000000101 int c = a & b;// 00000000000000000000000000000001->1(十进制) eg:找出一个整数的二进制的1的个数。 #include <stdio.h> int main(){ int a=1; int cnt=0; for(int i=0; i<31; i++){ if((a&1) == 1){//整数的二进制数的1的个数 cnt++; } a=a >> 1; } printf("%d\n",cnt); return 0; } |按位或,全为0时结果才为0,其他情况结果均为1 如:int a = 3;// 000
这篇是第四部分的总结,大致上就是回看了最后的3篇笔记并且重新翻翻书梳理了一下,内容基本都是从前面的章节复制来的。
1.*p++和(*p)++的区别 *p++是先取值,然后将指针地址执行++操作 (*p)++是先取值,然后对(*p)这个值进行++操作 2.枚举变量enum的值如何计算 enum{a,b=5,c,d=4,e}; cout<<a<<b<<c<<d<<e 结果为0 5 6 4 5 因为在枚举变量的值默认为前一个变量的值加1,而第一个枚举值没有被赋值,所以默认为0 3.static的应用 (1)局部静态变量 存储空间分配不同,auto类型分配在栈上, 属于动态存储类别, 占动
在编程中,特别是在像C和C++这样的语言中,结构体(struct)是一种用于创建复合数据类型的工具。结构体允许你将多个不同类型的数据项组合成一个单一的实体。这对于组织和管理数据非常有用,尤其是当你需要处理复杂的数据集时。
①同一个内存段可以用来存放几种不同类型的成员,但在每一瞬间只能存放其中一个成员而不是几个
大家好,又见面了,我是你们的朋友全栈君。一、消息钩子的概念 1、基本概念 Windows应用程序是基于消息驱动的,任何线程只要注册窗口类都会有一个消息队列用于接收用户输入的消息和系统消息。为了拦截消息,Windows提出了钩子的概念。钩子(Hook)是Windows消息处理机制中的一个监视点,钩子提供一个回调函数。当在某个程序中安装钩子后,它将监视该程序的消息,在指定消息还没到达窗口之前钩子程序先捕获这个消息。这样就有机会对此消息进行过滤,或者对Windows消息实现监控。 2、分类 消息钩子分为局部钩子和全局钩子。局部钩子是指仅拦截指定一个进程的指定消息,全局钩子将拦截系统中所有进程的指定消息。 3、实现步骤 使用钩子技术拦截消息通常分为如下几个步骤:
函数包括:函数首部(第一行)+函数体(‘{’+内容+‘}‘),函数体=函数声明(即函数原型)+执行部分。
以前看过的源码里,也有用到过.call的时候,今天的一个例子,也碰到了,为了彻底的明白这个的用法,Google了一下,找到了一些比较有用的资料。
============================================================================= 涉及到的知识点有: 一、结构体 1、定义结构体struct和初始化、2、访问结构体中的成员、3、结构体的内存对齐模式、4、结构体中元素的位字段、 5、结构体中的数组、6、结构体的嵌套、7、结构体的赋值、8、通过指针访问结构体成员(即指向结构体的指针)、 9、通过指针访问结构体数组(即指向结构体数组的指针)、10、结构体变量的指针成员与浅拷贝、深拷贝的操作(即结构中的数组成员和指针成员)。 二、联合体 三、枚举类型 1、c语言中枚举的定义、2、改变枚举的默认值。 四、typedef 课堂练习:在堆中处理结构体的指针成员。 ============================================================================= ============================================================================= 之前学过的数据类型叫做基本数据类型,也叫做单一数据类型。 例如:整型、浮点型、指针类型。
在一些返回集合数据的接口中,我们经常能看到IEnumerable接口的身影。那什么是Enumerable呢?首先它跟C#中的enum关键字所表达的意思是不同的, 从翻译上来看:可枚举的,展开来说就是它的数据是一枚一枚可以让我们列举出来。就像人们排队去打疫苗,排队的人就是可枚举的,他们有的开车,有走着,有早有晚全都按照先来后到的顺序排好队,当医生开始进行打疫苗的工作时,他并不关心有多少人在排队,也不关心是否有人迟到,当然也不能越过第一个人让其后边的人先进来打,他只能说“请下一个人进来打疫苗”,如果没人响应医生就等着,直到有人进来开始接种,当前这个人完成接种后,医生继续叫下一个人,直到所有人都打完疫苗。这样的情景在编程中就体现为对Enumerable数据的操作。
作为一名有追求的程序猿,一定是希望自己写出的是最完美的、无可挑剔的代码。那完美的标准是什么,我想不同的设计师都会有自己的一套标准。而在实际编码中,如何将个人的标准愈发完善,愈发得到同事的认可,一定需要不断积累。如何积累,一定是从细微处着手,观摩优秀的代码,学习现有的框架,汲取前人留下的智慧。
在C语言中,结构体是一种用户自定义的数据类型,它允许开发者将不同类型的变量组合在一起,形成一个新的数据类型。结构体可以包含多个成员变量,每个成员可以是不同的数据类型,例如整型、字符型、浮点型等。
1. 程序运行模式 当我们将一个程序交给CPU去执行的时候,CPU只会执行main函数中的代码,别的地方的代码是不会执行的,因此如果想要在CPU中执行程序就必须要在main函数中从上到下一句一句执行代码,并且只有在上一句执行完毕之后才会执行下一句。 mian是程序的入口,当mian函数中的代码执行完毕之后就会自动结束,所以也是出口。 2. 计算机三大件 CPU : 中央处理器,处理数据的,负责计算,协调其他硬件相互和谐的工作。 内存 :存储数据 ,临时,效率高,通过电路存储,电子式。 硬盘 :存储数据 ,
对static限定的改变必然会造成范围性的影响,而const限定的只是变量或对象自身
A.对值类型的分配。 虚拟内存中存在一个叫堆栈的区域,我们并不知道它到底在地址空间的什么地方,在一般开发过程中也没有必要知道,我们知道的是值类型就分配于此。值类型在堆栈上分配的时候,是自上而下填充的,也就是从高内存地址开始填充。 比如当前的堆栈指针为100000,这表明它的下一个自由存储空间从99999开始,当我们在C#中声明一个int类型的变量A,因为int类型是四个字节,所以它将分配在99996到99999这个存储单元中。如果我们接着声明double变量B(8字节),该变量将分配在99988到99995这个存储单元。 如果代码运行到他们的作用域之外,这时候A和B两个变量都将被删除,此时的顺序正好相反,先删除变量B,同时堆栈指针会递增8,也就是重新指向到99996这个位置;接下来删除变量A,堆栈指针重新指向10000。如果两个变量是同时声明的。如int A,B,此时我们并不知道A和B的分配顺序,但是编译器会确保他们的删除顺序正好和分配顺序相反。
&在c++中的一种作用为取出当前变量在内存的逻辑地址 *在c++中的一种作用为取出当前逻辑地址对应的内存空间的值 c++中提供指针变量存储对象的地址,指针的运算会被编译器优化为地址的运算,比如一个int类型的指针 p+1的值实际是p指向的地址+1个int所占空间大小后的逻辑地址 指针语法为 typename * variable,比如
Email relay 和Email access分别用了什么协议? 答:SMTP,POP3 1:多态是如何实现绑定的? 多态的绑定可以分为运行是多态和编译时多态 ● 编译时的多态性 编译时的多态性是
2)switch(expert1)中的expert1只能是常整数(整数表达式或枚举常量),不能是变量
使用struct关键词,可以创造新的类型。 关键词struct取自structure,中文翻译为结构。 这种由多个不同的数据类型组成的类型,被称为结构。
类和结构体是一种多功能且灵活的构造体。通过使用与现存常量、变量、函数完全相同的语法来在类和结构体当中定义属性和方法以添加功能。
假设要统计一个班上同学的身高和姓名 , 使用两个数组一个存放同学姓名,另一个存放同学身高,两个数组的类型分别为char 和 float类型 , 每个同学对应自己的身高 ,对身高进行排序,然后在一个个核对每个同学的身高,这样就会变得很麻烦,如果数据不止这两种,有体重、血型、臂展等等 , 这样数组与数组之间的下标就不再具有关联性。于是C语言就定义了一个不同类型数据的集合的数据结构 ————结构体。
要记住结构体是一种类型,它的地位是和int这些类型是一样的,我们能用int做的事情,也可以用结构体做。唯一不同的是,结构体是通过我们自己去定义的,而int这些类型是我们c语言内置的类型
int arr[10] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
介绍一些判断类型的模板。 下列模板中包 含于头文件<type_traits>(C++11起引入)。 检查类型是否为void is_void 检查类型是否为std::nullptr_t C++14起引入。 is_null_pointer 检查类型是否为整数类型 is_integral 检查类型是否为浮点类型 is_floating_point 检查类型是否为数组类型 is_array 检查类型是否为枚举类型 is_enum 检查类型是否为联合类型 is_union 检查类型是否为非联合的
在Windows系统中,通过网络邻居可以方便地查看本地网络中的共享资源和计算机。通过使用Windows API中的一些网络相关函数,我们可以实现枚举网络邻居信息的功能,获取连接到本地网络的其他计算机的相关信息。本文将介绍一个简单的C++程序,使用Windows API枚举网络邻居信息,并获取对端名称、本机名称、主机名称以及主机IP等信息。
Hi,大家好!本文讨论了所有开发人员都应该学习和使用的一系列 C++11特性。该语言和标准库中有很多新增功能,本文只是触及了皮毛。但是,我相信其中一些新功能应该成为所有C++开发人员的日常工作。
人与人之间交流需要通过语言,我们中国人之间交流用普通话,英国人用英语,俄国人用俄语等。
大家好,很高兴能和大家再次相遇。今天我们要分享探讨的内容是初识C语言的末尾——结构体,希望经过咱们本篇的探讨之后,各位朋友能对这个知识点有更进一步的理解。废话不多说,咱们直接开始吧。
常量表达式(const expression)是指值不会改变并且在编译过程就能得到计算结果的表达式。显然,字面值属于常量表达式,用常量表达式初始化的const对象也是常量表达式。
常见的Bool、Int、Double、String、Array、Dictionary等常见类型都是结构体。
领取专属 10元无门槛券
手把手带您无忧上云