程序设计与数据结构

在程序设计过程中,很多开发人员在没有全局思维的把控,科学、系统的组织以及严密的测试与部署下,单纯地为开发而开发,而代码的优劣,直接决定了软件的质量和...

作者: 周立功、周攀峰
出版日期: 2017-05-04

作者简介

周立功, 1964 年3 月生,湖南人,广州周立功单片机科技有限公司和广州致远电子有限公司创始人。教授,著名嵌入式系统技术专家, 先后出版了40 余本嵌入式系统专业技术大学教材与专著,荣获省级教学成果一等奖2 项和国家级教学成果二等奖1 项。现任广东省计算机学会单片机与嵌入式系统分会副理事长。

内容简介

《程序设计与数据结构》重点阐述了三大方向内容:
1. C语言学习中的痛点:针对当前工程师在C语言学习中的痛点,如指针函数与函数指针,如何灵活应用结构体等。从变量的三要素(变量的类型,变量的值和变量的地址)出发,采用推导的方式,深入浅出的分析了广大C程序员学习和开发中遇到的难点。
2. 从方法论的高度对C语言在数据结构和算法方面的应用进行了深入讲解和阐述。
3. 讲解了绝大多数C程序员开发生涯中没有考虑过的问题。

目录

第1章 程序设计基础

1.1 思想的力量

1.1.1 过程主题

1.1.2 思维差异

1.1.3 语言的鸿沟

1.2 变量与指针

1.2.1 变量

1.2.2 值的表示形式

1.2.3 数据的输入输出

1.3 指针变量与指针的指针

1.3.1 声明与访问

1.3.2 变量的访问

1.3.3 指针的指针

1.4 简化表达式

1.4.1 逻辑表达式

1.4.2 综合表达式

1.4.3 条件表达式

1.5 共性与可变性分析

1.5.1 分析方法

1.5.2 建立抽象

1.5.3 建立接口

1.5.4 实现接口

1.5.5 使用接口

1.6 数组与指针

1.6.1 数组与指针

1.6.2 数组的访问形式

1.6.3 泛型编程

1.7 数组的数组与指针

1.7.1 指向数组的指针

1.7.2 二维数组

1.7.3 将二维数组作为函数参数

1.8 字符串与指针

1.8.1 字符常量

1.8.2 字符串常量

1.8.3 指针数组

1.9 动态分配内存

1.9.1 malloc()函数

1.9.2 calloc()函数

1.9.3 free()函数

1.9.4 realloc()函数

第2章 程序设计技术

2.1 函数指针与指针函数

2.1.1 函数指针

2.1.2 指针函数

2.1.3 回调函数

2.1.4 函数指针数组

2.2 结构体

2.2.1 内存对齐

2.2.2 内含基本数据类型

2.2.3 内置函数指针

2.2.4 嵌套结构体

2.2.5 结构体数组

2.3 栈与函数返回

2.3.1 堆栈

2.3.2 入栈与出栈

2.3.3 函数的调用与返回

2.4 栈ADT

2.4.1 不完全类型

2.4.2 抽象数据类型

2.4.3 开闭原则(OCP)

第3章 算法与数据结构

3.1 算法问题

3.1.1 排序

3.1.2 搜索

3.1.3 O记法

3.2 单向链表

3.2.1 存值与存址

3.2.2 数据与p_next分离

3.2.3 接口

3.3 双向链表

3.3.1 添加结点

3.3.2 删除结点

3.3.3 遍历链表

3.4 迭代器模式

3.4.1 迭代器与容器

3.4.2 迭代器接口

3.4.3 算法的接口

3.5 哈希表

3.5.1 问题

3.5.2 哈希表的类型

3.5.3 哈希表的实现

3.6 队列ADT

3.6.1 建立抽象

3.6.2 建立接口

3.6.3 实现与使用接口

第4章 面向对象编程

4.1 OO思想

4.1.1 职责转移

4.1.2 OO机制

4.1.3 OO收益

4.2 类与对象

4.2.1 对象

4.2.2 类

4.2.3 封装

4.3 继承与多态

4.3.1 抽象

4.3.2 继承

4.3.3 职责驱动设计

4.3.4 多态性

4.4 虚函数

4.4.1 二叉树

4.4.2 表达式算术树

4.4.3 虚函数

4.5 状态机

4.5.1 有限状态机

4.5.2 State模式

4.5.3 动作类

4.6 框架与重用

4.6.1 框架

4.6.2 契约

4.6.3 建立契约

4.6.4 框架与重构


附录A 参考文献

查看全部信息 ∨