C++ 容易忽略的细节

1 超出数据类型指定长度的赋值

(1)无符号数据类型

unsigned char ch1= 336;

unsigned char ch2 = -1;

上面两个赋值都超出了unsigned char 类型的范围,大部分的编译器对这种情况是这么处理的:允许赋值,仅仅给出一个警告,但是是经过modulo之后的值。

cout<<ch1<<ch2<<endl; 而这的结果是 ch1 = 336 modulo 256 = 80, ch2 = -1 modulo 256 = 255 。 取余数。

(2) 对于有符号的书来说,要根据具体的编译器来定。

2 浮点型的有效数字

float类型仅提供6位有效数字,double类型至少提供10位有效数字

3 definitions 和declarations(变量的定义和声明)

主要的区别就是定义要分配存储空间,声明不分配存数空间,仅仅谁说明名字是什么,类型是什么而已。看看下面集中定义和声明的方式:

extern int i;    // 声明

int i;              //定义

extern double pi = 3.14    // 定义

4 变量的作用范围

从声明开始到范围结束,局部变量覆盖全局变量,看下面的代码片段

      int i = 100, sum = 0;
      for (int i = 0; i != 10; ++i)
           sum += i;
      std::cout << i << " " << sum << std::endl
输出结果应该是: i= 100     sum = 45

     int sum = 0;
    for (int i = 0; i != 10; ++i)
          sum += i;

      std::cout << "Sum from 0 to " << i << " is " << sum << std::endl;

编译出错,因为i没有被定义(cout中的i)

5 const 变量的作用范围







const的变量的作用范围是本文件,即使它被声明成全局变量。要想在其他文件中使用本文件中定义的const变量,看下面代码

      // file_1.cc
      // defines and initializes a const that is accessible to other files
      extern const int bufSize = fcn();
      // file_2.cc
      extern const int bufSize; 
// uses bufSize from file_1
//uses bufSize defined in file_1
      for (int index = 0; index != bufSize; ++index)
            // ...
在声明和定义处都需要加extern关键字

6  vector<string>::const_iterator 和 const  vector<string>::iterator
看下面两个例子,就能明白二者的区别

     for (vector<string>::const_iterator iter = text.begin();
                                  iter != text.end(); ++ iter)
         *iter = " ";     // error: *iter  is const

vector<string>::const_iterator iter 允许自身变化,但不允许修改它下面指向的数据,即指向的内容是常量
     vector<int> nums(10);  // nums is non const
     const vector<int>::iterator cit = nums.begin();
     *cit = 1;               // ok:cit can change its underlying element
    ++cit;                  // error: can't change the value of cit
const vector<int>::iterator cit 允许修改它指向的下面的数据,不允许自身的变化,即本身是个常量
7 typedef string *pstring
const pstring cstr; 解释这个声明的意思?
相信大部分人是这么理解的,typedef string *pstring 是定义了一个指向string 的指针类型,因此const pstring cstr <=> const string * cstr

即 指向一个const string的指针,但是这是错误的。

正确的解释应该是, cstr是一个const指针,指向string类型的字符串

你可能感兴趣的:(C++ 容易忽略的细节)