char *a 与char a[] 的区别

简介: char *a = “hello” 中的a是指向第一个字符‘h’的一个指针char a[20] = “hello” 中数组名a也是执行数组第一个字符‘h’的指针*但二者并不相同:*看实例:把两个字符串相加: 结果:对比:结果: 把字符串加到指针所指的字串上去,出现段错误,本质原因:*d=”0123456789″存放在常量区,是无法修的。

char *a = “hello” 中的a是指向第一个字符‘h’的一个指针

char a[20] = “hello” 中数组名a也是执行数组第一个字符‘h’的指针

*但二者并不相同:*

看实例:把两个字符串相加:

这里写图片描述

结果:

这里写图片描述

对比:

这里写图片描述

结果:

这里写图片描述


把字符串加到指针所指的字串上去,出现段错误,本质原因:*d=”0123456789″存放在常量区,是无法修的。而数组是存放在栈中,是可以修改的。两者区别如下:

一. ”读“ ”写“ 能力

char *a = “abcd”; 此时”abcd”存放在常量区。通过指针只可以访问字符串常量,而不可以改变它。
而char a[20] = “abcd”; 此时 “abcd”存放在栈。可以通过指针去访问和修改数组内容。

二. 赋值时刻

char *a = “abcd”; 是在编译时就确定了(因为为常量)。
而char a[20] = “abcd”; 在运行时确定

三. 存取效率

char *a = “abcd”; 存于静态存储区。在栈上的数组比指针所指向字符串快。因此慢
而char a[20] = “abcd”; 存于栈上。快
另外注意:

char a[] = “01234”,虽然没有指明字符串的长度,但是此时系统已经开好了,就是大小为6—–‘0’ ‘1’ ‘2’ ‘3’ ‘4’ ‘5’ ‘\0’,(注意strlen(a)是不计‘’)

看一结构中出现的同样的问题:

这样红色部分在调用Init函数时会出现“Segment Default”, 因为此时 指针n是静态的,只有“读”的本事,不可以改变。


内存分配方式

内存分配有三种:静态存储区、堆区和栈区。他们的功能不同,对他们使用方式也就不同。

静态存储区:内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。它主要存放静态数据、全局数据和常量。

栈区:在执行函数时,函数(包括main函数)内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集中,效率很高,但是分配的内存容量有限。(任何变量都处于站区,例如int a[] = {1, 2},变量a处于栈区。数组的内容也存在于栈区。)

堆区:亦称动态内存分配。程序在运行的时候用malloc或new申请任意大小的内存,程序员自己负责在适当的时候用free或delete释放内存。动态内存的生存期可以由我们决定,如果我们不释放内存,程序将在最后才释放掉动态内存。
但是,良好的编程习惯是:如果某动态内存不再使用,需要将其释放掉,并立即将指针置位NULL,防止产生野指针。

相关文章
|
1月前
|
存储 数据库
5. CHAR和VARCHAR的区别?
`CHAR`和`VARCHAR`在数据库中有所不同:`CHAR`长度固定,用空格填充,存储效率高,英文占1字节,汉字占2字节;而`VARCHAR`长度可变,节省空间,英文和汉字都占2字节。
16 0
|
1月前
|
存储 SQL NoSQL
面试题:char和varchar的区别?
字节面试题:char和varchar的区别?
28 0
|
2月前
|
存储 机器学习/深度学习 关系型数据库
mysql中char和varchar的区别
mysql中char和varchar的区别
36 1
|
8月前
|
存储 SQL 数据库
char、varchar、nvarchar、text的区别
char、varchar、nvarchar、text的区别
36 0
|
10月前
|
存储
char和varchar的区别(秒懂!)
char和varchar的区别(秒懂!)
88 0
|
5月前
|
存储 关系型数据库 MySQL
MySQL之varchar和char的区别
MySQL之varchar和char的区别
18 0
|
5月前
|
存储 关系型数据库 MySQL
MySQL 总结char与varchar的区别
MySQL 总结char与varchar的区别
30 0
|
9月前
|
存储 SQL Oracle
通过实战探索数据库中的char、varchar、varchar2、nvarchar2的部分区别
通过实战探索数据库中的char、varchar、varchar2、nvarchar2的部分区别
|
9月前
|
存储 Java 数据安全/隐私保护
Java 最常见的面试题:char 和 varchar 的区别是什么?
Java 最常见的面试题:char 和 varchar 的区别是什么?
|
10月前
|
存储 关系型数据库 MySQL
MySQL 中 int (10) 和 char (10) 和 varchar (10) 的区别
MySQL 中 int (10) 和 char (10) 和 varchar (10) 的区别
112 0