C#中的数组探究与学习

目录

    • C#中的数组一般分为:
    • 一.数组定义:
    • 为什么要使用数组?
    • 什么是数组?
    • C#一维数组
    • for和foreach的区别
    • C#多维数组
    • C#锯齿数组
    • 初始化的意义:
    • 适用场景:

在这里插入图片描述

C#中的数组一般分为:

​①.一维数组。

②.多维数组,也叫矩形数组。

③.锯齿数组,也叫交错数组。

一.数组定义:

数组是一种聚合数据类型,它是将具有相同类型的若干变量有序地组织在一起的集合,是最基本的数据结构。

一个数组可以分解为多个数组元素,按照数据元素的类型,数组可以分为整型数组、字符型数组、浮点型数组、指针数组和结构数组等。数组还可以有一维、二维以及多维等表现形式。

一.数组存在的意义:

为什么要使用数组?

声明数组变量并不是Number0,Number1,Number2,…,Number999一个个单独的变量,而是声明一个就像 Numbers这样的变量,然后使Numbers[0],Numbers[1],Numbers[2],…,Numbers[999]来表示一个个单独的变量。数组中某个指定的元素是通过索引来访问的。

什么是数组?

Number0,Number1,Number2,…,Number999一个个单独的变量,这样的操作非常频繁并且执行效率低。那这个时候发明numbers的作者为了提高开发效率,防止代码冗余,给我们引入了一种新的数据类型,那这种就叫做数组类型。

数组都是由连续的内存位置组成的。最低的地址对应第一个元素,最高的地址对应最后一个元素。
在这里插入图片描述
我们把Number0,Number1,Number2,…,Number999集中在一起定义成一个类型,这个类型就是数组类型numbers,这些数的类型要求必须一致,并且在定义的时候必须指定个数也就是数组的长度Length。同时这些数的内存空间是连续开辟的, 而且是存放在托管堆中,这就是数组的定义
数组的表示方法:
数据类型[] 数组名;
数据类型[] Numbers ={Numbers[0],Numbers[1],Numbers[2],…,Numbers[999]}

C#一维数组

表示数组
数据类型[] 数组名;
1初始化数组中的元素
数据类型[] 数组名 = new 数据类型[长度];
数据类型[] 数组名 = {值 1, 值 2, …}
数据类型[] 数组名 = new 数据类型[长度]{值 1,值 2,…}
//有一个 int 类型的数组,输出数组中的第一个元素和最后一个元素
//定义int类型的数组
int[] array= { 1, 2, 3 };
2.一维数据的表示方法

第一种方式: 
int[] array; 
array=new int[3]{1,2,3}; 
第二种方式:
int[] array=new int[]{1,2,3}; 
第三种方式
int[] array={1,2,3}; 

一维数组的遍历

第一种方式: 
for(int i=0;i<3;i++) 
{ 
Console.WriteLine(数组名称[i]); 
} 
第二种方式:
foreach(int value in 数组名称) 
{ 
Console.WriteLine(value); 
} 

for和foreach的区别

1、从底层实现上:foreach是通过指针偏移实现的(最初在-1位置,每循环一次,指针就便宜一个单位),而for循环是通过当前索引相对零索引的偏移量(通过首地址和地址偏移量)计算实际访问地址实现的;
2、从编码结构上:foreach语句省去了for语句中设置循环起点和循环条件的过程;
3、从使用要求上:使用foreach语句遍历对象要求对象类型实现了枚举接口IEnumerable;

C#多维数组

1初始化数组中的元素
//定义多维数组
数据类型[ , , …] 数组名;
//创建多维数组并初始化
数据类型[ , , …] 数组名 = new 数据类型[m,n,…] {{ , , …},{ , , …}};
2.多数组表示方法
第一种形式:
int[,] array=new int[3,4]{{1,2,3,4},{5,6,7,8},{9,10,11,12}};
第二种形式:
int[,] array=new int[,]{{1,2,3,4},{5,6,7,8},{9,10,11,12}};
第三种形式:
int[,] array={{1,2,3,4},{5,6,7,8},{9,10,11,12}};
3.多数组的遍历

第一种方式:
for (int i = 0; i < 数组元素长度; i++)//行数 
{ 
for (int j = 0; j < 数组元素长度; j++)//列数 
{ 
Console.WriteLine(a[i, j]); 
} 
} 
第二种方式: 
int[,] array= new int[3, 4] { { 1, 2, 3, 4 }, { 5, 6, 7, 8 }, { 9, 10, 11, 12 } }; 
for (int i = 0; i < a.GetLength(0); i++)//行数 
{ 
for (int j = 0; j < a.GetLength(1); j++)//列数 
{ 
Console.Write("{0}\t",a[i, j]); 
} 
Console.WriteLine(); 
} 

C#锯齿数组

1初始化数组中的元素
锯齿数组又称为交错数组,数组中的每一个元素都是另一个数组,所有锯齿数组也叫作数组的数组,但是要注意,这些数组都必须要有相同的基本类型。
锯齿数组的声明和初始化
(1)锯齿数组声明
int[][] JoinArray;//声明一个int型锯齿数组JoinArray
(2)锯齿数组初始化
初始化JoinArray数组含有2个子数组(即数值中2个元素为另外2个数组)
JoinArray= new int[2][];//初始化jaggedArray数组
JoinArray[0] = new int[3] { 1, 2, 3 };//第一个元素为一个长度为3的一维数组
JoinArray[1] = new int[4] { 4, 5, 6, 7 };//第二个元素为一个长度为4的一维数组
还可以改进锯齿数组的声明和初始化,将声明和初始化写在一行代码:
int[][] JoinArray= new int[2][] { new int[] { 1, 2, 3 }, new int[] { 4, 5, 6, 7 } };
2.表示方法
第一种方式:

int[][] array=new int[3][]{new int[]{1,2,3},new int[]{4,5},new int[]{6,7,8}}; 
第二种方式: 
int[][] array=new int[][]{new int[]{1,2,3},new int[]{4,5},new int[]{6,7,8}}; 
第三种方式
int[][] array={new int[]{1,2,3},new int[]{4,5},new int[]{6,7,8}};

3.数组的遍历

int[][] array= new int[3][] { new int[] { 12, 213, 34 }, new int[] { 10, 12 }, new int[] { 54, 87, 98 } }; 
for (int i = 0; i < a.GetLength(0); i++) 
{ 
for (int j = 0; j < a[i].Length; j++) 
{ 
Console.Write("{0}\t", a[i][j]); 
} 
Console.WriteLine(); 
} 
Console.ReadKey(); 

初始化的意义:

我们数组定义成一个数据类型,这个类型就是数组类型,这些数的类型通常是相同,并且在定义数组的时候必须指定数组长度,在内存空间里面是连贯的,而且是固定存放在内存空间中。赋予一定数据类型的数值。(注意:不初始化直接报错。)
声明一个数组不会在内存中初始化数组。当初始化数组变量时,您可以赋值给数组。
数组是一个引用类型,所以您需要使用 new 关键字来创建数组的实例。
数组特点
关键字new:表示在内存中开辟空间。
数组是由每一个元素数据组成,所以每一个数据可以叫元素。元素从从First到Last
Leghth长度代表元素的个数
数组范围:不能超出索引范围,超出范围就会异常错误。
固定大小,数组的大小是初始化时决定的,无法扩容(怎么扩容)。
强类型,存储数据元素类型必须在初始化时指定,数组只能存储一种类型的数据。
按照索引查询元素速度快、遍历数组方便;添加,删除操作慢,因为要移动其他的元素。

适用场景:

频繁查询,对存储空间要求不大,很少增加和删除的情况。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/151533.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

分布式文件系统HDFS(林子雨慕课课程)

文章目录 3. 分布式文件系统HDFS3.1 分布式文件系统HDFS简介3.2 HDFS相关概念3.3 HDFS的体系结构3.4 HDFS的存储原理3.5 HDFS数据读写3.5.1 HDFS的读数据过程3.5.2 HDFS的写数据过程 3.6 HDFS编程实战 3. 分布式文件系统HDFS 3.1 分布式文件系统HDFS简介 HDFS就是解决海量数据…

读书笔记——C++高性能编程(一至三)

《C高性能编程》作者&#xff1a;费多尔.G.皮克斯 版本&#xff1a;2022年11月第1版 第一章.性能基础 描述了吞吐量&#xff0c;功耗&#xff0c;实时应用性能的含义。 阐述了“虽然几乎不可能提前预测最佳优化&#xff0c;但是可以确定某些设计决策将使后续优化变得非常困难…

C/C++ 进程间通信system V IPC对象超详细讲解(系统性学习day9)

目录 前言 一、system V IPC对象图解 1.流程图解&#xff1a; ​编辑 2.查看linux内核中的ipc对象&#xff1a; 二、消息队列 1.消息队列的原理 2.消息队列相关的API 2.1 获取或创建消息队列&#xff08;msgget&#xff09; 实例代码如下&#xff1a; 2.2 发送消息到消…

单元测试该怎么写

单元测试对于开发人员来说很熟悉&#xff0c;各种语言都提供了单元测试的框架&#xff0c;用于自动化执行单元测试并生成测试报告。它通常提供了一组API和工具&#xff0c;使开发人员能够编写和运行测试用例&#xff0c;比较预期行为和实际行为之间的差异&#xff0c;并准确地识…

多线程锁-synchronized字节码分析

从字节码角度分析synchronized实现 javap -c(v附加信息) ***.class 文件反编译 synchronized同步代码块 >>>实现使用的是monitorenter和monitorexit指令 synchronized普通同步方法 >>>调用指令将会检查方法的ACC_SYNCHRONIZED访问标志是否被设置&#xf…

【数据结构-二叉树 九】【树的子结构】:树的子结构

废话不多说&#xff0c;喊一句号子鼓励自己&#xff1a;程序员永不失业&#xff0c;程序员走向架构&#xff01;本篇Blog的主题是【子结构】&#xff0c;使用【二叉树】这个基本的数据结构来实现&#xff0c;这个高频题的站点是&#xff1a;CodeTop&#xff0c;筛选条件为&…

不同数据类型在单片机内存中占多少字节?

文章目录 前言一、不同编译器二、C51* 指针型 三、sizeof结构体联合体 前言 在C语言中&#xff0c;数据类型指的是用于声明不同类型的变量或者函数的一个广泛的系统。变量的类型决定了变量存储占用的空间 一、不同编译器 类型16位编译器大小32位编译器大小64位编译器大小char…

Kafka 简介之(学习之路)

正文 一、简介 1.1 概述 Kafka是最初由Linkedin公司开发&#xff0c;是一个分布式、分区的、多副本的、多订阅者&#xff0c;基于zookeeper协调的分布式日志系统&#xff08;也可以当做MQ系统&#xff09;&#xff0c;常见可以用于web/nginx日志、访问日志&#xff0c;消息服务…

软件设计原则 1小时系列 (C++版)

文章目录 前言基本概念 Design Principles⭐单一职责原则(SRP) Single Responsibility PrincipleCode ⭐里氏替换原则(LSP) Liskov Substitution PrincipleCode ⭐开闭原则(OCP) Open Closed PrincipleCode ⭐依赖倒置原则(DIP) Dependency Inversion PrincipleCode ⭐接口隔离…

【抢先体验】开通使用 ChatGPT 语音版功能保姆级教程

大家好&#xff0c;我是苍何&#xff0c;一个土木转码的非典型程序员&#xff0c;也是一名技术管理者&#xff0c;同时也是 AI 应用的探索者。今天在视频号上看到和 ChatGPT 语音对话的视频&#xff0c;其声音的真实感太让人震撼了&#xff0c;于是也想去抢先体验一下 ChatGPT …

Centos7安装MongoDB7.xxNoSQL数据库|设置开机启动(骨灰级+保姆级)

一: mongodb下载 MongoDB 社区免费下载版 MongoDB社区下载版 [rootwww tools]# wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-7.1.0-rc4.tgz 二: 解压到指定目录 [rootwww tools]# mkdir -p /usr/local/mongodb [rootwww tools]# tar -zxvf mongodb-…

选择适合普通公司的项目管理软件

不管是打工人还是学生党都适合使用Zoho Projects项目管理软件。利用项目概览功能&#xff0c;将整体项目尽收眼底&#xff0c;作为项目管理者&#xff0c;项目日程、进度都可见&#xff0c;Zoho Projects项目管理APP助推项目每一环节的进展&#xff0c;更便于管理者设计项目的下…

ThingsBoard如何自定义tcp-transport

1、概述 很久没有更新了,一直忙于其他的事情,最近去搞了一个在ThingsBoard中自定义一个tcp-transport,用于连接使用tcp长连接的设备,目前使用tcp和mqtt协议连接服务端的设备还是很多,ThingsBoard的PE版提供了Integration是可以实现tcp的接入,但是CE版是没有提供接入tcp长…

【MySQL】基本查询(二)

文章目录 一. 结果排序二. 筛选分页结果三. Update四. Delete五. 截断表六. 插入查询结果结束语 操作如下表 //创建表结构 mysql> create table exam_result(-> id int unsigned primary key auto_increment,-> name varchar(20) not null comment 同学姓名,-> chi…

IO 之 操作properties属性文件

propreties文件&#xff1a; properties文件是一种用于存储配置信息的文本文件&#xff0c;通常以“.properties”为文件扩展名。它是一种简单的键值对格式&#xff0c;用于保存应用程序的配置参数。 在properties文件中&#xff0c;每一行都包含一个键值对&#xff0c;键和值…

HTTPS工作过程,国家为什么让http为什么要换成https,Tomcat在MAC M1电脑如何安装,Tomcat的详细介绍

目录 引言 一、HTTPS工作过程 二、Tomcat 在访达中找到下载好的Tomcat文件夹&#xff08;这个要求按顺序&#xff09; zsh: permission denied TOMCAT的各部分含义&#xff1a; 引言 在密码中一般是&#xff1a;明文密钥->密文&#xff08;加密&#xff09; &#xff…

Spring源码解析——IOC属性填充

正文 doCreateBean() 主要用于完成 bean 的创建和初始化工作&#xff0c;我们可以将其分为四个过程&#xff1a; 最全面的Java面试网站 createBeanInstance() 实例化 beanpopulateBean() 属性填充循环依赖的处理initializeBean() 初始化 bean 第一个过程实例化 bean在前面一篇…

复旦大学EMBA:揭秘科创企业,领略未来战略!

智能制造&#xff0c;国之重器。作为制造强国建设的主攻方向&#xff0c;智能制造的发展水平关系到我国未来制造业在全球的地位与影响力。发展智能制造&#xff0c;是加快建设现代化产业体系的重要手段&#xff0c;提升供给体系适配性的有力抓手&#xff0c;也是建设数字中国的…

【C++设计模式之状态模式:行为型】分析及示例

简介 状态模式&#xff08;State Pattern&#xff09;是一种行为型设计模式&#xff0c;它允许对象在内部状态改变时改变其行为&#xff0c;看起来就像是改变了其类。状态模式将对象的状态封装成不同的类&#xff0c;并使得对象在不同状态下有不同的行为。 描述 状态模式通过…

Android用户登录与数据存储:从权限请求到内外部存储的完整实践【完整实践步骤、外部存储、内部存储】

步骤 1: 登录页面布局 在 MainActivity 中实现用户登录功能&#xff0c;首先创建一个布局文件 activity_main.xml 包含用户名和密码的输入字段以及登录按钮。 <!-- activity_main.xml --> <LinearLayoutxmlns:android"http://schemas.android.com/apk/res/andr…