百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

C# - 初识数组 033_c#数组用法

wptr33 2025-09-01 15:47 7 浏览

数组:是引用类型的数据结构;是一个存储同一数据类型元素有固定大小有顺序的集合;复杂数据类型的一种

数组的语法格式

//方式1
数据类型[] 数组名 = new 数据类型[数组的长度];
[]表示要声明的是一个数组//这里不是省略的意思
数据名:就是为数组起一个要求符合变量的命名规则的名字
new 数据类型[数据的长度] 表示在内存中开辟的数组长度
//声明数组时一定是可以表示正整数长度的数据如
//整形数字int,byte,或者可以转换为数组下标范围正整数的其他类型肉"0"等
//长度必须有,即使长度为0
//如 int[] nums = new int[0];开辟长度为0的数组
new 后面的数据类型必须与[]前面的类型一致
因为 数组声明时不存在隐式或显示类型转换
//int[] nums=new float[0]; //因此 此数组格式声明错误 
//==============================
int[] numbers = new int[10];
表示在内存开辟了10个可以存储int类型的空间
这一组空间的名称叫 numbers
数组中的numbers[下标]被称之为数组的一个变量
数组中的每个变量又被称之为 元素
可以通过下标或索引器访问数组的元素
第一个元素的下标是0,最后一个元素的下标是9,也就是:数组的长度-1
通过访问下标可以对每个元素进行赋值,修改与使用
numbers[9]=10;
为数组的元素numbers[9]赋值为10
//声明一个类型为int 名称为numbers 长度为10的 数组
int[] numbers = new int[10];
//通过下标为具体元素赋值
numbers[0] = 1;
numbers[9] = 10;
//打印输出数组元素
Console.WriteLine("numbers[9]={0}", numbers[9]);
//通过下标修改具体元素的值
numbers[9] = 100;//修改下标为9的元素其值变为100
//打印输出数组元素
Console.WriteLine("numbers[0]={0}", numbers[0]);
Console.WriteLine("numbers[9]={0}", numbers[9]);
Console.ReadKey();

数组名称,数组元素与元素的值在内存中的表现形式与关系

数组元素的赋值范围与数组的类型有关,与数组的长度无关

byte[] nums = new byte[258];
//byte类型的范围为0-255 
//声明数组长度 设置为258不会报错
//赋值/使用时不报错的情况
nums[258]=3;//与数组长度无关,即使声明数组长度为999999999
//赋值/使用时报错的情况
//超出byte的范围
nums[0]=256;//与赋值范围有关 
//=================================
//不建议这么做  没意义
byte[] nums = new byte[999999];

byte数组常用于如文件流等

数组的注意事项

1 声明什么类型的数组,数组中只能存储什么类型范围内(数组类)的数据; 如int类型的数组,其元素值只能赋值int类型,不能为其赋值其他类型的数据(除非可以转换为int类型)

由图中(行号33)可以看出只能赋值显示(强制)类型转换的数据,不能赋值隐式类型转换的数据

2 各个类型的元素都有自己类型的默认值

数组元素的默认值就是基本数据类型各自的默认值;单个使用的规则:声明一>赋值一>使用,必须赋初始值;基本数据类型放置在复杂数据类型中可以不必赋初始值

//单个使用
int num=6;//必须赋初始值后才能使用

复杂类型:1)枚举就是一个枚举成员的第一个(底层就是int类型,本例中) 2)结构与数组就是自己成员变量各个的类型的默认值

 class Program
 {
     enum MyEnum
        {
            男, 女
        }
     struct MyStruct
        {
            public string name;
            public int age;
        }
     static void Main(string[] args)
     {
         //基本数据类型的默认值
         int[] numbers = new int[1];//代表整形数值的与decimal类型 默认值为0
         float[] fs = new float[1];//代表float,double 默认值为0.0
         string[] s = new string[1];//代表string与object 默认值为null 
         char[] cs = new char[1];//默认值为0或ASCII码表的第一个
         bool[] bs = new bool[1];//默认值为false
         //复杂类型的默认值
         MyEnum Gender;
         MyStruct Info;
        MyEnum[] gs = new MyEnum[3];//枚举类型数组
        Student[] stus = new Student[3];//结构类型数组
     }
}

3 声明数组时必须确定数组的长度,长度一旦确定不可改变

上面数组的变形格式

//正确的格式
int[] nums2;//声明数组类型的变量
nums=new int[9];//比较常用
//错误的格式
int[] nums2=new nums;
nums[9];

必须确定数组的长度:

1)声明数组时要确定该数组需要在内存中开辟多大的空间

2)数组在内存中开辟的是连续的一段存储空间

数组没有添加/删除元素的方法,因此长度无法改变;可以通过两个数组实现另一种意义的改变数组长度(了解即可)

//假设不想要某些数据
int[] nums1 = new int[5];
//只需要下标为0,2,4的数据有3个元素
int[] nums2 = new int[3];
//将需要的数据存储在新数组中
nums2[0]=nums1[0];
nums2[1]=nums1[2];
nums2[2]=nums1[4];

4 使用下标访问元素时,下标也可以使用变量(必须在数组下标的范围内)

5 使用数组常见错误

1 数组元素所赋的值超出数组类型的范围,编程时VS会有提示,通过输入语句就会报错

2 赋值,访问时下标超出数组长度的范围

声明时的数字[255]表示数组长度是255,下标是0-254(长度-1)

另两种声明方式(了解即可)

//方式2 以元素个数定数组长度
//声明一个长度为3的数组
//等号右面一个大括号,括号中间每个元素用逗号隔开
//[]前面是什么类型,{}里面就必须使用什么类型的表示方式书写元素
//书写几个元素表示该数组长度就是多少
int[] nums={1,2,3};
string[] names={"zs","ls","ww"};//字符串数组 元素加双引号
//声明了有5个元素的char类型数组
char[] cs={'a','b','c','d','e'};//字符数组 元素加单引号
//其他类型以此类推
//=======================================
//方式3 声明时就给元素赋值初始化元素的值
//{ }在类或集合初始化时最常见
//类似的语法一般称为语法糖
//作用:简化编写代码
int[] nums=new int[]{1,2,3};//声明了一个长度为3的int类型数组
int[] nums=new int[3]{1,2,3};//[]中的长度可以省略
//==========================
//错误格式 []中确定了长度 但{}中元素多/少写
//编程时VS有提示
int[] nums=new int[3]{1,2};
int[] nums=new int[3]{1,2,3,5};

反编译查看3种声明方式的区别

使用数组的益处:1)相当于一次声明多个数类型相同的变量 2)数组元素在内存的存储是连续的 3)可以使用循环进行操作

相关推荐

栋察宇宙(二十一):Python 文件操作全解析

分享乐趣,传播快乐,增长见识,留下美好。亲爱的您,这里是LearingYard学苑!...

python中12个文件处理高效技巧,不允许你还不知道

在Python中高效处理文件是日常开发中的核心技能,尤其是处理大文件或需要高性能的场景。以下是经过实战验证的高效文件处理技巧,涵盖多种常见场景:一、基础高效操作...

Python内置模块bz2: 对 bzip2压缩算法的支持详解

目录简介知识讲解2.1bzip2压缩算法原理2.2bz2模块概述...

Python文件及目录处理方法_python目录下所有文件名

Python可以用于处理文本文件和二进制文件,比如创建文件、读写文件等操作。本文介绍Python处理目录以及文件的相关方法。...

The West mustn't write China out of WWII any longer

ByWarwickPowellLead:Foreightdecades,theWesthasrewrittenWorldWarIIasanAmericanandEuro...

Python 的网络与互联网访问模块及应用实例(一)

Python提供了丰富的内置模块和第三方库来处理网络与互联网访问,使得从简单的HTTP请求到复杂的网络通信都变得相对简单。以下是常用的网络模块及其应用实例。...

高效办公:Python处理excel文件,摆脱无效办公

一、Python处理excel文件1.两个头文件importxlrdimportxlwt...

Python进阶:文件读写操作详解_python对文件的读写操作方法有哪些

道友今天开始进阶练习,来吧文件读写是Python编程中非常重要的技能,掌握这些操作可以帮助你处理各种数据存储和交换任务。下面我将详细介绍Python中的文件读写操作。一、基本文件操作...

[827]ScalersTalk成长会Python小组第11周学习笔记

Scalers点评:在2015年,ScalersTalk成长会完成Python小组完成了《Python核心编程》第1轮的学习。到2016年,我们开始第二轮的学习,并且将重点放在章节的习题上。Pytho...

ScalersTalk 成长会 Python 小组第 9 周学习笔记

Scalers点评:在2015年,ScalersTalk成长会完成Python小组完成了《Python核心编程》第1轮的学习。到2016年,我们开始第二轮的学习,并且将重点放...

简析python 文件操作_python对文件的操作方法

一、打开并读文件1、file=open('打开文件的路径','打开文件的权限')#打开文件并赋值给file#默认权限为r及读权限str=read(num)读文件并放到字符串变量中,其中num表...

Python 中 必须掌握的 20 个核心函数——open()函数

open()是Python中用于文件操作的核心函数,它提供了读写文件的能力,是处理文件输入输出的基础。一、open()的基本用法1.1方法签名...

python常用的自动化脚本汇总_python 自动脚本

以下是python常用的自动化脚本,包括数据、网络、文件、性能等操作。具体内容如下:数据处理工具网络检测工具系统任务自动化工具测试自动化工具文件管理自动化工具性能监控工具日志分析工具邮件...

Python自动化办公应用学习笔记37—文件读写方法1

一、文件读写方法1.读取内容:read(size):读取指定大小的数据,如果不指定size,则读取整个文件。...

大叔转行SAP:好好学习,好好工作,做一个幸福的SAP人

我是一个崇尚努力的人,坚定认为努力可以改变命运和现状,同时也对自己和未来抱有非常高的期待。随着期待的落空,更对现状滋生不满,结果陷入迷茫。开始比较,发现周围人一个个都比你有钱,而你的事业,永远看不到明...