char型数组与int型数组区别
ints[]={1,2,3,4,5};chars[]={'a','b','c','d','e','\0'};分别使用语句cout<<s<<endl;时会有完全不同的结果问...
int s[]={1,2,3,4,5};
char s[]={'a','b','c','d','e','\0'};
分别使用语句cout << s << endl;时会有完全不同的结果
问题:出现这种情况是由什么机制决定的?
我的意思是 一个会输出地址 一个会输出内容 这是为什么? 展开
char s[]={'a','b','c','d','e','\0'};
分别使用语句cout << s << endl;时会有完全不同的结果
问题:出现这种情况是由什么机制决定的?
我的意思是 一个会输出地址 一个会输出内容 这是为什么? 展开
展开全部
char 表示的数值范围是: -128 ~ 127 unsigned char 表示的数值范围是: 0 ~ 255
int 是2字节(16位处理器)或4字节(32、64) long int 32 位, short int 16 位。数值范围 不同。
char 是1字节。
当Int 表达0-127 的时候,他只用了一个字节的空间,另外的字节并没用使用;而char 字节是只有一个字节的大小,所以这个图片的意思为在Int表达0-127的时候,他和char的值是一样的,而且是正常的。
但是可以通过使用%c 或%d来让这个变量表示它的值所代表的asc2值或者它的值的大小。 int a=97;
printf(“%d" ,a) //output 数字97
printf("%c" ,a) //output 'a' 因为a的ASC值为97;
INT函数
将数字向下舍入到最接近的整数,即取不大于自变量的最大整数,例如:int[6.4]=6 int[-9.7]= -10 语法 INT(number) Number 需要进行向下舍入取整的实数。 示例 如果将示例复制到空白工作表中,可能会更易于理解该示例。 A 1 数据 2 19.5
公式 说明(结果)
=INT(8.9) 将8.9向下舍入到最接近的整数(8) =INT(-8.9) 将-8.9向下舍入到最接近的整数(-9)
=A2-INT(A2) 返回单元格A2中正实数的小数部分(0.5)。
int 是2字节(16位处理器)或4字节(32、64) long int 32 位, short int 16 位。数值范围 不同。
char 是1字节。
当Int 表达0-127 的时候,他只用了一个字节的空间,另外的字节并没用使用;而char 字节是只有一个字节的大小,所以这个图片的意思为在Int表达0-127的时候,他和char的值是一样的,而且是正常的。
但是可以通过使用%c 或%d来让这个变量表示它的值所代表的asc2值或者它的值的大小。 int a=97;
printf(“%d" ,a) //output 数字97
printf("%c" ,a) //output 'a' 因为a的ASC值为97;
INT函数
将数字向下舍入到最接近的整数,即取不大于自变量的最大整数,例如:int[6.4]=6 int[-9.7]= -10 语法 INT(number) Number 需要进行向下舍入取整的实数。 示例 如果将示例复制到空白工作表中,可能会更易于理解该示例。 A 1 数据 2 19.5
公式 说明(结果)
=INT(8.9) 将8.9向下舍入到最接近的整数(8) =INT(-8.9) 将-8.9向下舍入到最接近的整数(-9)
=A2-INT(A2) 返回单元格A2中正实数的小数部分(0.5)。
展开全部
你这里对s定义了两次数组,重复定义,编译都通不过的,怎么输出,这是我在VC6.0中编译的错误提示信息:
error C2371: 's' : redefinition; different basic types
如果只定义其中一个数组,有时结果不同,是这样的:定义数组时s即是数组第一个元素的地址也是,也是数组的起始地址。在VC6.0环境下,定义int数组时输出s是数组起始地址,当定义char时先输出第一个元素,不为空接着输出下个,直到遇到空字符结束为止。
error C2371: 's' : redefinition; different basic types
如果只定义其中一个数组,有时结果不同,是这样的:定义数组时s即是数组第一个元素的地址也是,也是数组的起始地址。在VC6.0环境下,定义int数组时输出s是数组起始地址,当定义char时先输出第一个元素,不为空接着输出下个,直到遇到空字符结束为止。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
操作符重载,你cout << (void*)s << end;再试试?
这个就是操作符重载:
#include <iostream>
using namespace std;
struct A {
A& operator<<(int i){cout<<i;return *this;}
A& operator<<(void*i){cout<<(void*)i;return *this;}
A& operator<<(ostream& (*op) (ostream&)){op(cout);return *this;}
};
int main()
{
A a;
a << 1 << endl;
a << (void*)&a << endl;
return 0;
}
这个就是操作符重载:
#include <iostream>
using namespace std;
struct A {
A& operator<<(int i){cout<<i;return *this;}
A& operator<<(void*i){cout<<(void*)i;return *this;}
A& operator<<(ostream& (*op) (ostream&)){op(cout);return *this;}
};
int main()
{
A a;
a << 1 << endl;
a << (void*)&a << endl;
return 0;
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
数组名是地址,所以整数数组输出地址.
但c++规定使用字符数组名就是使用它保存的字符串
所以字符数组输出内容
但c++规定使用字符数组名就是使用它保存的字符串
所以字符数组输出内容
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
char字符是以ASC码为实际保存数值的输出的当然是ASC码了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询