C++测量二维数组行列数

在C++中,没有直接测量二维数组大小的函数,因此需要通过sizeof()函数来进一步计算。

目录

一、sizeof()函数基础语法

1.定义

2.语法

二、sizeof()函数进阶

1.      基本数据类型——sizeof

2.      结构体——sizeof

3.  联合体——sizeof

4.数组——sizeof

5.指针——sizeof

6. 函数——sizeof

 三、测量二维数组行列数


一、sizeof()函数基础语法

1.定义

sizeof是一个操作符(operator),返回一个对象或类型所占内存的字节数

2.语法

sizeof有三种语法形式:

1)  sizeof (object);  //sizeof (对象)

2)  sizeof object;   //sizeof 对象

3)  sizeof (type_name);  //sizeof (类型)

对象可以是各种类型的变量,以及表达式(一般sizeof不会对表达式进行计算)。

sizeof (表达式); //值为表达式的最终结果的数据类型的大小

sizeof对对象求内存大小,最终都是转换为对对象的数据类型进行求值。

int i;  
sizeof(int); //值为4  
sizeof(i); //值为4,等价于sizeof(int)  
sizeof i; //值为4  
sizeof(3); //值为4,等价于sizeof(int),因为数字3类型为int  
sizeof(3 + 3.14); //值为8,等价于sizeof(double),因为该表达式的结果的类型为double  

二、sizeof()函数进阶

1.      基本数据类型——sizeof

基本数据类型指,short、int、long、float、double内置数据类型

注:它们内存大小与系统相关,不同系统下取值可能不同。

2.      结构体——sizeof

结构体的sizeof涉及到字节对齐问题。

为什么需要字节对齐?计算机组成原理教导我们这样有助于加快计算机的取数速度,否则就得多花指令周期了。为此,编译器默认会对结构体进行处理(实际上其它地方的数据变量也是如此),让宽度为2的基本数据类型(short等)都位于能被2整除的地址上,让宽度为4的基本数据类型(int等)都位于能被4整除的地址上,依次类推。这样,两个数中间就可能需要加入填充字节,所以整个结构体的sizeof值就增长了。

字节对齐的细节和编译器的实现相关,但一般而言,满足三个准则:

1)  结构体变量的首地址能够被其最宽基本类型成员的大小所整除。

2)  结构体的每个成员相对于结构体首地址的偏移量(offset)都是成员大小的整数倍,如有需要,编译器会在成员之间加上填充字节(internal adding)。

3)  结构体的总大小为结构体最宽基本类型成员大小的整数倍,如有需要,编译器会在最末一个成员后加上填充字节(trailing padding)。

    注意:空结构体(不含数据成员)的sizeof值为1试想一个“不占空间“的变量如何被取地址、两个不同的“空结构体”变量又如何得以区分呢,于是,“空结构体”变量也得被存储,这样编译器也就只能为其分配一个字节的空间用于占位了。

实例:

#include <iostream>
#include <stdlib.h>
using namespace std;

int main()
{
	int a, b, c;

	struct S1
	{
		char a;
		int b;
	};
	a=sizeof(S1); //值为8,字节对齐,在char之后会填充3个字节。  

	struct S2
	{
		int b;
		char a;
	};
	b=sizeof(S2); //值为8,字节对齐,在char之后会填充3个字节。  

	struct S3
	{
	};
	c=sizeof(S3); //值为1,空结构体也占内存

	cout << a << ' ' << b << ' ' << c;
	system("pause");
}

输出结果:

3.  联合体——sizeof

在内存组织上,结构体是顺序式的;联合体则是重叠式,各成员共享一段内存。所以,整个联合体的sizeof每个成员sizeof的最大值

实例:

#include <iostream>
#include <stdlib.h>
using namespace std;

int main()
{
	int num;

	union u
	{
		int a;
		float b;
		double c;
		char d;
	};

	num =sizeof(u);  //值为8

	cout << num << '\n';
	system("pause");
}

输出结果:

4.数组——sizeof

数组的sizeof值等于数组所占用的内存字节数。

注意:1)当字符数组表示字符串时,其sizeof值将’/0’计算进去。

            2)当数组为形参时,其sizeof值相当于指针的sizeof值。

实例:

#include <iostream>
#include <stdlib.h>
using namespace std;

int main()
{
	char a[10];
	char n[] = "abc";

	cout << "char a[10]  " << sizeof(a) << endl;//数组,值为10  

	cout << "char n[] = abc   "  << sizeof(n) << endl;//字符串数组,将'/0'计算进去,值为4

	system("pause");
}


void func(char a[3])
{
	int c = sizeof(a); //c = 4,因为这里a不在是数组类型,而是指针,相当于char *a。  
}

void funcN(char b[])
{
	int cN = sizeof(b); //cN = 4,理由同上。  
}

输出结果:

 

5.指针——sizeof

指针是用来记录另一个对象的地址,所以指针的内存大小当然就等于计算机内部地址总线的宽度

在32位计算机中,一个指针变量的返回值必定是4。

注:指针变量的sizeof值与指针所指的对象没有任何关系。

实例:

#include <iostream>
#include <stdlib.h>
using namespace std;

int main()
{	char *b = "helloworld";
	char *c[10];
	double *d;
	int **e;
	void(*pf)();

	cout << "char *b =helloworld /      "  << sizeof(b) << endl;//指针指向字符串,值为4  
	cout << "char *b                    " << sizeof(*b) << endl; //指针指向字符,值为1  
	cout << "double *d                  " << sizeof(d) << endl;//指针,值为4  
	cout << "double *d                  " << sizeof(*d) << endl;//指针指向浮点数,值为8  
	cout << "int **e                    " << sizeof(e) << endl;//指针指向指针,值为4  
	cout << "char *c[10]                " << sizeof(c) << endl;//指针数组,值为40  
	cout << "void (*pf)();              " << sizeof(pf) << endl;//函数指针,值为4

	system("pause");
}

输出结果:

6. 函数——sizeof

sizeof可对一个函数调用求值,其结果是函数返回值类型的大小,函数并不会被调用

对函数求值的形式:sizeof(函数名(实参表))

注:   1)不可以对返回值类型为空的函数求值。 

            2)不可以对函数名求值。

           3)对有参数的函数,在用sizeof时,须写上实参表。

实例:

#include <iostream>
#include <stdlib.h>
using namespace std;

float FuncP(int a, float b)
{
	return a + b;
}

int FuncNP()
{
	return 3;
}

void Func()
{
}

int main()
{
	cout << sizeof(FuncP(3, 0.4)) << endl; //OK,值为4,sizeof(FuncP(3,0.4))相当于sizeof(float)  
	cout << sizeof(FuncNP()) << endl; //OK,值为4,sizeof(FuncNP())相当于sizeof(int)  
									  /*cout<<sizeof(Func())<<endl; //error,sizeof不能对返回值为空类型的函数求值*/
									  /*cout<<sizeof(FuncNP)<<endl; //error,sizeof不能对函数名求值*/
	system("pause");
}

输出:

 三、测量二维数组行列数

计算二维数组大小实例:

#include <iostream>
#include <stdlib.h>
using namespace std;

int main()
{
	int a[2][3] = { 1, 2, 3, 4, 1,2};

	int lines, row, column;

	lines = sizeof(a) / sizeof(a[0][0]);    // 数组数据总个数
	row = sizeof(a) / sizeof(a[0]);         // 行数
	column = lines / row;                   // 列数

	cout << lines << ' ' << row << ' ' << column;
	system("pause");
}

输出结果:

 

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

珞瑜·

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值