关于数组以及函数的一些问题与解答

1.C语言数组下标在低层次上处理会带来什么样的缺点?

答:程序在运行时你无法知道一个数组到底由多大或一个数组下标是否有效。ANSI/ISO C标准没有对使用越界下标的行为做出定义,因此,一个越界下标有可能导致几种后果。(1)程序仍能正确运行;(2) 程序会异常终止或崩溃;(3)程序能继续运行,但无法得到正确的结果;(4)其他情况。 换句话说,你不知道程序此后会做做出什么反应,这会带来很大麻烦。

2.在什么情况下,数组和指针是可以等价的?

答 : 当数组出现在一个表达式中时,它和指向数组中的第一个元素的指针是等价的,因此数组和指针几乎可以呼唤使用。不过,使用指针要比使用数组下标快两倍。另一种情况,将数组作为参数传递给函数和将指向数组中第一个元素的指针传递给函数是完全等价的。

3.数组的下标总是从0开始吗?

答:是的,对数组a【MAX】(MAX是一个编译时可知的值)来说,它的第一个和最后一个元素分别是a【0】和a【MAX-1】。

4.可以使用数组后面的一个元素的地址吗?

答:可以使用数组后面第一个元素的地址,但不可以查看该地址中的值。

5.地址是由哪几部分组成的?

答:地址是由两部分组成的:第一部分是一个指向某一块内存的起始点的指针(即基地址),第二部分是相对于这块内存的起始点的地址偏移量。这种地址结构被称为段地址结构,子程序的调用通常就是通过在栈指针上加上一个地址偏移量来实现的。

6.array_name和&array_name有什么区别?

答:array_name是指向数组中的第一个元素的指针,&array_name是指向整个数组的指针。

7.为什么用const说明的常量不能用来定义一个数组的初始大小?

答:并不是所有的常量都可以用来定义一个数组的初始大小,在C程序中,只有C语言的长量表达式才能用来定义一个数组的初始大小。

8.字符串和数组有什么不同?

答:数组的元素可以是任意一种类型,而字符串是一种的数组,它使用了一种众所周知的,确定长度的规则。

9.函数的声明与定义的不同?

答:函数的声明就是声称一个函数的名字,只是说明函数的名字,不涉及函数的实现,即没有函数体,所以函数的声明只包括前三个部分。函数的定义就是确定一个函数的意义,即让函数具有某项功能,但是这里可不是只有函数体,要指明这个函数体是那个函数的,所以函数的定义包含了一个函数的所有部分。

10.C语言中的参数传递是怎样的?

答:C中实参和形参之间的数据都是单向的“值传递”方式,包括指针变量和数组名做参数的情况。C要求函数的实参有确定的值,在函数调用是给形参分配相应的内存单元,同时将实参的“值”赋给形参,实现数据从实参到形参的传递。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值