小编SSS*_*SSS的帖子

重载==函数

我目前正在为==运算符创建一个重载函数.我正在为我的链表创建一个hpp文件,我似乎无法让这个操作符在hpp文件中工作.

我目前有这个:

template <typename T_>
class sq_list 
{

bool operator == ( sq_list & lhs, sq_list & rhs) 
{
    return *lhs == *rhs;
};

reference operator * ()     {
        return _c;
    };

};
}
Run Code Online (Sandbox Code Playgroud)

我得到大约10个错误,但它们几乎重复为错误:

C2804:二进制'运算符=='参数太多
C2333:'sq_list :: operator ==':函数声明错误; 跳过函数体
C2143:语法错误:缺少';' 在'*'
C4430 之前:缺少类型说明符 - 假设为int.注意:C++不支持default-int

我试过改变一些事情,但我一直得到与上面相同的错误

任何提示或帮助都非常感谢.

c++ templates operator-overloading operators equals-operator

7
推荐指数
1
解决办法
392
查看次数

打印int指针的值

我一直在努力,我似乎​​无法正常工作.我正在返回一个指针列表的最后一个值,我想打印它,但它打印一个非常随机的数字.我假设这是指针的内存地址,但是当我取消引用它时,我的输出仍然做同样的事情.

我的指针列表是一个指针列表,如: list<int*> pointerList

例如,这是我的方法返回:

int* end() { return (pointerList.back()); }
Run Code Online (Sandbox Code Playgroud)

这就是我的称呼方式.

int* totry = ca.end();
cout << *totry;
Run Code Online (Sandbox Code Playgroud)

这是打印内存地址而不是值.有没有人有任何想法如何解决这个问题?

提前致谢!

编辑:这是int指针指向的内容:我有一个值列表,例如,[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15] 我有一个指针列表,指向该列表的不同部分,如下所示:

[0,4,8,12]
Run Code Online (Sandbox Code Playgroud)

我有代码: int* end() { return (pointerList.back()); }在我的Header文件中,以及我的.cpp文件中的调用:

int*totry = ca.end(); cout <<*totry;


这是我声明我的指针列表的方式

    class ptrList
    {
    public:
        std::list<value_type> listOfValues;
        std::list<*int> pointerlist;
Run Code Online (Sandbox Code Playgroud)

我在"添加"功能中填写我的列表指针,我这样做:

int lstsqrt = 4;
for (int a = 1; a < lstsqrt; a++)
{
   int endptr = a + (int)lstsqrt;
    pointerlist.push_back((&*listOfValues.begin() + endptr)); //( (lstsqrt - 1) + a)  );

}
Run Code Online (Sandbox Code Playgroud)

这是我的end()方法 …

c++ printing pointers list memory-address

4
推荐指数
1
解决办法
796
查看次数

从一个表中选择另一个表中不存在

我有一张桌子与人,我有第二张表来记录这些人是否"缺席"缺席表(缺席)有AbsenceID,PersonID和AbsentDate人员表有PersonID,FirstName,LastName

我正在尝试创建一个SQL,它将从People表中获取所有值,除了当天缺席的那些值.因此,如果例如Joe在Absences表中列出并且AbsentDate是11/01/2014,我希望从生成的查询中排除他的名字.这是我到目前为止所做的,但它没有告诉我什么:

我在下面尝试过,但它返回所有行:

SELECT * FROM People 
where not exists(Select PersonID 
                 from Absences 
                 where Absences.AbsentDate = 11/01/2014)
Run Code Online (Sandbox Code Playgroud)

我确信这是一件非常简单的事情.任何帮助,将不胜感激

sql ms-access

3
推荐指数
1
解决办法
9753
查看次数