1、
(1)typedef 声明简称 typedef为现有类型创建一个新的名字。在编程中使用typedef目的一般有两个一个是给变量一个易记且意义明确
的新名字另一个是简化一些比较复杂的类型声明。
比如人们常常使用 typedef 来编写更美观和可读的代码。所谓美观意指 typedef 能隐藏笨拙的语法构造以及平台相关的数据类型从而增强可移植性和以及未来的可维
护性。如何创建平台无关的数据类型隐藏笨拙且难以理解的语法? 使用 typedef 为现有类型创建同义字。 定义易于记忆的类型名 typedef 使用最多的地方是创建易于记忆的类型名用它来归档程序员的意图。类型出现在所声明的变量名字中位于 ”typedef” 关键字右边。例如 typedef int size; 此声明定义了一个 int 的同义字名字为 size。注意 typedef 并不创建新的类型。它仅仅为现有类型添加一个同义字。你可以在任何需要 int 的上下文中使用 size
void measure(size * psz);
size array[4];
size len = file.getlength();
std::vector vs;
(2)标准函数 strcmp()有两个‘const char ‘类型的参数。因此它可能会误导人们象下面这样声明 mystrcmp() int mystrcmp(const pstr, const pstr); 这是错误的按照顺序‘const pstr’被解释为‘char const’一个指向 char 的常量指针而不是‘const char ‘指向常量 char 的指针。这个问题很容易解决 typedef const char cpstr; int mystrcmp(cpstr, cpstr); // 现在是正确的记住不管什么时候只要为指针声明 typedef那么都要在最终的 typedef 名称中加一个 const以使得该指针本身是常量而不是对象。
(3)问题出在你不能在声明中有多个存储类关键字。因为符号 typedef 已经占据了存储类关键字的位置在 typedef 声明中不能用 register或任何其它存储类关键字。
(4)typedef 有另外一个重要的用途那就是定义机器无关的类型例如你可以定义一个叫 REAL 的浮点类型在目标机器上它可以i获得最高的精度 typedef long double REAL; 在不支持 long double 的机器上该 typedef 看起来会是下面这样 typedef double REAL; 并且在连 double 都不支持的机器上该 typedef 看起来会是这样、
typedef float REAL; 你不用对源代码做任何修改便可以在每一种平台上编译这个使用 REAL类型的应用程序。唯一要改的是 typedef 本身。在大多数情况下甚至这个微
小的变动完全都可以通过奇妙的条件编译来自动实现。
2、内存中数据的存储
计算机要处理的信息是多种多样的,如十进制数、文字、符号、图形、音频、视频等,这些信息在人们的眼里是不同的。但对于计算机来说,它们在内存中都是一样的,都是以二进制的形式来表示。要想学习编程,就必须了解二进制,它是计算机处理数据的基础。
内存条是一个非常精密的部件,包含了上亿个电子元器件,它们很小,达到了纳米级别。这些元器件,实际上就是电路;电路的电压会变化,要么是 0V,要么是 5V,只有这两种电压。5V 是通电,用1来表示,0V 是断电,用0来表示。所以,一个元器件有2种状态,0 或者 1。我们通过电路来控制这些元器件的通断电,会得到很多0、1的组合。例如,8个元器件有 28=256 种不同的组合,16个元器件有 216=65536 种不同的组合。虽然一个元器件只能表示2个数值,但是多个结合起来就可以表示很多数值了。
我们可以给每一种组合赋予特定的含义,例如,可以分别用 1101000、00011100、11111111、00000000、01010101、10101010 来表示 C、语、言、中、文、网 这几个字,那么结合起来 1101000 00011100 11111111 00000000 01010101 10101010 就表示”C语言中文网“。一般情况下我们不一个一个的使用元器件,而是将8个元器件看做一个单位,即使表示很小的数,例如 1,也需要8个,也就是 00000001。1个元器件称为1比特(Bit)或1位,8个元器件称为1字节(Byte),那么16个元器件就是2Byte,32个就是4Byte,以此类推:
8×1024个元器件就是1024Byte,简写为1KB;
8×1024×1024个元器件就是1024KB,简写为1MB;
8×1024×1024×1024个元器件就是1024MB,简写为1GB。
现在,你知道1GB的内存有多少个元器件了吧。我们通常所说的文件大小是多少KB、多少MB,就是这个意思。
单位换算:
8 Bit = 1Byte
1024Byte = 1KB
1024KB = 1MB
1024MB = 1GB
1024GB = 1TB
你看,在内存中没有abc这样的字符,也没有gif、jpg这样的图片,只有0和1两个数字,计算机也只认识0和1。所以,计算机使用二进制,而不是我们熟悉的十进制,写入内存中的数据,都会被转换成0和1的组合。
学习C语言的一些知识点(来源网络,陆续补充)

最新推荐文章于 2025-09-09 17:42:29 发布
