频道栏目
首页 > 资讯 > C++ > 正文

C++ 一次简单的错误处理

17-09-29        来源:[db:作者]  
收藏   我要投稿

不知道这个错误是不是很silly,情况如下:

#include

#include

#include

using namespace std;

int main (int argc, char * const argv[]){

string str = “Hello”;

transform(str.begin(), str.end(), str.begin(), toupper);

cout << str << endl;

return 0;

}

程序的意思很简单,去把Hello都转换为大写。

编译死活不通过:

$ g++ -g -Wall strToUpper.cpp -o strToUpper

strToUpper.cpp: In function ‘int main(int, char* const*)’:

strToUpper.cpp:9: error: no matching function for call to ‘transform(__gnu_cxx::__normal_iterator, std::allocator > >, __gnu_cxx::__normal_iterator, std::allocator > >, __gnu_cxx::__normal_iterator, std::allocator > >, )’< /CHAR * , >< /CHAR*, >< /CHAR*, >

后来查明原因如下——

我们先看看这个函数的定义:

template OutIter transform(InIter start, InIter end, OutIter result, Func unaryFunc)

它要求参数和返回值都要是char。Linux中将toupper实现为一个宏而不是函数:

/usr/lib/syslinux/com32/include/ctype.h:

/* Note: this is decimal, not hex, to avoid accidental promotion to unsigned */

#define _toupper(__c) ((__c) & ~32)

#define _tolower(__c) ((__c) | 32)

__ ctype_inline int toupper(int __c)

{

return islower(__c) ? _toupper(__c) : __c;

}

__ctype_inline int tolower(int __c)

{

return isupper(__c) ? _tolower(__c) : __c;

}

有三种解决方法:

1.因为在全局命名空间中有实现的函数(而不是宏),所以我们明确命名空间,这并不是总奏效,但是在我的g++环境中没有问题:

transform(str.begin(), str.end(), str.begin(), ::toupper);

2.自己写一个函数出来—wraper

inline char charToUpper(char c)

{

return std::toupper(c);

}

3.强制转化:将toupper转换为一个返回值为int,参数只有一个int的函数指针。

transform(str.begin(), str.end(), str.begin(), (int (*)(int))toupper);

不要再.h 文件中使用 using namespace std;

会导致很多文件的namespace冲突

相关TAG标签
上一篇:可重入锁实现ReadWriteLock
下一篇:可重入锁实现ReentrantLock
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站