C++二进制'operator+' 'const char*'和'const char [2]'类型的无效操作数
C++ invalid operands of types 'const char*' and 'const char [2]' to binary 'operator+'
我想知道这里发生了什么?请建议
我不熟悉c++,我可以这样做吗?
char result = (msg[0] == 0) ? "OFF" : "ON";
printf("A/C is " + result + "n");
你应该使用:
printf("A/C is %sn", result);
您的result
实际上声明了错误的类型;应该是char const *
甚至更好(正如Ed的评论中提到的),你不应该使用printf
。这样做:
std::cout << "A/C is " << result << "n";
显然你不能。试试这个:
const char * result = (msg[0] == 0) ? "OFF" : "ON";
printf("A/C is %sn", result);
看起来您应该使用streams
。
std::cout << "A/C is " << result << std::endl;
首先,你不能简单地使用加法操作来连接c风格的字符串,其次,你应该使用std::cout
输出:
std::cout << "A/C is " << result << 'n';
如果要连接字符串,至少有一个字符串必须是std::string
对象
相关文章:
- 在字符串函数中抛出'char const*'实例后调用的终止
- 双重标准?为什么只有 char* const&a = "bla" 的警告?
- 包括"lvtocon.h",未定义对'operator<<(std::ostream&, char const*)的引用
- 为什么 const char* const & = 可以编译"hello"?
- 将字符串文本常量定义为 char const* 和 wchar const*
- 如何将std::wstring转换为char const[]
- "char const * name() const _WEBSOCKETPP_NOEXCEPT_TOKEN_ {"剂量是什么意思
- 使用提升对字符串进行标记化时,将令牌转换为 char* const* 时失败
- 如何从 std::initializer_list<char const* 构建 std::vector<std::string>>
- 将 std::vector<std::string> 转换为 const char* const*
- 引发"char const*"错误的实例后调用的终止
- 将const char * const参数成员分配给新值
- 从'const char**'到'char* const*'的转换无效
- 从 sub_match<常量字符 *>' 转换为'const char *const &'
- char*const和constchar*之间有什么区别?(重复-需要更多澄清)
- 使用工厂方法时编译器错误:无法转换"const std::p air<char* const
- HEVC 解码器端口 Android 警告:从 'signed char*' 到 'char const* 的转换无效*
- 如何从'char const*'中删除常量
- 'char const *str'作为模板参数
- 为什么不;t strlen(.)应为const char*const str,而不是const char*