在编译c++程序时运行gcc -o fileio fileio.cpp报错,错误提示为:

/tmp/ccinWfZ2.o:在函数‘main’中:
fileio.cpp:(.text+0x26):对‘std::basic_string<char, std::char_traits<char>, std::allocator<char> >::basic_string()’未定义的引用
fileio.cpp:(.text+0x30):对‘std::cout’未定义的引用
fileio.cpp:(.text+0x35):对‘std::basic_ostream<char, std::char_traits<char> >& std::operator<< <std::char_traits<char> >(std::basic_ostream<char, std::char_traits<char> >&, char const*)’未定义的引用
fileio.cpp:(.text+0x44):对‘std::cin’未定义的引用
fileio.cpp:(.text+0x49):对‘std::basic_istream<char, std::char_traits<char> >& std::operator>><char, std::char_traits<char>, std::allocator<char> >(std::basic_istream<char, std::char_traits<char> >&, std::basic_string<char, std::char_traits<char>, std::allocator<char> >&)’未定义的引用
fileio.cpp:(.text+0x69):对‘std::string::c_str() const’未定义的引用
fileio.cpp:(.text+0x80):对‘std::basic_ofstream<char, std::char_traits<char> >::basic_ofstream(char const*, std::_Ios_Openmode)’未定义的引用
fileio.cpp:(.text+0x94):对‘std::basic_ostream<char, std::char_traits<char> >& std::operator<< <std::char_traits<char> >(std::basic_ostream<char, std::char_traits<char> >&, char const*)’未定义的引用
fileio.cpp:(.text+0x9e):对‘std::cout’未定义的引用
fileio.cpp:(.text+0xa3):对‘std::basic_ostream<char, std::char_traits<char> >& std::operator<< <std::char_traits<char> >(std::basic_ostream<char, std::char_traits<char> >&, char const*)’未定义的引用
fileio.cpp:(.text+0xb2):对‘std::cin’未定义的引用
fileio.cpp:(.text+0xb7):对‘std::istream::operator>>(float&)’未定义的引用
fileio.cpp:(.text+0xd1):对‘std::basic_ostream<char, std::char_traits<char> >& std::operator<< <std::char_traits<char> >(std::basic_ostream<char, std::char_traits<char> >&, char const*)’未定义的引用
fileio.cpp:(.text+0xe7):对‘std::ostream::operator<<(float)’未定义的引用
fileio.cpp:(.text+0xec):对‘std::basic_ostream<char, std::char_traits<char> >& std::endl<char, std::char_traits<char> >(std::basic_ostream<char, std::char_traits<char> >&)’未定义的引用
fileio.cpp:(.text+0xf4):对‘std::ostream::operator<<(std::ostream& (*)(std::ostream&))’未定义的引用
fileio.cpp:(.text+0x103):对‘std::basic_ofstream<char, std::char_traits<char> >::close()’未定义的引用
fileio.cpp:(.text+0x112):对‘std::string::c_str() const’未定义的引用
fileio.cpp:(.text+0x12c):对‘std::basic_ifstream<char, std::char_traits<char> >::basic_ifstream(char const*, std::_Ios_Openmode)’未定义的引用
fileio.cpp:(.text+0x136):对‘std::cout’未定义的引用
fileio.cpp:(.text+0x13b):对‘std::basic_ostream<char, std::char_traits<char> >& std::operator<< <std::char_traits<char> >(std::basic_ostream<char, std::char_traits<char> >&, char const*)’未定义的引用
fileio.cpp:(.text+0x14d):对‘std::basic_ostream<char, std::char_traits<char> >& std::operator<< <char, std::char_traits<char>, std::allocator<char> >(std::basic_ostream<char, std::char_traits<char> >&, std::basic_string<char, std::char_traits<char>, std::allocator<char> > const&)’未定义的引用
fileio.cpp:(.text+0x15a):对‘std::basic_ostream<char, std::char_traits<char> >& std::operator<< <std::char_traits<char> >(std::basic_ostream<char, std::char_traits<char> >&, char const*)’未定义的引用
fileio.cpp:(.text+0x16d):对‘std::cout’未定义的引用
fileio.cpp:(.text+0x172):对‘std::basic_ostream<char, std::char_traits<char> >& std::operator<< <std::char_traits<char> >(std::basic_ostream<char, std::char_traits<char> >&, char)’未定义的引用
fileio.cpp:(.text+0x18b):对‘std::istream::get(char&)’未定义的引用
fileio.cpp:(.text+0x1a0):对‘std::basic_ios<char, std::char_traits<char> >::operator void*() const’未定义的引用
fileio.cpp:(.text+0x1b4):对‘std::cout’未定义的引用
fileio.cpp:(.text+0x1b9):对‘std::basic_ostream<char, std::char_traits<char> >& std::operator<< <std::char_traits<char> >(std::basic_ostream<char, std::char_traits<char> >&, char const*)’未定义的引用
fileio.cpp:(.text+0x1c8):对‘std::basic_ifstream<char, std::char_traits<char> >::close()’未定义的引用
fileio.cpp:(.text+0x1dc):对‘std::basic_ifstream<char, std::char_traits<char> >::~basic_ifstream()’未定义的引用
fileio.cpp:(.text+0x1eb):对‘std::basic_ofstream<char, std::char_traits<char> >::~basic_ofstream()’未定义的引用
fileio.cpp:(.text+0x1fa):对‘std::basic_string<char, std::char_traits<char>, std::allocator<char> >::~basic_string()’未定义的引用
fileio.cpp:(.text+0x21f):对‘std::basic_ifstream<char, std::char_traits<char> >::~basic_ifstream()’未定义的引用
fileio.cpp:(.text+0x233):对‘std::basic_ofstream<char, std::char_traits<char> >::~basic_ofstream()’未定义的引用
fileio.cpp:(.text+0x247):对‘std::basic_string<char, std::char_traits<char>, std::allocator<char> >::~basic_string()’未定义的引用
/tmp/ccinWfZ2.o:在函数‘__static_initialization_and_destruction_0(int, int)’中:
fileio.cpp:(.text+0x288):对‘std::ios_base::Init::Init()’未定义的引用
fileio.cpp:(.text+0x297):对‘std::ios_base::Init::~Init()’未定义的引用
/tmp/ccinWfZ2.o:(.eh_frame+0x4b):对‘__gxx_personality_v0’未定义的引用
collect2: error: ld returned 1 exit status
nicolas@bestpc:~/tmp$ gcc -o cryptoDemo cryptoDemo.cpp
/tmp/ccRtQPe6.o:在函数‘testAes(char*, int, char*, int)’中:
cryptoDemo.cpp:(.text+0xfb):对‘AES_set_encrypt_key’未定义的引用
cryptoDemo.cpp:(.text+0x193):对‘AES_encrypt’未定义的引用
cryptoDemo.cpp:(.text+0x293):对‘AES_encrypt’未定义的引用
cryptoDemo.cpp:(.text+0x317):对‘AES_set_decrypt_key’未定义的引用
cryptoDemo.cpp:(.text+0x3a9):对‘AES_decrypt’未定义的引用
cryptoDemo.cpp:(.text+0x49e):对‘AES_decrypt’未定义的引用
collect2: error: ld returned 1 exit status

不要被这么长的错误吓到了,其实很简单,你只是用错了编译器而已!

把gcc改为g++即可!

在编译c++程序时运行gcc -o fileio fileio.cpp报错,错误提示为:/tmp/ccinWfZ2.o:在函数‘main’中:fileio.cpp:(.text+0x26):对‘std::basic_string, std::allocator >::basic_string()’未定义的引用fileio.cpp:(.text+0x30):对‘std::cout’未定义
增强PFR 这是一个C ++ 14库,用于非常基本的反射,使您可以按索引访问结构元素,并为用户 定义 的类型提供其他 std ::tuple类的方法,而无需任何宏或样板代码。 测试覆盖率 激励实例#0 # include < iostream> # include < fstream> # include < string> # include " boost/pfr.hpp " struct some_person { std ::string name; unsigned birth_year; int main ( int argc, const char * argv[]) { some_person val{ " Edgar Allan Poe " , 1809 }; std :: cout << boost>(val) // No macro! << " was born in " << boost>(val
C++中 std ::string是日常Coding中经常使用的一个类,使用起来非常方便,但是也存在一些弊端。 如下代码,参数传递的过程发生了内存分配(Memory Allocation)和内存拷贝。 void fun(const std ::string& s) { std :: cout << s << std ::endl; const char* ch = "hello world"; // bad way, expensive if the string is long fun(ch); 再看下面的常用的字符串截取实现: // very long string std ::strin
C++ 语言是个十分优秀的语言,但优秀并不表示完美。还是有许多人不愿意使用C或者C++,为什么?原因众多,其中之一就是C/C++的文本处理功能太麻烦,用起来很不方便。以前没有接触过其他语言时,每当别人这么说,我总是不屑一顾,认为他们根本就没有领会C++的精华,或者不太懂C++,现在我接触 perl, php, 和Shell脚本以后,开始理解了以前为什么有人说C++文本处理不方便了。 总之,有了string 后,C++的字符文本处理功能总算得到了一定补充,加上配合STL其他容器使用,其在文本处理上的功能已经与perl, shell, php的距离缩小很多了。 因此掌握string 会让你的 C++11引入了thread类,大大降低了多线程使用的复杂度,原先使用多线程只能用系统的API,无法解决跨平台问题,一套代码平台移植,对应多线程代码也必须要修改。现在在C++11中只需使用语言层面的thread可以解决这个问题。 所需头文件 二:构造函数 1.默认构造函数 thread() noexcept 一个空的 std ::thread执行对象 2.初始化构造函数 template explicit thread(Fn&& fn, Args&&… args); 创建 std ::thread执行对象,线程调用thre xxx.cpp(.text+0x1000):对'A' 定义 引用 原因是将C/C++编译为obj文件的时候并不需要函数的具体实现,只需要有函数的原型即可。但是在编译为可执行文件的时候,需要找到函数的具体实现。 因此 声明的 引用 是头文件引入 误,而 定义 引用 是函数的实... 在GCC中已经指定链接库,然而编译时却提示动态库函数 定义 ! 测试出现的 误提示如下: [GMPY@13:48 tmp]$gcc -o test -L. -lmylib test.c /tmp/ccysQZI3.o:在函数‘main’中: test.c:(.text+0x1a):对‘func_lib’ 定义 引用 collect2: error: ld returned 1 ex...
0INRMumLsiQwT0xVgvYVmNCBWS7mV8LzSeLOZGHzflL3ziBSx+iej3G1syAeYvPZxqagQ0P7mgdX /qgnEWWuIcv4cTR6ZI5QNmqULAGtRkCtCNsphAD7cLBiV7UpV7yvURpKw6H8jHyDDZc8zP5P8QF9 abbRoeoTcPcDs/Ij0+JSX9fkdkqCvmUFYzy/GBb+hMWJ...
/tmp/cct7CPFw.o:在函数‘main’中: 19012705.c:(.text+0x88):对‘pow’ 定义 引用 collect2: error: ld returned 1 exit status linux中gcc没有默认链接math库 在编译时后面链接math库,即gcc xx.c -o xx -lm 如果在VSCode 中 引用 ,可以直接在.vscode下的文件中添加进去,具体做法如下博客: 如果你报了相同的 误,但是没有安装libtorch的话,可能是cmakelist中没有target_link_libraries(opencvt ${OpenCV_LIBS}) 本博客的重点在于解决同时配置opencv和libtorch时报的上面的 Ubuntu 16.04+opencv4.4+clion+libtorch1.4 关于在clion上配置libtorch的问题可以查看本人的另一篇博客 报 的特征
b'\xe5\xaf\xb9\xe2\x80\x98 std :: cout \xe2\x80\x99\xe6\x9c\xaa\xe5\xae\x9a\xe4\xb9\x89\xe7\x9a\x84\xe5\xbc\x95\xe7\x94\xa8' 这个字符序列是一个 Python 3 中的 bytes 类型的数据,如果需要对其进行处理需要进行解码操作。由于该字符序列中包含了非ASCII字符,所以需要指定对应的编码方式进行解码,例如: data = b'\xe5\xaf\xb9\xe2\x80\x98 std :: cout \xe2\x80\x99\xe6\x9c\xaa\xe5\xae\x9a\xe4\xb9\x89\xe7\x9a\x84\xe5\xbc\x95\xe7\x94\xa8' decoded_data = data.decode('utf-8') print(decoded_data) 解码后输出的结果为: 对‘ std :: cout 定义 引用 可以看出,该字符序列实际上是一个中文字符串,意思是“对‘ std :: cout 定义 引用 ”。这是一个 C++ 编译器报的 误信息。