strlen与sizeof

1.strlen
   strlen的功能为计算字符串的长度,其函数声明为
size_t strlen(const char*);功能为计算字符串的长度,不包含‘\0’,’\0’是字符串的结束标志,而不是字符串的内容。
当调用strlen的实参的类型不是char类型,是char,int,char**,char (*)[n]或者字符数组等类型时,属于未定义行为,结果未知。由于C语言是弱类型语言,在编译的时候只给了提示但是做了隐式类型转换。

// char arr[] = { 'a', 'b', 'c', 'd', 'e', 'f' };

	// UB 对应着错误的代码
	//printf("%d\n", strlen(arr));		// 未定义行为(UB)
	//printf("%d\n", strlen(arr + 0));	// 未定义行为(UB)
	// *arr 得到的是 char 类型, strlen 要求的参数是 char* 类型的. 
	// printf("%d\n", strlen(*arr));	// 这个代码按理说, 是要编译出错的. 但是 c 是弱类型的编程语言, 把 char 和char* 就给隐式转换了
	// printf("%d\n", strlen(arr[1]));		// 效果同上

2.sizeof
  sizeof是一个运算符,用于计算变量或者类型在内存中占的字节数。在编译期执行。指针类型在32位系统下均含4个字节。

int arr[] = { 3, 2, 5 };
	printf("%d\n", sizeof(arr)); //12 arr为int[4]类型
	int a[3][4] = {
			{ 1, 2, 3, 4 }, //a[0]
			{ 5, 6, 7, 8 }, //a[1]
			{ 9, 10, 11, 12 }, //a[2]
	};
	// printf("%d\n", sizeof(a));	// 48  a为int[3][4]类型
	// printf("%d\n", sizeof(a[0][0]));	// 4 a[0][0] => int
	// printf("%d\n", sizeof(a[0]));  // 16 a[0] => int[4] 类型
	a[0]相当于*(a+0)a由int[3][4]类型转成指向第一元素的指针类型,即int(*)[4]类型解引用得到int[4]类型,占16个字节。
	// printf("%d\n", sizeof(a[0] + 1));	// 4 a[0] => int[4] 再 + 1 , 就隐式转成指针 int*
	// *(a[0]+1) => a[0][1] 等价 => 2
	// printf("%d\n", sizeof(   *  ( a[0] + 1 )  )    );	// 4 a[0] => int[4] 再 + 1 , 隐式转成 int*, 再 * 得到 int
	// printf("%d\n", sizeof(&a[0] + 1));		//4  a[0] => int[4]    &a[0] => int(*)[4]  再 + 1 还是数组指针  

	 printf("%d\n", sizeof(*(&a[0] + 1)));	// a[0] => int[4]  再&得到 int(*)[4] 再 + 1得到的还是 int(*)[4], 再解引用 int[4]
	// printf("%d\n", sizeof(*a)); // 16 *a => *(a + 0) => a[0] 结果 int[4]

数组名在参与解引用运算、加减运算和作为函数实参时会隐式转成指向首元素的指针。若a为有四个元素的整型数组名,a的类型为int[4],当作a或a+1的运算时,a被隐式转成int类型,且指向首元素。所以a得到首元素,a+1得到第二个元素的地址。
  若int a[3][4];a中有3个元素,每个元素又是一个拥有四个元素的数组。此时
a,a+1中,a隐式转成指向首元素的指针,即int(*)[4]类型,再解引用得到int[4]类型;+1得到第二个元素的地址,指向a中第二个一维数组。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值