上节内容中,我们详细的分析了argv的类型,并将其演变为了一个二维数组。这样做的目的是建立一个从简单到复杂的理论过程。教程的最后也明确的说明了,这两者本质的不同在于类型。char argv[][5]具有静态性,而 char *argv[5]则具有动态性,这节内容我们逐步向动态性靠近。
对于char *argv[2],我们可能已经习惯了下面的用法:
那对于 int *argv[2]呢?
不幸的是,上面的赋值是错误的。根本原是因为对于int *argv[2]的类型没有理解。数组要求每个元素都是一个int*指针,而我们却赋予它一个int数值常量3/4,两个类型不一致,这就导致错误了。
你可能要说,那为什么char *argv的赋值就是正确呢?现在我们反推。这个数组要求每个元素指向char*数据,反向证明cs.glimix.com字符串可以转化为一个char*指针。事实也是如此,C语言中常量字符串存储于静态内存区域,它们不能被修改,但可以被字符指针指向。
明白了这个道理之后,我们来看如何为int *argv[2]设置正确的初始化。它的每个元素都是一个int*指针,要让指针有效,就是要让它指向一个有效的存储空间,可以是一个已知变量的地址,也可以是一个动态分配的存储空间。下面的程序展示了这两种方案。
你会注意到,我们为argv2[1]分配了一个可以存储3个int数值的空间。而argv2[0]则指向一个已知变量的地址,它只有一个元素。这表明指针数组中的每一个元素可以有不同维度的大小。事实上,由argv1存储两个不同长度的字符串,你也可以有所感悟。
程序的最后,我们使用free释放掉了为argv2[1]分配的内存,以免发生内存泄露。argv2[0]并不是由malloc分配的,因此不需要做free工作。
领取专属 10元无门槛券
私享最新 技术干货