C++数组名的思考

C++数组名和编译器


目录


野生程序猿的故事

Markdown 是一种轻量级标记语言,它允许人们使用易读易写的纯文本格式编写文档,然后转换成格式丰富的HTML页面。 —— [ 维基百科 ]

我们在编程中经常会用到数组这种数据结构,使用C++作为编程语言的同学也经常会用到指针。指针在内存中存储的内容是一个地址,而数组名也可以说是一个地址,

C11规范

我在Coursera上看您的《计算概论A》的时候遇到一个关于数组名的问题:

c语言规范,说的是“如果数组名不是sizeof、alignof、&的操作数,不是用来初始化char数组的string,这时数组类型转化为指向数组第一个元素的指针”。

int a[3];
a++;

这里的数组名是++的操作数,按理说a应该转化为指向数组第一个元素的指针,也就是int*类型(在编译器中我也确认了a是int 类型),这时如果a是int 类型的话为什么不能对a进行++运算呢?

关于这点我的考虑是a在这里是int const类型的,所以a不能做++运算,然而为什么编译器不显示a是int const类型,而显示a是int *类型呢?

分配内存的含义,就是分配一个指针指向分配的内存的首地址,++相当于你挪动了这个地址指针,当然也就等于释放了内存
a++相当于释放数组的内存,编译器会报错。

代码块

代码块语法遵循标准markdown代码,例如:

@requires_authorization
def somefunc(param1='', param2=0):
    '''A docstring'''
    if param1 > param2: # interesting
        print 'Greater'
    return (param2 - param1 + 1) or None
class SomeClass:
    pass
>>> message = '''interpreter
... prompt'''

脚注

生成一个脚注1.


  1. 未经博主允许,请勿转载.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值