C++ 在我的模板类示例中,即使我没有定义add方法,它也是addstack";分段故障(堆芯倾倒)“;错误
!!注意:我在回答之后多次编辑了问题。但下面的问题是第一个问题,第一个答案是一个有用的答案。请不要被一些评论弄糊涂。它们是在我多次更改问题后编写的C++ 在我的模板类示例中,即使我没有定义add方法,它也是addstack";分段故障(堆芯倾倒)“;错误,c++,template-classes,C++,Template Classes,!!注意:我在回答之后多次编辑了问题。但下面的问题是第一个问题,第一个答案是一个有用的答案。请不要被一些评论弄糊涂。它们是在我多次更改问题后编写的 我有一个商店模板类和Cookie类。商店是一张保存着饼干的清单,名为cookieShop。Shop cotr可以将一个cookie作为其参数,并且可以通过Shop template类的Add方法添加更多cookie 我正在制作两个饼干。一个是通过车间cotr添加的,第二个是通过添加方法添加的。即使我不在add方法中编写代码,第二个cookie也会添
我有一个商店模板类和Cookie类。商店是一张保存着饼干的清单,名为cookieShop。Shop cotr可以将一个cookie作为其参数,并且可以通过Shop template类的Add方法添加更多cookie 我正在制作两个饼干。一个是通过车间cotr添加的,第二个是通过添加方法添加的。即使我不在add方法中编写代码,第二个cookie也会添加到商店列表中。我试图理解它为什么会这样做,但无法理解 这是我的密码: //商店
#ifndef SHOP_T
#define SHOP_T
#include <string>
using namespace std;
template<class type>
class Shop;
template<typename type>
ostream& operator<<(ostream& out, const Shop<type>& S){
for(int i = 0; i < S.size; i++)
out << i + 1 << ".\t" << S.list[i] << endl;
}
template<class type>
class Shop{
type *list;
string name;
int size;
public:
Shop() { list = 0; size = 0; }
Shop(type t);
~Shop(){ delete[] list; }
void Add(type A);
friend ostream& operator<< <>(ostream& out, const Shop<type>& S);
};
template<class type>
Shop<type>::Shop(type t) : size(0){
list = new type;
list = &t;
size++;
}
template<class type>
void Shop<type>::Add(type A){
// type *temp = new type[size+1];
// for(int i = 0; i < size; i++)
// temp[i] = list[i];
// delete[] list;
// temp[size] = A;
// list = temp;
size++;
}
#endif
\ifndef车间
#定义车间
#包括
使用名称空间std;
模板
高级商店;
模板
ostream&运算符此处:
模板
车间:车间(t型):尺寸(0){
列表=新类型;
列表=&t;
大小++;
}
变量t
是此函数的局部变量。将list
设置为指向该变量的指针。当函数终止时,变量将超出范围,商店将保留一个悬空指针,您将得到未定义的行为。此处:
template<class type>
Shop<type>::Shop(type t) : size(0){
list = new type;
list = &t;
size++;
}
模板
车间:车间(t型):尺寸(0){
列表=新类型;
列表=&t;
大小++;
}
变量t
是此函数的局部变量。将list
设置为指向该变量的指针。当函数终止时,变量将超出作用域,商店将保留一个悬空指针,您将获得未定义的行为。您忘记注释掉size++代码>在中添加@NathanOliver。因为我想打印列表[1]。我认为问题不在于此。是吗?谁教你原始数组是一个有用的容器,那就大错特错了。你最好使用std::vector
这是一个家庭作业。我不得不这样做。截止日期已经结束。不幸的是,我如上所述发送了家庭作业。但是现在我想学习。我为你的学习愿望喝彩,但是1)请不要以完全改变它们的方式编辑你的问题,2)当你编写代码时,最好从一个小而简单、工作完美的东西开始,当你在这里发布代码时,最好将其减少到最小,产生错误的最简单代码。您忘记注释掉size++代码>在中添加@NathanOliver。因为我想打印列表[1]。我认为问题不在于此。是吗?谁教你原始数组是一个有用的容器,那就大错特错了。你最好使用std::vector
这是一个家庭作业。我不得不这样做。截止日期已经结束。不幸的是,我如上所述发送了家庭作业。但是现在我想学习。我为你的学习愿望喝彩,但是1)请不要以完全改变它们的方式编辑你的问题,2)当你编写代码时,最好从一些小而简单、工作完美的东西开始,当你在这里发布代码时,最好将其减少到产生错误的最小、最简单的代码。哦。我在这里写了很糟糕的代码。我会尽力改正的。谢谢。list=new type
,list=&t
与delete[]list
@Caleth不匹配也会导致UB。为什么在我更改您提到的代码后,它仍然会给出分段错误?我对修改后的代码也是错的吗?@Murat:现在你调用了Add
函数,但大部分还是被注释掉了;它没有添加Cookie,它只是增加大小
。然后,当您尝试打印第二个Cookie时,您读取的内容超过了数组的末尾(它不是真正的数组,Cookie
不是Cookie[1]
),并且再次获得未定义的行为。@Beta:我已经通过注释部分尝试了代码:cookieShop.Add(cookie2)。对不起,我忘了在这儿换了。但是我得到了和上面一样的结果。我在这里写了很糟糕的代码。我会尽力改正的。谢谢。list=new type
,list=&t
与delete[]list
@Caleth不匹配也会导致UB。为什么在我更改您提到的代码后,它仍然会给出分段错误?我对修改后的代码也是错的吗?@Murat:现在你调用了Add
函数,但大部分还是被注释掉了;它没有添加Cookie,它只是增加大小
。然后,当您尝试打印第二个Cookie时,您读取的内容超过了数组的末尾(它不是真正的数组,Cookie
不是Cookie[1]
),并且再次获得未定义的行为。@Beta:我已经通过注释部分尝试了代码:cookieShop.Add(cookie2)。对不起,我忘了在这儿换了。但是我得到了与上面相同的结果。
#include "Cookie.h"
#include <iostream>
#include <string>
using namespace std;
Cookie::Cookie() {}
Cookie::Cookie(string n, int pi, float pr){
name = n;
piece = pi;
price = pr;
}
ostream& operator<<(ostream& o, const Cookie& C){
o << C.name << "\t" << C.piece << "\t" << C.price;
}
#include <iostream>
#include <string>
#include "Shop.h"
#include "Cookie.h"
using namespace std;
int main(){
Cookie cookie1("Chocolate Cookie", 50, 180);
Cookie cookie2("Cake Mix Cookie", 60, 200);
Shop<Cookie> cookieShop(cookie1);
cookieShop.Add(cookie2);
cout << cookieShop <<endl;
return 0;
}
template<class type>
Shop<type>::Shop(type t) : size(0){
list = new type;
list = &t;
size++;
}