在编译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++ 编译器报的
错
误信息。