目录: 12.1 数值概论

12.2整数

12.3浮点数

12.4 字符和字符串

12.5布尔变量

12.6枚举类型

12.7具名常量

12.8数组

12.9创建你自己的类型

12.1   数值概论

基本数据类型是组成数据的块

一 、避免使用神秘数值

二、如果需要,可以使用硬编码的0和1

三、预防除零错误

四、使类型转换变得明显

五、避免混合类型的比较

六、注意编译器的警告

12.2 整数

一、检查整数除法

二、检查整数溢出

三、检查中间结果溢出

12.3 浮点数

一、避免数量级相差巨大的数之间的加减运算

二、避免等量判断

三、处理舍入误差问题:使用精度更高的数值进行计算

四、检查语言和函数库对特定数据类型的支持

12.4字符和字符串

一、避免使用神秘字符和神秘字符串

二、避免 off-by-one错误

三、了解你的语言和开发环境是如何支持Unicode的

四、 在程序生命期中尽早决定国际化、本地化策略

五、如果你知道只需要支持一种文字的语言,请考虑使用ISO8895字符集

六、如果你需要支持多种语言,请使用Unicode

七、 采用某种一致的字符串类型转换策略

C语言中的字符串

八、注意字符串指针和字符数组之间的差异

九、 把C—style字符串的长度声明为CONSTANT+1

十、用null 初始化字符串以避免无结束符的字符串

十一、用字符数组取代C中的指针

十二、 用strncpy()取代 strcpy以避免无结束符的字符串

12.5 布尔变量

一、用布尔变量对程序加以文档说明

二、用布尔变量来简化复杂的判断

三、如果需要的话,创建你自己的布尔类型

12.6枚举类型

一、用枚举类型来提高可读性

二、用枚举类型提高可靠性

三、 用枚举类型来简化修改

四、将枚举类型作为布尔变量的替代方案

五、检查非法数值

六、定义出枚举的第一项和最后一项,以便用于循环边界

七、把枚举类型的第一个元素留作非法值

八、明确定义项目代码编写标准中第一个和最后一个元素的使用规则,并且在使用时保持一致

九、警惕给枚举元素明确赋值而带来的失误

12.7 具名常量

一、数据声明中使用具名常量

二、避免使用文字量,即使是安全的

三、用具有适当作用域的变量或类来模拟具名常量

四、统一地使用具名常量

12.8 数组

一、确认所有的数组下标都没有超出数组的边界

二、考虑用容器(集合、栈、队列)来取代数组,或者将数组作为顺序化结构来处理

三、检查数组的边界点

四、如果数组是多维的,确认下标的使用顺序是正确的

五、提防下标串话

六在C中结合ARRAY_LENGTH()宏来使用数组

12.9创建你自己的类型

原则:1、给所创建的类型取功能导向的名字

2、避免使用预定义类型

3、不要重定义一个预定义的类型

4、定义替代类型以便于移植

第十二章Fundamental Data Types 基本数据类型的更多相关文章

  1. PRML读书会第十二章 Continuous Latent Variables(PCA,Principal Component Analysis,PPCA,核PCA,Autoencoder,非线性流形)

    主讲人 戴玮 (新浪微博: @戴玮_CASIA) Wilbur_中博(1954123) 20:00:49 我今天讲PRML的第十二章,连续隐变量.既然有连续隐变量,一定也有离散隐变量,那么离散隐变量是 ...

  2. 《Android群英传》读书笔记 (5) 第十一章 搭建云端服务器 + 第十二章 Android 5.X新特性详解 + 第十三章 Android实例提高

    第十一章 搭建云端服务器 该章主要介绍了移动后端服务的概念以及Bmob的使用,比较简单,所以略过不总结. 第十三章 Android实例提高 该章主要介绍了拼图游戏和2048的小项目实例,主要是代码,所 ...

  3. 《Django By Example》第十二章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:第十二章,全书最后一章,终于到这章 ...

  4. 第二十二章 Django会话与表单验证

    第二十二章 Django会话与表单验证 第一课 模板回顾 1.基本操作 def func(req): return render(req,'index.html',{'val':[1,2,3...]} ...

  5. 《汇编语言 基于x86处理器》第十二章浮点数部分的代码

    ▶ 书中第十二章的程序,主要讲了 FPU 的指令和浮点数计算的过程 ● 代码,简单的 32 为浮点数测试 INCLUDE Irvine32.inc INCLUDE macros.inc .data f ...

  6. 《Django By Example》第十二章(终章) 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:第十二章,全书最后一章,终于到这章 ...

  7. 进击的Python【第十二章】:mysql介绍与简单操作,sqlachemy介绍与简单应用

    进击的Python[第十二章]:mysql介绍与简单操作,sqlachemy介绍与简单应用 一.数据库介绍 什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,每个数 ...

  8. R in action读书笔记(16)第十二章 重抽样与自助法之 置换检验

    第十二章:重抽样与自助法 本章,我们将探究两种应用广泛的依据随机化思想的统计方法:置换检验和自助法 12.1 置换检验 置换检验,也称随机化检验或重随机化检验. 有两种处理条件的实验,十个受试者已经被 ...

  9. python 教程 第二十二章、 其它应用

    第二十二章. 其它应用 1)    Web服务 ##代码 s 000063.SZ ##开盘 o 26.60 ##最高 h 27.05 ##最低 g 26.52 ##最新 l1 26.66 ##涨跌 c ...

随机推荐

  1. Spring泛型依赖注入

    1.定义基础仓库 package com.spring.generic.di; public class BaseRepository<T> { } 2.定义基础服务层   package ...

  2. iOS 启动画面 代码自定义

    先来看一个可能会遇到的问题: 如果你已经删除了xcode为你的项目自动生成的LaunchScreen.storyboard, 然后你在测试你的app的时候发现,屏幕里出现了黑色的区域,如上图(画红线的 ...

  3. React使用jquery方式动态获取数据

    好久没写react了,今天有空写一下来react实现实时请求数据,并刷新数据的小demo. 首先我还是选择了jquery方式中自带的ajax获取数据,首先要引用所需的js包 接下来要写一个自定义的js ...

  4. fork()创建子进程

    fork()系统调用是Unix下以自身进程创建子进程的系统调用,一次调用,两次返回,如果返回是0,则是子进程,如果返回值>0,则是父进程(返回值是子进程的pid) 在fork()的调用处,整个父 ...

  5. 【改】iOS学习之键盘类型UIKeyboardType

    关于 UITextField 的键盘是可以自定义的,正好在一个代码用这个,就总结一下. 在 UITextField 中有一个 keyboardType 属性,它的类型是一个枚举值,下面就是枚举值和对应 ...

  6. Leetcode jump Game II

    Given an array of non-negative integers, you are initially positioned at the first index of the arra ...

  7. 性能分析神器VisualVM

    VisualVM 是一款免费的,集成了多个 JDK 命令行工具的可视化工具,它能为您提供强大的分析能力,对 Java 应用程序做性能分析和调优.这些功能包括生成和分析海量数据.跟踪内存泄漏.监控垃圾回 ...

  8. jQuery 利用 parent() parents() 寻找父级 或祖宗元素

    $(this).parent().parent().parent().parent().parent().remove(); //此方法通过parent()一级一级往上找   $(this).pare ...

  9. [IOS]Swift使用SVGKit的记录

    最近打算使用swift和SVGkit做一个app,遇到了好多状况,对于初学者的几个概念,一个是静态库,第二个是oc和swift混编,第三个是xcode6b4的类库不齐全. 首先是SVGKit的GitH ...

  10. SqlServer 笔记一 某表中每个月的产品数量(DATENAME() 与 DATEPART()、YEAR())

    1.使用 DATENAME() 函数 SELECT DATENAME(yyyy, [columnName]) + '/' + DATENAME(mm, [columnName]) AS monthDa ...