毕设的一些小问题

这篇博客记录了作者在完成毕设项目时遇到的C++和ARM汇编相关问题,包括vector错误、read()、feof与feof()的使用、this指针的理解、类中定义vector的问题、拷贝构造函数、立即数合法性、字符串处理、位域、引用与左值/右值、溢出和进位等。文章提供了详细的错误分析和解决方法,帮助读者理解并避免这些常见的编程陷阱。
摘要由CSDN通过智能技术生成

给自己看的东西,所以比较乱,主要是记录在做毕设遇到的一些小问题,大部分关于C++和arm汇编指令

 

1 vector

错误:出现"vector不是模板”

原因: 因为没有使用using namespace std;而是一个个写如using std::endl;,只写了常用的,没有注意到vector,vector也在命名空间std里。

解决:加上using namespace std;不用这个的写using std::vector;,其他容器如list同理。

后面还有ifstream未定义标识符,还是using namespace std方便呀

2 read()

使用read()读取文件,当前的指针会随着read到数据的时候移动,读多少,移动多少。

3 feof与eof

 

https://www.cnblogs.com/zhenghao2/p/6612459.html

EOF通常用来判断文本文件的结尾,因为EOF的值为-1,ASCII都是字符型,不可能出现-1的情况。而在二进制文件中,信息以数值存放,使用EOF就可能会异常。因此,通常使用feof来判断二进制文件的结尾。

feof用于判断文件结尾。头文件<cstdio>。使用方法是feof(fp),fp为指向需要判断的文件的指针。如果不到文件结尾,返回0值;如果是文件结尾,返回非0.使用feof判断文件结尾一定要非常注意以下一点:

假设文件包含10字节,并且你读取了十字节,调用feof函数,函数返回值均为0,这是因为尽管文件指针这时已经指向文件尾了,但是你没有试图越过文件尾读取数据,只有当你尝试了读取第十一个字节时,调用feof,函数才会返回1.

因此,使用feof常用的逻辑结构是先读在判断,如果先判断在读取,就会发生异常。

4 eof()

程序里用一个while来判断文件是否读到末尾,while里执行的是没读完的情形。如果用while(!file.eof())来判断的话,会出错,eof()是读到最后一个数据仍返回FALSE,试图再读一个数据读不到的时候才返回TRUE,所以不用eof()判断,直接用读到的数据是否存在来判断:while(file.read( char *,1))。

5 this指针

 

voidDate::setMonth(int mn)

{

  month=mn;

  this->month=mn;

  (*this).month=mn;

  //这三句是等价的

}

this只能在成员函数中使用。

如果有对象A,A.month=mn;实际上是把A的地址赋值给了this指针,A.month相当于(*this).month,如果又有B.month=nnn;实际上是把B的地址又赋值给了this指针,this指针是类的一个自动生成、自动隐藏的私有成员,它存在于类的非静态成员函数中,指向被调用函数所在的对象。全局仅有一个this指针,当一个对象被创建时,this指针就存放指向对象数据的首地址。

而现今都用同一个函数段,系统怎样使它分别引用A或B中的数据成员呢?在每一个成员函数中都包含一个特殊的指针,这个指针的名字是固定的,称为this指针。它是指向本类对象的指针,它的值是当前被调用的成员函数所在的对象的起始地址。

 

然而其实很少用到,就算没写this指针,编译器也会加上this作为隐含形参:

this的使用:1)在类的非静态成员函数中返回对象的本身时候,直接用return *this(常用于操作符重载和赋值、拷贝等函数)。2)传入函数的形参与成员变量名相同时,例如:this->n = n (不能写成n=n)

6 类里定义vector

错误:vector<armword> armwordlist(0); 提示应输入类型说明符

原因:这句在定义的时候同时调用了vector的带参构造函数,这就好比你在类中写了一个int a=5;这些应当放到构造函数中去:

解决:在构造函数里初始化,armwordlist.resize(0);

 

7 const  char*,char*,string(**待思**拷贝构造函数

如果 string s="abc";

写char * p=s;可以通过但是会有警告,(为了兼容旧的C代码)

const char *p2=s; 可以。

String是引用数据类型,传参数的时候,是引用传递,也就是传给参数的是引用,也就是地址,参数拿到引用后,就指向了该引用在堆中所存的常量

https://www.cnblogs.com/z2qfei/p/7998132.html

string类的构造函数:string(const char *s);//用c字符串s初始化 string(int n,char c); //用n个字符c初始化此外,string类还支持默认构造函数和复制(拷贝)构造函数,如string s1;string s2="hello";都是正确的写法

拷贝构造函数的格式为:类名(const 类名& 对象名);//拷贝构造函数的原型,参数是常量对象的引用。由于拷贝构造函数的目的是成员复制,不应修改原对象,所以建议使用const关键字

https://blog.csdn.net/silentob/article/details/76994618

 

const char *ptr;定义一个指向字符常量的指针,这里,ptr是一个指向 char* 类型的常量,所以不能用ptr来修改所指向的内容,换句话说,*ptr的值为const,不能修改。但是ptr的声明并不意味着它指向的值实际上就是一个常量,而只是意味着对ptr而言,这个值是常量。实验如下:ptr指向str,而str不是const,可以直接通过str变量来修改str的值,但是确不能通过ptr指针来修改。

深入 char*, char** ,char a[],char *a[]:https://blog.csdn.net/u011068702/article/details/52588649

字符串其实就是一个地址,所以可以 char* s="abc",假设编译器为"abc"分配的地址单元是 3000H 3001H 3002H,则s="abc"=3000H.

8 构造函数

错误:提示没有合适的默认构造函数可用,我自己已经写了一个构造函数,别的地方也没有使用不带参的默认构造函数。

解决方法 : 加一个armword();默认的构造函数即可,但是不知道为什么要加,别的地方并没有使用这个

 

——————看报错,我怀疑是跟后面定义了一个这个类的vector有关

如果直接声明一个默认的构造函数,这个错误解决了,会紧跟着一个错误,

error LNK2019: 无法解析的外部符号 "public: void __thiscall

解决方法:实现一下

armword::armword()

{};

 

9 vector

警告:从size_t转到int,可能丢失数据

代码是获取了一个容器的大小,int n= vector.size();

原因:size_t在64位机器用的是__int64 ,64位赋值32位所以报警告

解决:程序原因,肯定不会超过32位,虽然对结果没什么影响,但是看到警告很难受,解决方法就直接把int改成size_t即可。

在32位系统下size_t是一个unsigned int,
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值