c++运行时决定数组大小 variable-length array

variable-length array是C99添加的一个特性,即数组的长度可以在运行时(run time)决定,而不是在编译时(compile time)。即,定义数组时不一定要使用 const int, 也可以使用变量、函数返回值等。 例如

1 int main(){
2     int a=5, b=6;
3     int arr1[a];
4     int arr2[ min(a,b) ];
5     int arr3[ rand()%10 ];
6
7 }

这些定义数组的方式都是合法的。

不过,这种声明方式好像只适用于局部变量,全局变量是不行的。下面的用法会报错。

int a=100;
int b[a];

int main(){
    return 0;
}

允许运行时决定数组大小会带来很多方便。

不过,在C11标准时,variable-length array变成了一个可选的特性,不要求编译器必须实现。笔者测试了手头可用编译器的默认支持情况。

编译器 是否支持variable-length array
gcc 4.8 支持
clang 3.4 支持
visual studio 2012 不支持
visual studio 2013 不支持

c,c++隐藏的东西太多,确实很麻烦。variable-length array这一特性,如果在跨平台开发时,需要慎重使用。

另外,看很多地方翻译为 “变长数组”, 其实不是很合适,这和其他语言中的边长数组还是不同的。

时间: 2024-10-08 15:49:12

c++运行时决定数组大小 variable-length array的相关文章

VS2010 基本运行时检查 和“Stack around the variable XX was corrupted”之间的关系

下午在重新整理一份代码,中间遇到这么一个问题:要么出现内存访问冲突,要么出现“Stack around the variable XX was corrupted”错误. 很是恼火! 先出现的是“Stack around the variable XX was corrupted”错误,网上查到的第一种解决方案是让在“项目-属性-配置属性-C/C++-代码生成中”,将基本运行时检查设置成默认值,原来的值为“两者(/RTC1,等同于 /RTCsu) (/RTC1)”. 修改后重新生成,错误是不见了

java-基础入门-泛型数组列表-解决运行时动态更改数组的问题

泛型数组列表,主要是为了解决运行时动态更改数组的问题 平常我们会定义一个部门里面的人员的一个数组, 但是在实际业务当中,这个数组的大小往往是不确定的, 如果定义过大,那么会浪费空间,定义过小,又不够用, 因为为了解决运行时动态更改数组的问题,我们提出下面的解决方案. package com.ray.object; import java.util.ArrayList; /** * 泛型数组列表 ,解决运行时动态更改数组的问题 * * @author ray * @since 2015-05-04

使用Net.Sockets.TcpListener和Net.Sockets.TcpClient进行图片传输时如何精确控制接收缓存数组大小

<span style="font-size:18px;">在dotnet平台Net.Sockets.TcpListener和Net.Sockets.TcpClient已经为我们封装了所有Socket关于tcp部分,操作也更为简单,面向数据流.使用TcpClient的GetStream方法获取数据流后可以方便的对数据流进行读写操作,就如同本地磁盘的文件读写一样,使得程序员在设计程序时更为便捷简单.</span> 但如果你使用过这两个对象进行数据传输的时候,你会发

运行时手动伸缩控件大小

public partial class PanelX : UserControl { private Point oldXY; //private static PanelX instance; //public DataRow dr = null; public delegate void RowSelectedEventHandler(object sender, EventArgs e); public event RowSelectedEventHandler RowSelected;

winform窗体运行时的大小和设计时不一致

窗体设置的尺寸为1946*850,而电脑分辨率是1920*1280 按说宽度已经超过屏幕大小很多了,应该显示占满屏幕宽度才对,但是运行时宽度只有设计时的一半 高度最多只能是1946像素,再拉大也不管用,而高度可以设置 解决办法,把窗体的AutoScaleMode改为None 这个属性的意思是:确定当屏幕分辨率或字体更改时窗体或控件如何缩放 而我不小心设置成了Font,就显示不对了 原文地址:https://www.cnblogs.com/yaotome/p/10026320.html

深入探索.NET内部了解CLR如何创建运行时对象

前言 SystemDomain, SharedDomain, and DefaultDomain. 对象布局和内存细节. 方法表布局. 方法分派(Method dispatching). 因为公共语言运行时(CLR)即将成为在Windows上创建应用程序的主角级基础架构, 多掌握点关于CLR的深度认识会帮助你构建高效的, 工业级健壮的应用程序. 在这篇文章中, 我们会浏览,调查CLR的内在本质, 包括对象实例布局, 方法表的布局, 方法分派, 基于接口的分派, 和各种各样的数据结构. 我们会使用

iOS开发——高级特性&amp;Runtime运行时特性详解

Runtime运行时特性详解 本文详细整理了 Cocoa 的 Runtime 系统的知识,它使得 Objective-C 如虎添翼,具备了灵活的动态特性,使这门古老的语言焕发生机.主要内容如下: 引言 简介 与Runtime交互 Runtime术语 消息 动态方法解析 消息转发 健壮的实例变量(Non Fragile ivars) Objective-C Associated Objects Method Swizzling 总结 引言 曾经觉得Objc特别方便上手,面对着 Cocoa 中大量

ART运行时垃圾收集(GC)过程分析

ART运行时与Dalvik虚拟机一样,都使用了Mark-Sweep算法进行垃圾回收,因此它们的垃圾回收流程在总体上是一致的.但是ART运行时对堆的划分更加细致,因而在此基础上实现了更多样的回收策略.不同的策略有不同的回收力度,力度越大的回收策略,每次回收的内存就越多,并且它们都有各自的使用情景.这样就可以使得每次执行GC时,可以最大限度地减少应用程序停顿.本文就详细分析ART运行时的垃圾收集过程. 老罗的新浪微博:http://weibo.com/shengyangluo,欢迎关注! ART运行

Objective-C Runtime 运行时之一:类与对象

Objective-C语言是一门动态语言,它将很多静态语言在编译和链接时期做的事放到了运行时来处理.这种动态语言的优势在于:我们写代码时能够更具灵活性,如我们可以把消息转发给我们想要的对象,或者随意交换一个方法的实现等. 这种特性意味着Objective-C不仅需要一个编译器,还需要一个运行时系统来执行编译的代码.对于Objective-C来说,这个运行时系统就像一个操作系统一样:它让所有的工作可以正常的运行.这个运行时系统即Objc Runtime.Objc Runtime其实是一个Runti