数组概述
2016-02-18 21:30
211 查看
摘要
主要对数组相关的基础知识进行概述,主要内容有数组的定义及相关概念,数组的越界现象,数组空间的初始化,字符串处理的函数,非字符的内存处理,指针数组数组的定义及相关概念
数组其实是内存分配的一种形式,其用法和指针十分类似。数组也是定义了一个内存空间。在初始化数组中,需要命名数组命”数据类型 数组名[SIZE]“SIZE表示数组中元素的个数,每一个元素是前面数据类型定义的。注意在数组的使用中仍然可能存在越界的情况。
程序如下:
#include <stdio.h> int main (void ) { int a[3]={1,2,3}; const int b=0; a[3]=40; printf("b=%d\n",a[3]); return 0; }
通过如上程序,运用a数组越界赋值就能修改b的内容,尽管b是用const修饰的。运行结果如下所示。
由此可知,指针与数组在指向地址的时候有很多类似的地方,但是,数组也有自己独到的地方,比如数组名其实是一个常量,数组名是不能改变的。所以数组名也同样不能运用a++运算。
数组的运用a[i]=XXX,在通常情况下i是大于等于0的,但是如果用a[-1]也是可以得,只是数组越界向下进行指向,编译器是不会报错的。
数组的空间初始化
1、按照标签逐一处理int a[10];//[0-9] a[0]=xx; a[1]=xx;
2、利用编译器逐一处理:注意第一次的赋值初始化,其具体用法如下所示:
int a[10] ={0,1,2,3,4,5,6,7,8,9};//其实这一部分编译器也会逐一对每个元素进行复制
注意:数组空间的初始化和变量的初始化本质不同,在嵌入式开发过程中,尤其是裸机开发的时候,空间初始化往往需要调用库函数或者单独为之设计程序
char buff[10]={'a','b','c'};
(1)buf存放的数据,对格式没有要求;
(2)buf存放的是字符串,则需要以’/0’作为结束符
char buff[]={"Hello World\n"}; char buff[5]={"abc"}; char buff[]="abc";//"abc"是可以改变的 char *p = "abc";//"abc"是一个常量,不能改变
3、再次赋值:需要对每个元素进行逐一处理。
经典错误:buff=”fgh”;
在C语言中也有一些针对字符串的函数,可以调用 string.h中
#include <stdio.h> #include <string.h> int main (void ) { char buff1[]="Hello World."; char buff2[]="abc"; strcpy(buff1,"abc"); strcpy(buff2,"Hello World"); printf("the buff1 is \" %s\" .\n",buff1 ); printf("The buff2 is \" %s \" .\n",buff2); return 0
虽然数组修改了,但是也出现了一些错误,错误先不进行深入分析。可以看出这个函数虽然功能可以满足复制数组的功能,但是可能存在内存的泄露,在使用中要十分慎重。在通常使用中,常常使用strncpy。
非字符空间
比如数据采集,在AD采集可能存在数据在0x00-0xFF当中。如果运用 char buf[10]进行声明,可能与字符串产生歧义。因此在实际工程中通常运用 unsigned char buf[10]。
:**注意:1、由于buf中的数据不是字符串,因此不能用string.h的函数。
2、数据的copy通常运用memcpy函数**
函数memcpy (目的地址,源地址,字节):
int buf1[10]; int buf2[20]; memcpy(buf1,buf2,10*sizeof(int));
指针数组
定义方式:int * a[100],与二级指针类似。相关文章推荐
- 关于指针的一些事情
- 我是运营,我没有假期
- IE7降低内存和降低CPU的几个技巧
- DB2数据库的安装
- C#实现把指定数据写入串口
- “传奇”图象数据存储方式
- 修复mysql数据库
- 如何高效的使用内存
- DOS下内存的配置
- XP/win2003下发现1G的内存比512M还慢的解决方法
- 浅析SQL数据操作语句
- SQLServer 数据导入导出的几种方法小结
- MySQL数据备份之mysqldump的使用详解
- PowerShell实现动态获取当前脚本运行时消耗的内存
- C#实现窗体间传递数据实例
- C#实现把dgv里的数据完整的复制到一张内存表的方法
- SQL语句实现查询SQL Server内存使用状况
- 给你的数据库文件减肥
- Oracle数据更改后出错的解决方法
- Oracle数据库数据丢失恢复的几种方法总结