关闭

存在编译错误的程序和改后的程序比较

294人阅读 评论(0) 收藏 举报
/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生 
* All rights reserved.
* 文件名称:       找错误并改正                       
* 作    者:       田庆                       
* 完成日期:   2012      年 3      月    26    日
* 版 本 号:          

* 对任务及求解方法的描述部分
* 输入描述: 
* 问题描述: 
* 程序输出: 
* 程序头部的注释结束
*/
原错误程序如下:
class C
{
private:
	int x;
 public:
	C(int x){this->x = x;}
	int getX(){return x;}
};
void main()
{
	const C c(5);
	cout<<c.getX();
	system("pause");
}
改正方法一:
#include<iostream>
using namespace std;
class C
{
private:
	int x;
 public:
	C(int x){this->x = x;}
	int getX(){return x;}
};
void main()
{
	 C c(5);
	cout<<c.getX()<<endl;
	system("pause");
}
改正方法二:
#include<iostream>
using namespace std;
class C
{
private:
	int x;
 public:
    C(int x){this-> x= x;}
	int getX() const{return x;}
};
void main()
{
	const C c(5);
	cout<<c.getX()<<endl;
	system("pause");
}
我更倾向于第二种,因为常对象有一定的保护作用,其值不能轻易被改变,虽然多加个字母吧,但对程序来说更安全,而第一种是我们以前经常用的安全性不高。所以还是第二个比较好些。原则是先看清是什么类型的const注意它的访问对象。
 

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:57644次
    • 积分:1175
    • 等级:
    • 排名:千里之外
    • 原创:65篇
    • 转载:0篇
    • 译文:0篇
    • 评论:18条
    最新评论