gpt4 book ai didi

c++ - 将文件扩展名从 c 更改为 cpp 后,如何解决 C++ 中的歧义错误?

转载 作者:太空宇宙 更新时间:2023-11-04 06:55:15 24 4
gpt4 key购买 nike

我将文件 address2lineutil 的扩展名从 C 更改为 CPP。

当我使用带有 .c 扩展名的 GCC 进行编译时,它编译正确并且运行良好。在我将其扩展名更改为 .cpp 后,它抛出以下错误:

./../include/libiberty.h:112:64: error: new declaration 'char* basename(const char*)'
In file included from sysdep.h:48:0,
from address2lineutil.cpp:5:
/usr/include/string.h:603:28: error: ambiguates old declaration 'const char* basename(const char*)'

address2lineutil.cpp: In function 'void slurp_symtab(bfd*)':
address2lineutil.cpp:74:26: error: invalid conversion from 'void*' to 'asymbol** {aka bfd_symbol**}' [-fpermissive]
address2lineutil.cpp: In function 'void translate_addresses(bfd*, asection*)':
address2lineutil.cpp:252:32: error: invalid conversion from 'const char*' to 'char*' [-fpermissive]

我的 address2lineutil.cpp header :

       #include "sysdep.h"
#include "bfd.h"
#include "getopt.h"
#include "libiberty.h"
#include "demangle.h"
#include "bucomm.h"
#include "elf-bfd.h"
#include "address2lineutil.h"
#include <string.h>
#include <execinfo.h>
#include <stdio.h>
#include <stdlib.h>
#include <dirent.h>
#include <unistd.h>

static bfd_boolean unwind_inlines; /* -i, unwind inlined functions. */
static bfd_boolean with_addresses; /* -a, show addresses. */
static bfd_boolean with_functions; /* -f, show function names. */
static bfd_boolean do_demangle; /* -C, demangle names. */
static bfd_boolean pretty_print; /* -p, print on one line. */
static bfd_boolean base_names; /* -s, strip directory names. */

static int naddr; /* Number of addresses to process. */
static char **addr; /* Hex addresses to process. */
static asymbol **syms; /* Symbol table. */

static void slurp_symtab (bfd *);
static void find_address_in_section (bfd *, asection *, void *);
static void find_offset_in_section (bfd *, asection *);
static void translate_addresses (bfd *, asection *);

最佳答案

C++ 具有与 C 不同的类型检查规则(至少与旧的“C”不同)。默认情况下,它不允许您“摆脱” C 所做的事情。

您需要开始学习如何解释输出错误。打开“address2lineutil.cpp”。转到第 74 行。查看传递的类型。毫无疑问,它是类型“void*”。但是需要的是类型asymbol**。您确定传递的内容确实是 类型的 asymbol** 吗?如果是这样,您可以简单地 reinterpret_cast 它。

在同一个文件中,转到第 252 行。您有一个 const char* 并试图将它传递给需要 char* 的函数(可能传递给一个函数)。许多较旧的 C 函数需要 char*,即使它们不更改传递给它们的字符串。如果您确定是这种情况,您可以直接对其进行 const_cast。

上面只是描述了您可以 执行此编译的操作。至于你真正应该做什么,我不能告诉你,因为我不知道你的代码。也许第 252 行中需要“char*”的函数可以将其签名更改为采用 const char*?或者,另一方面,如果它实际上更改了给定的字符串,那么您应该只是强制转换,而应该创建一个非常量字符串缓冲区并传递它。

实际上,您应该 做的超出了这个答案的范围。

关于c++ - 将文件扩展名从 c 更改为 cpp 后,如何解决 C++ 中的歧义错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45836671/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com