C#中的数组,多维数组和交错数组
想研究一些面向对象的东西,也许是代码写得还不够多。感觉还不好,看那些教程,不是嫌太水就是太难看不懂。心情很是落寞
不过再怎样也要坚持每天发一篇博客。
这篇来说一下C#中的数组,多维数组,交错数组的一些东西。
有那么一点点研究茴香豆的茴有四种写法的感觉。
先讲三点显而易见却又值得一提的东西
第一点数组是一种数据结构
似乎没什么好解释的
第二点数组类型是从抽象类Array派生出的引用类型
与C当中的数组不同的是C#以面向对象的方式设计的。
所以再次证明 任何东西都是对象
第三点C#的数组可以开很大
C直接开在堆栈不同的还有C#的数组在托管栈只有引用,而实际的数据是放在托管堆里面的。
int[, , ] a = new int[500, 500, 500];
这样是不会有问题的。同样的大小在C早就……了
虽然是这么说,正常使用是不大可能用到这么大的数组。
第四点数组类型可以使用foreach迭代
这个部分我想另外写一篇来研究这个
另外还有几点可以参考MSDN数组部分
http://msdn.microsoft.com/zh-cn/library/9b9dty7d%28VS.80%29.aspx
然后呢,先上代码吧
- //一维数组
- int[] a1 = new int[3];
- int[] a2 = new int[] { 0, 1, 2 };
- int[] a3 = { 0, 1, 2 };
- int[] a4;
- a4 = new int[3] { 0, 1, 2 };
- //int[3] a5; 错误代码
- //int a5[3]; 错误代码
- a1[0] = 0;
- Console.WriteLine("{0}",a1[0]);
- //多维数据
- int[,] b1 = new int[3, 3];
- int[,] b2 = new int[,] {{0,1,2},
- {0,1,2},
- {0,1,2}};
- int[,] b3 = new int[,] {{0,1,2},
- {0,1,2},
- {0,1,2}};
- int[,] b4;
- b4 = new int[,]{{0,1,2},
- {0,1,2},
- {0,1,2}};
- int[, ,] b5 = new int[2,2,2] {{{1,2},{1,2}},
- {{1,2},{1,2}}};
- b5[0,0,0] = 1;
- Console.WriteLine("{0}",b5[0,0,0]);
- //交错数组(数组的数组)
- int[][] c1 = new int[3][];
- c1[0] = new int[3];
- c1[1] = new int[2];
- c1[2] = new int[1];
- int[][] c2 = new int[][]
- {
- new int[] {1,2,3},
- new int[] {4,5,6},
- new int[] {7,8,9}
- };
- int[][] c3 =
- {
- new int[] {1,2,3},
- new int[] {4,5,6},
- new int[] {7,8,9}
- };
- //int[][] c4 = new int[3][3];错误代码
- c1[0][0] = 3;
- Console.WriteLine("{0}",c1[0][0]);
- //混搭
- int[][,] d1 = new int[1][,];
- d1[0] = new int[,]{{4,2,3},
- {4,2,3},
- {4,2,3}};
- Console.WriteLine("{0}",d1[0][0,0]);
一维数组部分,比较有价值的是那两行错误的代码。
C#与C在这个地方语法有所不同,本来这两种语言的设计这块时的思路就有所差异
关于语法的事,习惯就好了
关于多维数组,C#当中有两种方式,一个是多维数组,另一种是交错数组
根据MSDN的说明
多维数组只是数组,交错数组是数组的数组
半句半句看都还好,整句看起来怎么不是一回事。我也不知道该怎么解释比较好
简单总结了下面几点
交错矩阵的声明部分比较麻烦
使用时交错数组的样子更像C语言是人都看出来了,可以利用FOR语句来简化
多维数组只能构造一个矩形的数据结构,而使用交错数组可以设计出不规则的结构
所以有需要时可以选择使用交错矩阵。
在这里 使用foreach迭代也有所不同,
但都非常给力,具体可以参考相关文章
交错数组的访问速度比多维数组快
具体的分析可以参见
《C#中各种数组性能比较》http://www.cnblogs.com/xuefeng1982/archive/2010/03/04/1678152.html
唉,想自己写一些东西,真的不容易。也许是自己对这部分的内容掌握还没十分彻底,也许是语言表达的问题
总之短短的一篇文章,写了好久,而且似乎没能表达出什么特别的东西
C#中的数组,多维数组和交错数组的更多相关文章
- 地图四叉树一般用在GIS中,在游戏寻路中2D游戏中一般用2维数组就够了
地图四叉树一般用在GIS中,在游戏寻路中2D游戏中一般用2维数组就够了 四叉树对于区域查询,效率比较高. 原理图
- C语言中如何将二维数组作为函数的参数传递
今天写程序的时候要用到二维数组作参数传给一个函数,我发现将二维数组作参数进行传递还不是想象得那么简单里,但是最后我也解决了遇到的问题,所以这篇文章主要介绍如何处理二维数组当作参数传递的情况,希望大家不 ...
- php中count获取多维数组长度的方法
转自:http://www.jb51.net/article/57021.htm 本文实例讲述了php中count获取多维数组长度的实现方法.分享给大家供大家参考.具体分析如下: 先来看看下面程序运行 ...
- php中向前台js中传送一个二维数组
在php中向前台js中传送一个二维数组,并在前台js接收获取其中值的全过程方法: (1),方法说明:现在后台将数组发送到前台 echo json_encode($result); 然后再在js页面中的 ...
- 《剑指Offer》第1题(Java实现):在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
一.题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该 ...
- 剑指offer 1.数组 二维数组中查找
题目描述 在一个二维数组中(每个一维数组的长度相同), 每一行都按照从左到右递增的顺序排序, 每一列都按照从上到下递增的顺序排序. 请完成一个函数, 输入这样的一个二维数组和一个整数,判断数组中是否含 ...
- 以杨辉三角为例,从内存角度简单分析C语言中的动态二维数组
学C语言,一定绕不过指针这一大难关,而指针最让人头疼的就是各种指向关系,一阶的指针还比较容易掌握,但一旦阶数一高,就很容易理不清楚其中的指向关系,现在我将通过杨辉三角为例,我会用四种方法从内存的角度简 ...
- 如何在C++中动态建立二维数组(转)
http://blog.sina.com.cn/s/blog_7c073a8d0100qp1w.html http://blog.163.com/wujiaxing009@126/blog/stati ...
- Java中如何获取多维数组的长度
在程序处理中遍历数组是一种很常见的操作,但遍历数组时,我们需要知道数组各维度的长度(一维数组除外,for each 可以遍历),下面举例说明如何求多维数组的长度. 一维 : int [] array ...
随机推荐
- BootStrap学习(2)
使用Bootstrap添加代码框 可先看:简介.引入.包下载等:http://www.cnblogs.com/0201zcr/p/4900062.html Bootstrap 允许您以两种方式显示代码 ...
- IBM云的商业动作之我见(1):IBM 收购 OpenStack 托管私有云公司 Blue Box [IBM Acquired Blue Box]
2015-06-10 IBM 刚刚(2015/06/03)宣布收购 Blue Box 公司.本文就聊聊这点事. 1. Blue Box 是做什么的?它是一家中小型托管私有云提供商. 1.1 公司的简单 ...
- SoapUI调用webservice实现的两种方式
SoapUI用来做测试,已经是很多人做过的事情了,而且网上教程也很多.不过还是写下来,对比webservice协议与http协议脚本编写的不同. 首先测接口得有一个服务,刚好笔者所在项目做ESB集成. ...
- VS Code
VS Code VS Code(Visual Studio Code)是由微软研发的一款免费.开源的跨平台文本(代码)编辑器.几乎完美的编辑器. 官网:https://code.visualstudi ...
- SilverFoxServer出炉!!
SilverFoxServer是啥?各位看官搜一下SmartFoxServer便知 是一套服务端+客户端通迅框架,快速搭建起回合制,棋牌类的联机 网页游戏 SilverFoxServer的特点包括 用 ...
- 精通CSS version2笔记之⒈选择器
1.常用的选择器:①元素选择器 指定希望应用样式的元素.比如:p {color:#fff;}②后代选择器 寻找特定元素或者元素的后代. 比如:body p{color:#ccc;} 这个选 ...
- zlog学习笔记(mdc)
mdc.h #ifndef __zlog_mdc_h #define __zlog_mdc_h #include "zc_defs.h" typedef struct zlog_m ...
- 使用华为U8860测试时出现“Unable to open log device '/dev/log/main': No such file or directory”
这是因为华为默认禁掉了log输出, 解决办法: 拨号: *#*#2846579#*#* 会显示工程菜单, Go to "ProjectMenu" -> "Backg ...
- Centos5.8 安装 ImageMagick 6.8.9-3
下载最新的ImageMagick源码包 ImageMagick-6.8.9-3.x86_64.rpm 直接prm -ivh 安装提示错误 error: Failed dependencies: lib ...
- PAT 1007. 素数对猜想 (20)
让我们定义 dn 为:dn = pn+1 - pn,其中 pi 是第i个素数.显然有 d1=1 且对于n>1有 dn 是偶数."素数对猜想"认为"存在无穷多对相邻且 ...