《C++primer》v5 第2章 C++基础 读书笔记 习题答案

2.1

int,long long ,short 可表示范围和占用内存空间不同。具体与计算机有关。

无符号类型只能表示0和正数,带符号类型可以表示负数,0,正数。

float是单精度,一般占用4个字节,double是双精度,一般占用8个字节,它们可表示的数据范围也不相同。

2.2

利率用double,本金和付款用int

2.3

    unsigned u=10,u2=42;
    cout<<u2-u<<endl;
    cout<<u-u2<<endl;
    int i=10,i2=42;
    cout<<i2-i<<endl;
    cout<<i-i2<<endl;
    cout<<i-u<<endl;
    cout<<u-i<<endl;

输出

32
4294967264
32
-32
0
0

但凡unsigned类型涉及负数运算都会出现意外的情况(具体查询整数在计算机内的表示方法),比如上面第2个。int与unsigned计算会将int转化为unsigned。

2.4

2.5

(a)。

‘a‘ 是单字符字面值,char

L‘a‘是宽字符字面值,wchar_t

"a"是字符串字面值

L"a"宽字符型字符串字面值

wchar_t占16位,char占8位

(b)。

10是int字面值

10u是unsigned字面值

10L是long字面值

10LL是longlong字面值

012是八进制,等于十进制下的10

0xC是十六进制,等于十进制下的12

(c)。

3.14浮点数字面值

3.14f是float字面值

3.14L是longdouble字面值

(d)。

10是int字面值

10u是unsigned字面值

10.浮点数字面值

10e-2浮点数字面值,等于0.01

2.6

上面一行定义的是十进制整型,下面一行定义的是八进制整型,因此int month=09的写法是错的。

2.7

(1)字符串常量

cout<<"Who goes with F\145rgus?\012";

输出Who goes with Fergus?

其中\145是‘e‘,\012是’\n‘

(2)longdouble常量

(3)float常量

(4)longdouble常量

2.8略

2.9

    cin>>int inpu_value;//error:不能在读入的时候定义,只能读已经定义好的变量
    int i={3.14};//虽然编译通过,但是给了一warning,因为损失了精度!可能与编译器有关,有的可能会报错。
    double salary=wage=9999.99;//errer:wage未定义,不能连续定义!
    int j=3.14;//正确,虽然也损失了精度,但没有提示

2.10

local_int初值未知

global_int初值为0

global_str和local_str初值为空

2.11

(a)错误,既有extern又有初始值

(b)定义

(c)声明

2.12

(a)非法,double是c++关键字

(c)-不能出现在变量名中

2.13

j等于100

因为局部变量i隐藏了全局变量i

2.14

输出100 45。

2.15

(a)正确,发生隐式转化double转int

(b)错。普通引用不能绑定常量,而且数据类型也不符。

(c)正确

(d)错,引用未初始化。

2.16

(a)合法,double赋给double

(b)合法,int隐式转化成double

(c)合法,double隐式转化成int

(d)合法,double隐式转化成int

2.17

输出10 10.

因为ri是i的引用,改了i的值

2.18略

2.19

指针是对象,它指向的也是一个对象。

而引用不是对象,它绑定一个对象,是对象的一个别名,定义时必须初始化。

很多区别。。。

2.20

第一行:定义变量i=42

第二行:定义int指针指向i

第三行:通过指针修改i,使其等于42*42

2.21

(a)指向double的指针不能指向int变量

(b)错误。等号右侧缺少&。

(c)正确

2.22

如果p不是空指针。。

如果p指向的对象非空。。

2.23

在不用智能指针的前提下,定义的时候指针要初始化,释放内存后指针要置NULL。这样就可以通过检查指针是否为NULL来判断是否指向合法对象了。

2.24

void*p是一种特殊的指针类型,可以存放任意对象的地址。

*lp是指向long的指针而i是int,数据类型不符。

2.25

(a)ip是野指针,i的值是随机的,r绑定i。

(b)i的值是随机的,ip是空指针

(c)ip是野指针,ip2是int数据类型,值是随机的

2.26

(a)错,const变量必须初始化

(b)正确

(c)正确

(d)错。sz是指向常量对象的引用,不能修改对象的内容。

2.27

(a)&r=0,错误,普通引用不能绑定常量

(f)错误,不存在常量引用,而且也没用初始化

2.28

(a)不合法,*const需要初始化。

(b)不合法,*const需要初始化。

(c)不合法,ic是常量需要初始化。

(d)不合法,常量指针需要初始化

(e)不合法,常量指针对象初始化。

2.29

这里要注意const修饰的是数据类型还是声明符。

如*、&(类型修饰符)都只是声明符的一部分,不属于数据类型的部分。类型修饰符不作用于本次定义的全部变量,只作用于修饰的变量。

(a)合法,常量可以拷贝给非常量

(b)不合法,p3有底层const,不能赋给p1

(c)不合法,ic是常量,而p1是普通指针,不能指向它

(d)不合法,p3是常量指针,不能再指向其他对象

(e)不合法,p2是常量指针,不能再修改它指向的地址

(f)不合法,ic是常量,不能修改

2.30

    const int v2=0;//顶层const
    int v1=v2;
    int *p=&v1,&r1=v1;
    const int *p2=&v2,*const p3=&v1,&r2=v2;
    //p2是底层const,p3是顶层、底层const,r2底层const

2.31

(1)。合法

(2)。p1=p2不合法,p2具有底层const不能赋给p1;p2=p1,合法,没有const的指针可以赋给有底层const的指针

(3)。p1=p3不合法,p3具有底层const;p2=p3合法,两个指针都有底层const

2.32

不合法。不能将非地址的数据类型赋给指针,即使该变量值等于0也不行。

*p=NULL;

2.33

a是int,赋值合法。

b是int,赋值合法。auto会忽略顶层const而保留底层const

c是int,赋值合法。从引用中得到的是int。

d是一个int*,赋值不合法。

e是一个指向常量的指针,具有底层const,赋值不合法

g是常量int引用,赋值不合法。

auto可以从指针中得到指针变量,但是不能从引用中得到引用。所以我们可以使用auto&来定义引用。

2.34略

2.35

auto &k=10;这样是不行的

但是const auto &k=10;就可以

j是const int。

k是指向常量对象的引用。(前面不加const效果是一样的)

p是指向常量对象的指针

j2是常量int。

k2是指向常量对象的引用。

2.36

    int a=3,b=4;
    decltype(a) c=a;//c是int
    decltype((b)) d=a;//d是a的引用
    ++c;
    ++d;
    cout<<a<<" "<<b<<" "<<c<<" "<<d<<endl

2.37

对表达式使用decltype会得到普通引用

    int a=3,b=4;
    decltype(a) c=a;//c是int
    decltype((a=b)) d=a;//d是a的引用
    c=5;
    d=10;
    cout<<a<<" "<<b<<" "<<c<<" "<<d<<endl;

2.38

auto根据定义时的表达式决定变量类型同时初始化变量

decltype根据表达式决定变量类型但不同时初始化变量

等等。。

《C++primer》v5 第2章 C++基础 读书笔记 习题答案

时间: 2024-07-30 15:41:39

《C++primer》v5 第2章 C++基础 读书笔记 习题答案的相关文章

《C++primer》v5 第12章 动态内存 读书笔记 习题答案

这一章暂时没写完,先留着以后再写. 在C++程序中,程序员可以给手动开辟内存,但是这块内存需要手动释放,不便管理,因此新标准提供智能指针类型来管理动态对象.它负责自动释放所指向的对象. shared_prt允许多个指针指向同一个对象 unique_ptr独占所指向的对象 weak_ptr是一个弱引用,指向shared_ptr所管理的对象 一些操作: p=q;//递减p的引用计数,递增q的引用计数 shared_ptr<T> p(q);//p是q的拷贝,递增q的引用计数 通过make_share

《C++primer》v5 第8章 IO库 读书笔记 习题答案

8.1.8.2 这一章不咋会啊.. istream &read(istream &is) { int a; auto old_state=is.rdstate(); is.clear(); is>>a; is.setstate(old_state); return is; } int main() { read(cin); return 0; } 8.3 读到eof或错误类型的时候 8.4 #include<fstream> using namespace std;

《C++primer》v5 第11章 关联容器 读书笔记 习题答案

11.1 map是关联容器,vector是顺序容器 11.2 略 11.3 int main() { map<string,int> word; string s; while(cin>>s) word[s]++; for(auto i:word) cout<<i.first<<" "<<i.second<<endl; return 0; } 11.4 void convers(string &s) { s

《C++primer》v5 第10章 泛型算法 读书笔记 习题答案

10.1 using namespace std; int main() { vector<int> vec; int a; cin>>a; int v; while(cin>>v) vec.push_back(v); cout<<a<<" : "<<count(vec.begin(),vec.end(),a)<<endl; return 0; } 10.2 using namespace std; i

《C++primer》v5 第9章 顺序容器 读书笔记 习题答案

9.1 (a)list.可以快速插入. (b)deque.支持尾部快速插入和头部快速删除. (c)vector或者deque. 9.2 list<deque<int> > l; 9.3 它的范围是该容器的第一个元素和尾元素之后.区间左闭右开. 9.4 #include<iostream> #include<algorithm> #include<cstdio> #include<list> #include<deque>

《C++primer》v5 第5章 语句 读书笔记 习题答案

5.1 空语句只有一个";".如果什么也不想做可以使用空语句. 5.2 用花括号{}括起来的叫块,也叫复合语句.有多条语句作用在同一个作用域时,需要用花括号括起来. 5.3 降低了. 5.4 (a)每次迭代时候会初始化iter,但是iter缺少初值,所以这段代码根本不会通过编译.另外这里的括号需要一个bool类型的,而定义迭代器根本不会返回一个bool类型.假如上面那些问题都可以通过,每次迭代都会初始化这个iter,会导致死循环. (b)我试了一下编译未通过是因为没找到适合的find函

《C++primer》v5 第3章 字符串、向量和数组 读书笔记 习题答案

3.1略 3.2 string str; //读行 while(getline(cin,str)) cout<<str<<endl; //读单个词 while(cin>>str) cout<<str<<endl; 3.3 输入运算符读到空白符结束 getline读到换行符结束,并丢弃换行符 3.4 比较大小. 比较大小是比较的第一个不相同的字符的大小. int main() { string a,b; cin>>a>>b;

《C++primer》v5 第1章 开始 读书笔记 习题答案

从今天开始在博客里写C++primer的文字.主要以后面的习题作业为主,会有必要的知识点补充. 本人也是菜鸟,可能有不对之处,还望指出. 前期内容可能会比较水. 1.1略 1.2略 1.3 cin和cout分别是istream和ostream的对象. #include<iostream> using namespace std; int main() { cout<<"Hello,world"<<endl; return 0; } 1.4 #incl

《C++primer》v5 第4章 表达式 读书笔记 习题答案

4.1 105 4.2 *vec.begin()=*(vec.begin())//先调用点运算符,再解引用 *vec.begin()+1=(*vec.begin())+1//先解引用,再加一 4.3略? 4.4 (12/3*4)+(5*15)+(24%4/2)=91 4.5 (a)-86(b)-16 (c)0 (d)0 4.6 n%2 4.7 溢出:计算结果超出该数据类型所能表示的范围 2147483647+1 1U-2 ... 4.8 比较低.. 4.9 首先判断cp是否为空指针,若非空指针则