char argv, char argv[], char* argv, char argv[][], char * argv[], char** argv, char (*argv)[]

来源:互联网 发布:电视剧后期制作软件 编辑:程序博客网 时间:2024/06/06 08:51

首先大家需要弄懂以下几个概念:
1:字符:这个很简单,比如 ”c” 、”h”, 我们对一个字符变量初始化是这样:char argv = ”c”;
2:字符串:从字面理解就是一串字符,比如: “china” 、 “student”等,它的本质是以空字符(\o)结尾的char数组(所以字符串跟字符数组是有区别的,字符数组并不要求结尾有空字符)。所以有这样的字符串初始化方式:
const char argv[6]=”china”或{“c”,”h”,”i”,”n”,”a”,”\o”};
const char * argv =”china”;
这两种初始化方式是等价的。主要差别在于,数组名argv是一个常量(数组名就是数组首元素的地址),而指针argv是一个变量(所以可以使用增量运算符,而数组名不可以),这个变量初始化的时候指向字符串的第一个字符,*argv=”c” ; printf(“%s”,argv))输出字符串;printf(“%c”,*argv)输出一个字符;
两者区别如下:
一. ”读“ ”写“ 能力
const char * argv =”china”; 此时”china”存放在常量区。通过指针只可以访问字符串常量,而不可以改变它。
而 const char argv[6]=”china”; 此时 “china”存放在栈。可以通过指针去访问和修改数组内容。
二. 赋值时刻
const char * argv =”china”; 是在编译时就确定了(因为为常量)。
而 const char argv[6]=”china”; 在运行时确定
三. 存取效率
const char * argv =”china”; 存于静态存储区。在栈上的数组比指针所指向字符串快。因此慢
而 const char argv[6]=”china”; 存于栈上。快
3:字符串数组:首先它是一个数组,其内部的元素是字符串,所以你可以把它理解为一个二维数组。
我们来看一个例子:
const char argv[3][8] = {“china”,”student”,”hdu”};
const char *argv[3] = {“china”,”student”,”hdu”};
一个是典型的二维数组(argv[0] = “china”,argv[1] =”student”,argv[2] =”hdu”),一个是指针数组(由3个指向char的指针组成的数组,此时的argv是个一维数组,数组里面的每一个元素都是一个char类型值的地址,第一个指针是argv[0],它是指向第一个字符串的第一个字符,第二个指针是argv[1],它是指向第二个字符串的第一个字符,后面以此类推,这里的argv数组实际上并不存放字符串,它只是存放字符串的地址(字符串存在程序用来存放常量的那部分内存中),可以把argv[0]看作表示第一个字符串,*argv[0]看成表示第一个字符串的第一个字符,printf(“%s”,argv[i]))输出字符串;printf(“%c”,*argv[i])输出一个字符)。
4: 可以由(2)中的阐述来看,const char *argv[]和const char **argv,它俩有等价的效果,类似与(2)中的关系。
5: char (*argv)[3]表示argv是指向含有3个char型的数组的指针。

原创粉丝点击