C陷阱与缺陷阅读笔记

简介:

本文主要记录《C陷阱与缺陷》第三章中的一些知识。

一、指针与数组:

C语言数组特点:

(1)C语言中只有一维数组,而且数组的大小必须在编译期就作为一个常数确定下来。由于数组的元素可以是任何类型的对象,当然也可是另外一个数组。这样,要“仿真”出一个多维数组就不是一件难事。

(2)对于一个数组,我们只能够做两件事:确定该数组的大小,以及获得指向改数组下标为0的元素的指针。其他有关数组的操作,哪怕他们乍看上去是以数组下标进行运算的,实际上都是通过指针进行的。换句话说,任何一个数组下标运算都等同于一个对应的指针运算。

 

二、数组溢出:

  数组中实际不存在“溢界”元素的地址位于数组所占内存之后,这个地址可以用于进行赋值和比较;即:对于数组结尾之后的下一个元素,取它的地址是合法的。

 

三、一些运算符性质:

  运算符&&和运算符||首先对左侧操作数求值,只在需要时才对右侧操作数求值;

  运算符 ?: 有三个操作数,在a?b:c中,操作数a首先被求值,根据a的值再求操作数b或c的值;

  逗号运算符 , 首先对左侧操作数求值,然后该值被“丢弃”,再对右侧操作数求值;

  赋值运算符 = 并不保证任何求值顺序。

 

四、判断整数相加溢出

  在无符号算术运算中,没有所谓“溢出”一说。如果算术运算符的一个操作数是有符号整数,“溢出”也不可能发生。

  检查a+b是否溢出:

if((unsigned)a + (unsigned)b > INT_MAX)
    error();
或者:
if(a > INT_MAX - b)
error();

INT_MAX是一个已定义的常量,代表可能的最大正整数值,ANSI C标准在<limits.h> 中定义了 INT_MAX

目录
相关文章
|
存储 自然语言处理 编译器
C陷阱与缺陷
C陷阱与缺陷
67 0
C陷阱与缺陷
|
存储 人工智能 自然语言处理
【C缺陷与陷阱】----语义“陷阱”
那获得该下标为0的元素的指针,如果给这个指针加1,就能得到指向该数组中下一个元素的指针。也就是指针+一个整数得到的还是指针,只不过指针的位置发生改变
109 0
|
编译器 C语言
源于《C陷阱与缺陷》----研究程序死循环问题
所以最后答案应该就是打印了12次xiao tao,然后越界访问出现错误,使arr[10]=0,arr[11]=0了 但最后答案却不是这样。
120 0
|
监控 测试技术
测试思想 什么是软件测试(摘录)
测试思想 什么是软件测试(摘录)
147 0
|
自然语言处理 编译器 C语言
|
自然语言处理 算法 编译器
|
自然语言处理 编译器 C语言
|
存储 算法 测试技术
软件缺陷的概念
软件缺陷(Defect),常常又被叫做Bug。所谓软件缺陷,即为计算机软件或程序中存在的某种破坏正常运行能力的问题、错误,或者隐藏的功能缺陷。缺陷的存在会导致软件产品在某种程度上不能满足用户的需要。IEEE729-1983对缺陷有一个标准的定义:从产品内部看,缺陷是软件产品开发或维护过程中存在的错误、毛病等各种问题;从产品外部看,缺陷是系统所需要实现的某种功能的失效或违背。
|
程序员 C语言
《C语言程序设计进阶教程》一第3章 预防、检测及消除bug
本文讲的是C语言程序设计进阶教程一第3章 预防、检测及消除bug,本节书摘来华章计算机《C语言程序设计进阶教程》一书中的第2章,第2.6.2节, Intermediate C Programming[美] 陆永祥(Yung-Hsiang Lu) 著 徐东 译 译更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1001 0