目录
- 前言
- 一、pandas是什么?
- 1.1而对于string对象的首地址呢?
- 1.2cout与printf
- 二、实例
- 1.示例
- 2.printf 的输出类型
- 参考
前言
char m_char[20] = "temp";
char *ptr_char= m_char;
对于m_char的地址或者ptr_char指针的值怎么输出呢?
一、pandas是什么?
对于指针变量来说, (void*)取到的是指针值,也就是目的地址,而&取到的是指针变量的地址。
char m_char[20] = "temp";
对m_char来说,
(void*)m_char 是“temp”存储的地址,
&m_char是指针变量m_char的地址。
如果不加(void*)会怎样呢?
cout << "m_char = " << m_char << endl;
cout << "(void *)m_char = " << (void *)m_char << endl;
cout会直接输出 temp字符串。
原因应该是重载过,实现的是输出以m_char 为首地址 ’\0‘为结尾的字符串。
同样是首地址,但是转换成void*以后重载函数不知道这个是字符串,就找到单纯输出值的重载来输出
1.1而对于string对象的首地址呢?
不要试图获得string的字符串首地址,这个是类的内部实现。
也就是string 是个类,并不是基础类型,对string的输出,也是string类内重载过的。
1.2cout与printf
printf 会按照你的想法输出,而cout有太多重载,很多不是按照自己的想法实现的。
主要是三点不同:
1.原理不同
2.格式不同
3.输出效率不同
其中前两点很清晰,效率问题,cin与cout 总是效率比scanf与printf低的。
因为标准流对象cin/cout为了普适性,继承体系很复杂,所以在对象的构造等方面会影响效率,因此总体效率比较低。如果根据特定的场景进行优化,效率可以更高一点。
二、实例
1.示例
实例示范了 对于指针而言,cout 和printf 实现的区别。并加入了(void*),能看出差别。
char m_char[20] = "temp";
char *ptr_char = new char(50);
ptr_char = m_char;
cout << "m_char = " << m_char << endl;
cout << "(void *)m_char = " << (void *)m_char << endl;
cout << "ptr_char = " << ptr_char << endl;
cout << "(void *)ptr_char = " << (void *)ptr_char << endl;
cout << "&ptr_char = " << &ptr_char << endl;
printf("************************************\n");
printf("m_char = %s \n", m_char);
printf("m_char = %p \n", m_char);
printf("ptr_char = %s \n", ptr_char);
printf("ptr_char = %p \n", ptr_char);
printf("&ptr_char = %p \n", &ptr_char);
实现效果如下:
2.printf 的输出类型
其中对于输出类型:
%a(%A):浮点数、十六进制数字和p-(P-)记数法(C99)
%c:字符
%d:有符号十进制整数
%f:浮点数(包括float和doulbe)
%e(%E):浮点数指数输出[e-(E-)记数法]
%g(%G):浮点数不显无意义的零"0"
%i:有符号十进制整数(与%d相同)
%u:无符号十进制整数
%o:八进制整数 e.g. 0123
%x(%X):十六进制整数0f(0F) e.g. 0x1234
%p:指针
%s:字符串
%%:"%"
参考