目录

  • 前言
  • 一、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字符串。

打印字符串地址java 怎么打印string的地址值_指针

原因应该是重载过,实现的是输出以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);

实现效果如下:

打印字符串地址java 怎么打印string的地址值_printf_02

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:字符串
%%:"%"

参考