c语言知识结构

2024-05-07 01:18
文章标签 语言 知识结构

本文主要是介绍c语言知识结构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

c++的四个部分:
c语言
面向对象的c++
模板c++
STL
开发环境和类库:
Qt
MFC
wxWidgets
cocos2d(游戏引擎)

  1. c语言的数据类型包括基本类型,构造类型以及指针类型。
  2. 基本类型包括数值型数据和空类型(void)。数值型数据包括整形、字符型以及浮点型。因为字符型用ASCII码表示,所以也是数值型。字符型也包括有符号以及无符号。整型包括有符号和无符号。并且都有整型(int)、短整型(short)以及长整型(long)之分。整型要注意溢出的问题。浮点型要注意精度和取值范围。*浮点型包括单精度(float),双精度(double)以及长双精度(long double)*。
  3. 构造类型 枚举类型(enum),数组类型(type[]),结构体类型(struct)以及共用体类型(union)。数组类型是单一基类型的,并且是行序优先的顺序存储。
    数组的顺序存储方式:由于计算机内存时一维的,多维数组的元素应排成线性序列后存入存储器。
    行优先顺序:将数组元素按行向量排列,第i+1个行向量紧接在第i个行向量后面。eg:a11a12a13…a1na21a22a23…a2n
    pascal和c语言中数组按照行优先顺序存储。行优先推广到多维数组,可以规定先排最右的下标。
    列优先顺序:将数组元素按列向量排列,第i+1个列向量紧接在第i个列向量后面。eg:a11a21a31…an1a12a22a32…an2
    FORTRAN语言中,数组按列优先顺序存储。列优先顺序推广到多维数组,可规定为先排最左的下标

结构体类型中各数据成员连续存储,成员类型可以不同。结构体主要成员运算符主要有.和->。其中->用于指针。

共用体类型 不同数据成员占用同一个存储空间。
4. 指针类型 指针即地址。可以指向基本单元,也可以指向数组元素,其中指向数组元素的时候下标法和指针法可以互换使用。指针的最大价值在于可以直接操作内存空间,即动态分配空间。包括分配空间(malloc)和释放空间(free)。
5. c语言的运算中的运算量包括常量和变量。其中常量包括符号常量(用#define定义的常量)以及字面常量(‘a’,25)。变量按照作用范围包括全局变量以及局部变量。变量按照存储类型分有自动变量(auto)寄存器变量(register)静态变量(static)以及外部变量(extern)。运算中的类型转换包括自动类型转换以及强制类型转换。
6. c语言中国的函数要先声明后定义然后再调用。或者先定义后调用。比较推荐第一种方式。函数的返回值有两层含义:一个是求值结果的返回,还有一个是程序流程整个的返回。函数包括系统函数,例如:数学函数:cmath 输入输出函数 :cstdio 时间函数:ctime以及随机数函数:cstdlib。
7. c语言的输入输出是基于数据流的输入输出。包括格式化 输入输出(printf scanf 格式控制符),字符(串)的输入输出(getchar,putchar,gets,puts),利用文件的输入输出,以及stdio.h。
8. c语言中的利用文件的输入输出:文件包括文本文件以及二进制文件等。对文件的操作分类包括读写以及添加(a)。对文件的操作方式包括随机存取以及顺序存取。文件的实现方式包括缓存系统(高级)以及非缓存系统(低级)。利用文件包括打开(fopen)文件、读写文件((字符(串)读写:fgetc fputc fgets fputs) 格式化读写(fprintf fscanf)数据块读写( fread fwrite更适用于二进制文件)文件定位(rewind fseek ftell)文件检测(feof 是否到达文件结尾 ferror 文件读取发生什么错误))、关闭文件(fclose)(应该养成在程序终止之前关闭所有文件的习惯,如果不关闭文件将丢失数据。因为如前所述,在向文件写数据时,是先将数据输到缓冲区,待缓冲区充满后才正式输出给文件,如果当数据未充满缓冲区,而程序结束运行,就会将缓冲区中的数据丢失,用 fclose 函数关闭文件,可以避免这个问题,它先把缓冲区中的数据输出到磁盘文件,然后才释放文件指针变量。)
9. c语言中设备即文件。对键盘、显示器的操作和对存取文件、通过网络传送文件的操作是没有二义的。一个程序在运行的时候回自动打开标准输入输出文件指针包括stdin(标准输入设备),stdout(标准输出设备)以及stderr(标准错误输出设备)。常用设备包括CON(控制台),COMn(n可以为1,2,3,代表计算机上的键盘),PNT(打印机),这些都相当于文件名。
10. 问题的求解策略:迭代、穷举、分治法(二分法)、递归、贪心、回溯等。
11. 算法积累有:求最值,查找,排序,辗转相除求最大公约数,进制转换以及字符串处理等。

这篇关于c语言知识结构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/965924

相关文章

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.

Go语言使用sync.Mutex实现资源加锁

《Go语言使用sync.Mutex实现资源加锁》数据共享是一把双刃剑,Go语言为我们提供了sync.Mutex,一种最基础也是最常用的加锁方式,用于保证在任意时刻只有一个goroutine能访问共享... 目录一、什么是 Mutex二、为什么需要加锁三、实战案例:并发安全的计数器1. 未加锁示例(存在竞态)

C语言自定义类型之联合和枚举解读

《C语言自定义类型之联合和枚举解读》联合体共享内存,大小由最大成员决定,遵循对齐规则;枚举类型列举可能值,提升可读性和类型安全性,两者在C语言中用于优化内存和程序效率... 目录一、联合体1.1 联合体类型的声明1.2 联合体的特点1.2.1 特点11.2.2 特点21.2.3 特点31.3 联合体的大小1

Go语言使用select监听多个channel的示例详解

《Go语言使用select监听多个channel的示例详解》本文将聚焦Go并发中的一个强力工具,select,这篇文章将通过实际案例学习如何优雅地监听多个Channel,实现多任务处理、超时控制和非阻... 目录一、前言:为什么要使用select二、实战目标三、案例代码:监听两个任务结果和超时四、运行示例五

C语言中%zu的用法解读

《C语言中%zu的用法解读》size_t是无符号整数类型,用于表示对象大小或内存操作结果,%zu是C99标准中专为size_t设计的printf占位符,避免因类型不匹配导致错误,使用%u或%d可能引发... 目录size_t 类型与 %zu 占位符%zu 的用途替代占位符的风险兼容性说明其他相关占位符验证示