C++语言发展历史

 

     自从1946年第一台电子数字计算机ENIAC问世以来,随着计算机应用领域的不断扩大,促进了计算机技术的高速发展,尤其是近年来计算机的硬件和软件都是日新月异。作为应用计算机的一种工具—程序设计语言,得到不断的充实和完善。每年都有新的程序设计语言问世,老的程序设计语言不断地更新换代。

 

20世纪60年代,Martin Richards为计算机软件人员在开发系统软件时,作为记述语言使用而开发了BCPL语言(Basic Combined Programming Language)。

1970年,Ken Thompson在继承BCPL语言的许多优点的基础上发明了实用的B语言。

到了1972年,贝尔实验室的Dennis Ritchie和Brian kernighan在B语言的基础上,作了进一步的充实和完善,设计出了C语言。

当时,设计C语言是为了编写UNIX操作系统的。

 

以后,C语言经过多次改进,并开始流行。C++是在C语言的基础上发展和完善的,而C是吸收了其它语言的优点逐步成为实用性很强的语言。

 

C语言的主要特点是:

1、C语言是一种结构化的程序设计语言,语言本身简洁、使用灵活方便。既适用于设计和编写大的系统程序,又适用于编写小的控制程序,也适用科学计算。

2、它既有高级语言的特点,又具有汇编语言的特点。运算符丰富,除了提供对数据的算术逻辑运算外,还提供了二进制的位运算。并且也提供了灵活的数据结构。用C语言编写的程序表述灵活方便,功能强大。用C语言开发的程序,其结构性好,目标程序质量高,程序执行效率高。

 

 

3、程序的可移植性好。用C语言在某一种型号的计算机上开发的程序,基本上可以不作修改,而直接移植到其它型号和不同档次的计算机上运行。

 

4、程序的语法结构不够严密,程序设计的自由度大。这对于比较精通C语言的程序设计者来说,可以设计出高质量的非常通用的程序。但对于初学者来说,要能比较熟练运用C语言来编写程序,并不是一件容易的事情。与其它高级语言相比而言,调试程序比较困难。往往是编好程序输入计算机后,编译时容易通过,而在执行时还会出错。但只要对C语言的语法规则真正领会,编写程序及调试程序还是比较容易掌握的。

 

 

随着C语言应用的推广,C语言存在的一些缺陷或不足也开始流露出来,并受到大家的关注。如:C语言对数据类型检查的机制比较弱;缺少支持代码重用的结构;随着软件工程规模的扩大,难以适应开发特大型的程度等等。

 

 

为了克服C语言本身存在的缺点,并保持C语言简洁、高效,与汇编语言接近的特点,1980年,贝尔实验室的BjarneStroustrup博士及其同事对C语言进行了改进和扩充,并把Simula 67中类的概念引入到C中。并在1983年由Rick Maseitti提议正式命名为C++(C Plus Plus)。后来,又把运算符的重载、引用、虚函数等功能加入到C++中,使C++的功能日趋完善。

当前用得较为广泛的C++有:VC++ (Visual C Plus Plus)、 BC++(Borland C Plus Plus)、AT&T C++等。

 

 

#include  <iostream.h>

void  main(void)

{

  cout << “i=”;   //显示提示符

  inti;          //说明变量i

  cin  >>i;       //从键盘上输入变量i的值

  cout << “i的值为:” <<i<<’\n’; // 输出变量i的值

}

 

 

一般变量都是用匈牙利命名法命名的。

intnCount;

char  chChoice;

 

 

整型变量:

分为有符号型与无符号型。

有符号型:

          short 在内存中占两个字节,范围为-215~(215-1)

  int在内存中占四个字节,范围为-231~(231-1)

  long在内存中占四个字节,范围为-2-31~231-1

 

无符号型:最高位不表示符号位

unsigned  short 在内存中占两个字节,范围为0~216-1

unsigned int  在内存中占四个字节,范围为0~232-1

unsigned  long在内存中占四个字节,范围为0~232-1

 

实型数又称浮点数,有两种表示方式:

1)十进制形式:  23.0    24.5     3.56789


2) 指数形式:   23E1    145e-1    356789e1   e 前有数字,后面必须是整数。


 

实型变量分单精度 float 和双精度 double 两种形式:

float:占四个字节,提供7~8位有效数字。

double: 占八个字节,提供15~16位有效数字。

 

实数是既有整数又有小数的数。

实数可以表示成:N=S×RJ

S  称为尾数,尾数决定有效数字,即数字的精度。

J   表示指数(阶码)。

R  是基数,可取2,4,8,16等,对具体机器而言,基数取好后,就不能再变了。

数有正有负, 所以设置数符; 阶码亦有正负, 所以设置阶符

 

字长一定,尾数越多,精度越高;阶码越多,范围越大。

当计算机中出现小于机器所能表示的最小数时,机器只能当零来处理,当出现超过机器所能表示的最大数时,出现溢出现象,一旦出现溢出,就会停止运算。定点数,浮点数均会出现溢出现象。

 

转义字符虽然包含2个或多个字符,但它只代表一个字符。编译系统在见到字符“\”时,会接着找它后面的字符,把它处理成一个字符,在内存中只占一个字节。

 

典型转义字符:

‘\n’换行            ‘\b’ 退格              '\t'  下一个输出区

若输出中包含这些特定格式,则再加一个\

 

#include<iostream.h>

void main(void)

{

   char c1,c2,c3,c4;

   char n1,n2;

   c1='a';  //字符常量

   c2=97;  //十进制

   c3='\x61';  //转义字符

   c4=0141;  //八进制

   cout<<"c1="<<c1<<'\t'<<"c2="<<c2<<endl;

   cout<<"c3="<<c3<<'\t'<<"c4="<<c4<<endl;

   n1=‘\n’;      //转义字符:回车

   n2=‘\t’;       //转义字符:下一个输出区(Tab)

   cout<<"使用转义字符\n";

   cout<<"c1="<<c1<<n2<<"c2="<<c2<<n1;

   cout<<"c3="<<c3<<n2<<"c4="<<c4<<n1;

}

 

标识符常量

在C++中有二种方法定义标识符常量,一种是使用编译预处理指令;另一种是使用C++的常量说明符const。

例如:

     #define    PRICE  30

//在程序中凡是出现PRICE均用30替代

     #define    PI  3.1415926

     #define    S   “China”

 

const float pi=3.1415926;  //将变量pi定义为常量

(举例说明)

#include<iostream.h>

#define PI 3.14156

#define S  "China"

void main(void)

{

   const float pi=3.14156;  //变量作为常量使用

   cout<<"PI="<<PI<<endl;

   cout<<"10*PI="<<10*PI<<endl;

   cout<<S<<endl;

//  PI=PI+3;

//  pi=pi+4;

   cout<<"PI="<<PI<<endl;

   cout<<"pi="<<pi<<endl;

}

 

优先级:!à&&à| |

           !à算术à关系à逻辑à赋值à逗号

 

 

switch(表达式)

    { case  常量表达式1:语句1

         case  常量表达式2:语句2

          … …

         case 常量表达式n:语句n

         default:语句n+1

      }

 

void main(void)

{   int  i=1,sum=0;   //定义变量,初始化

     while(i<=100)    //构造循环

     {     sum=sum+i;   // 循环体,多次执行

             i=i+1;

     }

    cout<<“sum=”<<sum<<endl;   //输出结果

}

 

void main(void)

{   int  i=1,sum=0;   //定义变量,初始化

     do                 //构造循环

     {     sum=sum+i;   // 循环体,多次执行

             i=i+1;

     }while (i<=100);

    cout<<“sum=”<<sum<<endl;   //输出结果

}

 

 

 

void main(void)

{  int  i, sum;

    for (i=1, sum=0; i<=100; i++)

          sum=sum+i;

     cout<<“sum=”<<sum<<endl;

}

 

 

写一个函数验证哥德巴赫猜想;一个不小于6的偶数可以表示为两个素数之和,如6=3+3, 8=3+5, 10=3+7……。在主函数中输入一个不小于6的偶数n,函数中输出以下形式的结果∶

34=3+31

 

 

 

 

 

 

int power(intm,int n)  //m^n

{  inti,product=m;

  for(i=1;i<n;i++)

  product=product*m;

  return product;

}

intsum_of_power(intk,int n)  //n^k的累加和

{  inti,sum=0;

  for(i=1;i<=n;i++)

        sum+=power(i,k);

  return sum;

}

 

 

void main(void)

{  intk,m;

  cin>>k>>m;

  cout<<"f("<<k<<","<<m<<")="<<sum_of_power(k,m)<<endl;  //m^k的累加和

}

 

 

 

 

作用域是指程序中所说明的标识符在哪一个区间内有效,即在哪一个区间内可以使用或引用该标识符。在C++中,作用域共分为五类:块作用域、文件作用域、函数原型作用域、函数作用域和类的作用域。

 

 

在块作用域内可通过作用域运算符“::”来引用与局部变量同名的全局变量。

#include <iostream.h>

int  i= 100;

void main(void)

{

   inti , j=50;

   i=18;          //访问局部变量i

   ::i= ::i+4;    //访问全部变量i

   j= ::i+i;    //访问全部变量i和局部变量j

  cout<<”::i=”<<::i<<’\n’;

  cout<<”i=”<<i<<’\n’;

  cout<<”j=”<<j<<’\n’;

}

 

void main (void)

{   int  i;

     int  f [20]={1,1};

     for (i=2 ; i<20 ; i++ )

           f [i]=f [i-1]+f [i-2]; 

 

for ( i=0; i<20; i++)

   {   if (i%5= =0)  cout<<“\n”;

         cout<<f [i]<<‘\t’;

    }

}

 

 

 

for (j=0; j<n-1; j++)

   for (i=0; i<n-1-j; i++)

      {   if (a[i]>a[i+1])

             {  t=a[i];

                 a[i]=a[i+1];

                 a[i+1]=t;

              }

        }

 

 

 

有一个3×4的矩阵,要求编程序求出其中值最大的那个元素的值,以及其所在的行号和列号。

先考虑解此问题的思路。从若干个数中求最大者的方法很多,我们现在采用“打擂台”算法。如果有若干人比武,先有一人站在台上,再上去一人与其交手,败者下台,胜者留台上。第三个人再上台与在台上者比,同样是败者下台,胜者留台上。如此比下去直到所有人都上台比过为止。最后留在台上的就是胜者。

程序模拟这个方法,开始时把a[0][0]的值赋给变量max,max就是开始时的擂主,然后让下一个元素与它比较,将二者中值大者保存在max中,然后再让下一个元素与新的max比,直到最后一个元素比完为止。max最后的值就是数组所有元素中的最大值。

 

max=a[0][0];  //使max开始时取a[0][0]的值

  for (i=0;i<=2;i++)   //从第0行到第2行

    for (j=0;j<=3;j++) //从第0列到第3列

      if (a[i][j]>max)//如果某元素大于max

     {

           max=a[i][j]; //max将取该元素的值

            row=i;    //记下该元素的行号i

            colum=j;  //记下该元素的列号j

      }

 cout<<row<<‘\t’<<colum<<‘\t’<<max<<endl;

 

 

C++语言规定,数组名代表数组在内存中存储的首地址,这样,数组名作函数实参,实际上传递的是数组在内存中的首地址。实参和形参共占一段内存单元,形参数组中的值发生变化,也相当于实参数组中的值发生变化。

 

 

struct

   {    int  num;

         char  name[20];

         char  sex;

         int  age;

         float  score;

         char  addr[30];

    } student1, student2;

 

 

1、结构体类型的变量在内存依照其成员的顺序顺序排列,所占内存空间的大小是其全体成员所占空间的总和。

2、在编译时,仅对变量分配空间,不对类型分配空间。

3、对结构体中各个成员可以单独引用、赋值,其作用与变量等同。

 

格式:变量名 . 成员名    student1 . num

 

struct   student

   {    int  num;

         char  name[20];

         char  sex;

         int  age;

         float  score;

         char  addr[30];

} ;

struct  student  stu[30];

struct   student

   {    int  num;

         char  name[20];

         char  sex;

         int  age;

         float  score;

         char  addr[30];

} stu[30];

 

struct   student

   {    int  num;

         char  name[20];

         char  sex;

} stu[3]={ {1011, "Li Lin",'M'}, {1012,"Wang Lan",'F'},

                  {1013,"Liu Fang",'F'};

 

struct   student

   {    int  num;

         char  name[20];

         char  sex;

} stu[ ]={ {1011,"Li Lin",'M'}, {1012,"Wang Lan",'F'},

                  {1013,"Liu Fang",'F'}};