您的位置:首页 > 编程语言 > C语言/C++

C++语言发展历史 & 基础知识

2013-05-21 20:05 330 查看
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'}};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: