【C++初阶】类与对象(上)
温馨提示:这篇文章已超过405天没有更新,请注意相关的内容是否还可用!
类与对象(上)
- 1.面向过程和面向对象初步认识
- 2.类的引入
- 3.类的定义
- 4.类的访问限定符及封装
- 4.1 访问限定符
- 4.2 封装
- 5.类的作用域
- 6.类的实例化
- 7.类对象模型
- 7.1 如何计算类对象的大小
- 7.2 结构体内存对齐规则
- 8.this指针
- 8.1 this指针的引出
- 8.2 this指针的特性
- 8.3. C语言和C++实现Stack的对比
1.面向过程和面向对象初步认识
C语言是面向过程的,关注的是过程,分析出求解问题的步骤,通过函数调用逐步解决问题。
C++是基于面向对象的,关注的是对象,将一件事情拆分成不同的对象,靠对象之间的交互完成
2.类的引入
C语言结构体中只能定义变量,在C++中,结构体内不仅可以定义变量,也可以定义函数。比如:之前在数据结构初阶中,用C语言方式实现的栈,结构体中只能定义变量;现在以C++方式实现,会发现struct中也可以定义函数。
typedef int DataType; struct Stack { void Init(size_t capacity) { _array = (DataType*)malloc(sizeof(DataType) * capacity); if (nullptr == _array) { perror("malloc申请空间失败"); return; } _capacity = capacity; _size = 0; } void Push(const DataType& data) { // 扩容 _array[_size] = data; ++_size; } DataType Top() { return _array[_size - 1]; } void Destroy() { if (_array) { free(_array); _array = nullptr; _capacity = 0; _size = 0; } } DataType* _array; size_t _capacity; size_t _size; }; int main() { Stack s; s.Init(10); s.Push(1); s.Push(2); s.Push(3); cout // 类体:由成员函数和成员变量组成 }; // 一定要注意后面的分号 public: void Init(int year) { // 这里的year到底是成员变量,还是函数形参? year = year;// } private: int year; }; // 所以一般都建议这样 class Date { public: void Init(int year) { _year = year; } private: int _year; }; // 或者这样 class Date { public: void Init(int year) { mYear = year; } private: int mYear; }; //成员函数——显式基本信息 void showInfo(); //成员变量 char* _name;//姓名 char* _sex;//性别 int _age;//年龄 }; cout Person._age = 100; // 编译失败:error C2059: 语法错误:“.” return 0; } public: void f1() {} private: int _a; }; // 类中仅有成员函数 class A2 { public: void f2() {} }; // 类中什么都没有---空类 class A3 {}; int main() { cout public: void Init(int year, int month, int day) { _year = year; _month = month; _day = day; } void Print() { cout Date d1, d2;//定义两个日期类 d1.Init(2022, 1, 11);//给d1初始化化 d2.Init(2022, 1, 12);//给d2初始化 d1.Print();//调用Print函数 d2.Print();//调用Print函数 return 0; } public: void Init(int year, int month, int day) { _year = year; _month = month; _day = day; } void Print() { cout // cout private: char _ch; int _a; }; int main() { Date d1; Date d2; d1.Init(2023, 10, 7); d2.Init(2022, 10, 7); // 不能显示写this相关实参和形参 d1.Print(); d2.Print(); //d1.Print(&d1); //d2.Print(&d2); return 0; } public: void Print() { cout A* p = nullptr; p-Print(); return 0; } public: void PrintA() { cout A* p = nullptr; p-PrintA(); return 0; } DataType* array; int capacity; int size; }Stack; void StackInit(Stack* ps) { assert(ps); ps-array = (DataType*)malloc(sizeof(DataType) * 3); if (NULL == ps-array) { assert(0); return; } ps-capacity = 3; ps-size = 0; } void StackDestroy(Stack* ps) { assert(ps); if (ps-array) { free(ps-array); ps-array = NULL; ps-capacity = 0; ps-size = 0; } } void CheckCapacity(Stack* ps) { if (ps-size == ps-capacity) { int newcapacity = ps-capacity * 2; DataType* temp = (DataType*)realloc(ps-array, newcapacity * sizeof(DataType)); if (temp == NULL) { perror("realloc申请空间失败!!!"); return; } ps-array = temp; ps-capacity = newcapacity; } } void StackPush(Stack* ps, DataType data) { assert(ps); CheckCapacity(ps); ps-array[ps-size] = data; ps-size++; } int StackEmpty(Stack* ps) { assert(ps); return 0 == ps-size; } void StackPop(Stack* ps) { if (StackEmpty(ps)) return; ps-size--; } DataType StackTop(Stack* ps) { assert(!StackEmpty(ps)); return ps-array[ps-size - 1]; } int StackSize(Stack* ps) { assert(ps); return ps-size; } int main() { Stack s; StackInit(&s); StackPush(&s, 1); StackPush(&s, 2); StackPush(&s, 3); StackPush(&s, 4); printf("%d\n", StackTop(&s)); printf("%d\n", StackSize(&s)); StackPop(&s); StackPop(&s); printf("%d\n", StackTop(&s)); printf("%d\n", StackSize(&s)); StackDestroy(&s); return 0; } public: void Init() { _array = (DataType*)malloc(sizeof(DataType) * 3); if (NULL == _array) { perror("malloc申请空间失败!!!"); return; } _capacity = 3; _size = 0; } void Push(DataType data) { CheckCapacity(); _array[_size] = data; _size++; } void Pop() { if (Empty()) return; _size--; } DataType Top() { return _array[_size - 1]; } int Empty() { return 0 == _size; } int Size() { return _size; } void Destroy() { if (_array) { free(_array); _array = NULL; _capacity = 0; _size = 0; } } private: void CheckCapacity() { if (_size == _capacity) { int newcapacity = _capacity * 2; DataType* temp = (DataType*)realloc(_array, newcapacity * sizeof(DataType)); if (temp == NULL) { perror("realloc申请空间失败!!!"); return; } _array = temp; _capacity = newcapacity; } } private: DataType* _array; int _capacity; int _size; }; int main() { Stack s; s.Init(); s.Push(1); s.Push(2); s.Push(3); s.Push(4); printf("%d\n", s.Top()); printf("%d\n", s.Size()); s.Pop(); s.Pop(); printf("%d\n", s.Top()); printf("%d\n", s.Size()); s.Destroy(); return 0; }
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!




