学习笔记(C++Primer)--易错点总结(Chapter2)
2.1.2Type Conversions(1/10/2017)
1.If we assign an out-of-range value to an object of unsigned type, the result is
the remainder of the value modulo
the number of values the target type can
hold. For example, an 8-bit unsigned char can hold values from 0 through
255, inclusive. If we assign a
value outside this range, the compiler assigns the
remainder of that value modulo 256.
Therefore, assigning –1 to an 8-bit
unsigned char gives that object the value 255.
2. If
we assign an out-of-range value to an object of signed type, the result is
undefined.
The program might appear to work, it might crash, or it might
produce
garbage values.
3.Advice:
Avoid Undefined and Implementation-Defined Behavior
Undefined
behavior results from errors that the compiler is not required (and
sometimes
is not able) to detect. Even if the code compiles, a program that
executes
an undefined expression is in error.
Unfortunately,
programs that contain undefined behavior can appear to
execute
correctly in some circumstances and/or on some compilers. There is
no
guarantee that the same program, compiled under a different compiler or
even
a subsequent release of the same compiler, will continue to run
correctly.
Nor is there any guarantee that what works with one set of inputs
will
work with another.
Similarly,
programs usually should avoid implementation-defined behavior,
such
as assuming that the size of an int is a fixed and known value. Such
programs
are said to be nonportable. When the program is moved to another
machine,
code that relied on implementation-defined behavior may fail.
Tracking
down these sorts of problems in previously working programs is,
mildly
put, unpleasant.
4. The
compiler applies these same type conversions when we use a value of one
arithmetic
type where a value of another arithmetic type is expected. For example,
when
we use a nonbool value as a condition (§ 1.4.1, p. 12), the arithmetic value is
converted
to bool in the same way that it would be converted if we had assigned
that
arithmetic value to a bool variable:
int i = 42;
if (i) //
condition will evaluate as true
i = 0;
If
the value is 0, then the condition is false; all other (nonzero) values yield
true.
By
the same token, when we use a bool in an arithmetic expression, its value
always
converts to either 0 or 1. As a result, using a bool in an arithmetic
expression
is
almost surely incorrect.
5. Caution:
Don’t Mix Signed and Unsigned Types
Expressions
that mix signed and unsigned values can yield surprising results
when
the signed value is negative. It is essential to remember that signed
values
are automatically converted to unsigned. For example, in an
expression
like a * b, if a is -1 and b is 1, then if both a and b are ints,
the
value is, as expected -1. However, if a is int and b is an unsigned,
then
the value of this expression depends on how many bits an int has on
the
particular machine. On our machine, this expression yields 4294967295
6.2的32次方是4294967296
7.
unsigned
u = 10, u2 = 42;
std::cout
<< u2 - u << std::endl;//32
std::cout
<< u - u2 << std::endl;//4294967264
int
i = 10, i2 = 42;
std::cout
<< i2 - i << std::endl;//32
std::cout
<< i - i2 << std::endl;//-32
std::cout
<< i - u << std::endl;//0
std::cout <<
u - i << std::endl;//0
2.1.3literals
1.
Although
integer literals may be stored in signed types, technically speaking, the
value
of a decimal literal is never a negative number. If we write what appears to be
a
negative decimal literal, for example, -42, the minus sign is not part of the
literal.
The
minus sign is an operator that negates the value of its (literal) operand.
2.
3. The
type of a string literal is array of constant chars, a type we’ll discuss in §
3.5.4
(p.
122). The compiler appends a null character (’\0’) to every string literal.
Thus, the
actual
size of a string literal is one more than its apparent size. For example, the
literal
'A' represents the single character A, whereas the string literal "A"
represents
an
array of two characters, the letter A and the null character.
4. Two
string literals that appear adjacent to one another and that are separated only
by
spaces, tabs, or newlines are concatenated into a single literal. We use this
form of
literal
when we need to write a literal that would otherwise be too large to fit
comfortably
on a single line:
// multiline
string literal
std::cout <<
"a really, really long string literal "
"that spans
two lines" << std::endl;
学习笔记(C++Primer)--易错点总结(Chapter2)的更多相关文章
- ref:学习笔记 UpdateXml() MYSQL显错注入
ref:https://www.cnblogs.com/MiWhite/p/6228491.html 学习笔记 UpdateXml() MYSQL显错注入 在学习之前,需要先了解 UpdateXml( ...
- 【整理】解决vue不相关组件之间的数据传递----vuex的学习笔记,解决报错this.$store.commit is not a function
解决vue不相关组件之间的数据传递----vuex的学习笔记,解决报错this.$store.commit is not a function https://www.cnblogs.com/jaso ...
- 学习笔记 UpdateXml() MYSQL显错注入
在学习之前,需要先了解 UpdateXml() . UPDATEXML (XML_document, XPath_string, new_value); 第一个参数:XML_document是Stri ...
- TensorFlow学习笔记(MNIST报错修正 适用Tensorflow1.3)
在Tensorflow实战Google框架下的深度学习这本书的MNIST的图像识别例子中,每次都要报错 错误如下: Only call `sparse_softmax_cross_entropy_ ...
- 解决vue不相关组件之间的数据传递----vuex的学习笔记,解决报错this.$store.commit is not a function
Vue的项目中,如果项目简单, 父子组件之间的数据传递可以使用 props 或者 $emit 等方式 进行传递 但是如果是大中型项目中,很多时候都需要在不相关的平行组件之间传递数据,并且很多数据需要 ...
- python学习笔记-import utils报错
今天遇到一个坑爹的问题,查找了半天原因,终于解决了,在此特地记录一下. 运行环境:Windows eclipse 我在eclipse中配置了python的运行环境,在eclipse中编写python代 ...
- Java学习笔记之Scanner报错java.util.NoSuchElementException
转载自:IT学习者-螃蟹 一个方法A使用了Scanner,在里面把它关闭了.然后又在方法B里调用方法A之后就不能再用Scanner了Scanner in = new Scanner(System.in ...
- 学习笔记71—Python 报错处理集
****************************************************** 如有谬误,请联系指正.转载请注明出处. 联系方式: e-mail: heyi9069@gm ...
- 关于java学习中的一些易错点(基础篇)
由JVM来负责Java程序在该系统中的运行,不同的操作系统需要安装不同的JVM,这样Java程序只需要跟JVM打交道,底层的操作由JVM去执行. JRE(Java Runtime Environmen ...
- ------------------java collection 集合学习 ----小白学习笔记,,有错,请指出谢谢
<!doctype html>java对象集合学习记录 figure:first-child { margin-top: -20px; } #write ol, #write ul { p ...
随机推荐
- C#内获取泛型方法及扩展
C#内获取泛型方法及扩展 C#内我们可以通过反射来动态获取实例方法和静态方法,不管方法存在多少个重载都可以通过GetMethod内的第二个参数去筛选出所要获取的方法,代码如下: type.GetMet ...
- C/C++用匿名数据结构实现时间和空间名利双收
程序的时间和空间,往往是一对矛盾,比如计算CRC32的时候会用到余式表 DWORD *crcTable; // DWORD[256]; 余式表可以用某种规则计算生成,为缩短文章长度就不写出来了,总之要 ...
- CentOS下使用NVM
查看CentOS版本 # rpm -q centos-release centos-release-6-8.el6.centos.12.3.x86_64 安装epel源 32位系统选择: rpm -i ...
- Java构造器的深入理解
[构造器与方法的深入理解] 构造器的深入理解 [博主]高瑞林 [博客地址]http://www.cnblogs.com/grl214 [博客地址]http://www.cnblogs.com/grl2 ...
- 算法笔记_014:合并排序(Java)
1 问题描述 给定一组数据,使用合并排序得到这组数据的非降序排列. 2 解决方案 2.1 合并排序原理简介 引用自百度百科: 合并排序是建立在归并操作上的一种有效的排序算法.该算法是采用分治法(Div ...
- LDA进阶(Dynamic Topic Models)
转自:http://blog.csdn.net/hxxiaopei/article/details/8034308 http://blog.csdn.net/huagong_adu/article/d ...
- For循环输出一个表格
<!-- 作者:郑伟钊 时间:2017-01-16 描述:通过一个循环的嵌套输出一个表格 --> <?php header("Content-type:text/html; ...
- Windows 8 卡在正在检查更新
原文地址:https://answers.microsoft.com/en-us/windows/forum/windows_8-update/windows-update-not-updating- ...
- 数据结构之Heap (Java)
Heap简介 Heap译为“堆”,是一种特殊的树形数据结构,它满足所有堆的特性:父节点的值大于等于子节点的值(max heap),或者小于等于子节点的值(min heap).对于max heap 根节 ...
- 【NOIP2013】Day2不完全题解+代码
T1 直接递归区间,从1-n开始,找到这个区间中的最小值然后将区间里的所有值都减去这个最小值 以被减去最小值之后的零点为分段分别递归处理即可. #include <algorithm> # ...