C#编程(三十三)----------Array类

Array类

创建数组

Array intArray1 = Array.CreateInstance(typeof(int), 5);

for (int i = 0; i < 5; i++)

{

intArray1.SetValue(33, i);

}

for (int i = 0; i < 5; i++)

{

Console.WriteLine(intArray1.GetValue(i));

}

Console.ReadKey();

分析:array类是一个抽象类,所以不能使用构造函数来创建数组(不能使用new).但除了可以使用C#语法创建数组实例之外,还可以使用静态方法CreateInstance()创建数组.如果事先不知道元素的类型,该静态方法就非常游泳.因为类型可以作为Type对象传递给CreateInstance()方法.

还可以将使用Array类创建的数组强制转换成声明为int[]的数组:

int[] intArray2 = (int[])intArray1;

CreateInstance()方法有许多重载版本,可以创建多维数组和不基于0的数组:

using System;

namespace ConsoleApplication4

{

class Program

{

static void Main(string[] args)

{

int[] lengths = { 2, 3 };

int[] lowerBounds = { 1, 10 };

Array racers = Array.CreateInstance(typeof(Person), lengths, lowerBounds);

racers.SetValue(new Person("a", "b"), 1, 10);

racers.SetValue(new Person("c", "d"), 1, 11);

racers.SetValue(new Person("e", "f"), 1, 12);

racers.SetValue(new Person("g", "h"), 2, 10);

racers.SetValue(new Person("i", "j"), 2, 11);

racers.SetValue(new Person("k", "l"), 2, 12);

Person[,] racers1 = (Person[,])racers;

Person first = racers1[1, 10];

}

}

public class Person

{

public Person()

{ }

public Person(string firstName, string lastName)

{

this.FirstName = firstName;

LastName = lastName;

}

public string FirstName { get; set; }

public string LastName { get; set; }

public override string ToString()

{

return String.Format("{0} {1}", FirstName, LastName);

}

}

}

使用SetValue()方法设置数组的元素,参数是:要设置的值,和当前索引号.

复制数组

因为数组是引用类型,所以江数组变量赋予另一个数组变量,就会得到两个引用同一数组的变量.而复制数组,会使数组实现ICloneable接口.这个接口定义的Clone()方法会创建数组的浅表副本.

如果数组的元素是值类型,则:

如果数组包含引用类型,则不复制元素,而知复制引用.

除了使用Clone()方法之外,还可以使用Array.Copy()方法创建浅表副本.但Clone()方法和Copy()方法有一个重要区别:Clone()方法会创建一个新数组,而Copy()方法必须传递阶数相同且有足够元素的已有数组.

如果需要包含引用类型的数组的深层副本,就必须迭代数组并创建对象.

排序

string[] names = {"zhao","qian","sun","li" };

Array.Sort(names);

foreach (var item in names)

{

Console.WriteLine(item);

}

Console.ReadKey();

排序后的结果:

li

qian

sun

zhao

由此看见,排序是按照字典序排列.

如果对数组使用自定义类,就必须事先IComparable接口.这个接口定义了一个方法CompareTo(),如果要比较的对象相等,该方法就返回0.如果该实例应拍在参数对象的前面,该方法就返回小于0的值.如果该实例应排在参数对象的后面,该方法就返回大于0的值.

案例:

public class Person:IComparable<Person>

{

public Person()

{ }

public Person(string firstName, string lastName)

{

this.FirstName = firstName;

LastName = lastName;

}

public string FirstName { get; set; }

public string LastName { get; set; }

public override string ToString()

{

return String.Format("{0} {1}", FirstName, LastName);

}

public int CompareTo(Person other)

{

if (other==null)

{

throw new ArgumentNullException("other");

}

int result = this.LastName.CompareTo(other.LastName);

if (result==0)

{

result = this.FirstName.CompareTo(other.FirstName);

}

return result;

}

}

编写测试代码:

static void Main(string[] args)

{

Person[] persons ={

new Person{FirstName="shan",LastName="yongxu"},

new Person{FirstName="sun",LastName="yanzhao"},

new Person{FirstName="zhu",LastName="haitao"},

new Person{FirstName="wang",LastName="jiwei"}

};

Array.Sort(persons);

foreach (var item in persons)

{

Console.WriteLine(item);

}

Console.ReadKey();

}

这样是按照名排序,不是按照姓排序.

如果Person对象的排序方式与上述不同,或者不能修改在数组中用作元素的类,就可以实现IComparer接口或IComparer<T>接口.这两个接口定义了方法Compare().要比较的类必须实现这两个接口之一.ICompare接口的Compare()方法定义了两个要比较的参数的原因.其返回值与IComparable接口的CompareTo()方法类似.

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Threading.Tasks;

namespace ConsoleApplication1

{

public enum PersonCompareType

{

FirstName,

LastName

}

public class PersonComparer : IComparer<Person>

{

private PersonCompareType compareType;

public PersonComparer(PersonCompareType compareType)

{

this.compareType = compareType;

}

public int Compare(Person x, Person y)

{

if (x==null||y==null)

{

throw new ArgumentNullException("x==y");

}

switch (compareType)

{

case PersonCompareType.FirstName:

return x.FirstName.CompareTo(y.FirstName);

case PersonCompareType.LastName:

return x.LastName.CompareTo(y.LastName);

default:

throw new ArgumentNullException("type");

}

}

}

class Program

{

static void Main(string[] args)

{

Person[] persons ={

new Person{FirstName="shan",LastName="yongxu"},

new Person{FirstName="sun",LastName="yanzhao"},

new Person{FirstName="zhu",LastName="haitao"},

new Person{FirstName="wang",LastName="jiwei"}

};

Array.Sort(persons,new PersonComparer(PersonCompareType.FirstName));

foreach (var item in persons)

{

Console.WriteLine(item);

}

Console.ReadKey();

}

}

public class Person : IComparable<Person>

{

public Person()

{ }

public Person(string firstName, string lastName)

{

this.FirstName = firstName;

LastName = lastName;

}

public string FirstName { get; set; }

public string LastName { get; set; }

public override string ToString()

{

return String.Format("{0} {1}", FirstName, LastName);

}

public int CompareTo(Person other)

{

if (other == null)

{

throw new ArgumentNullException("other");

}

int result = this.LastName.CompareTo(other.LastName);

if (result == 0)

{

result = this.FirstName.CompareTo(other.FirstName);

}

return result;

}

}

}

分析:类PersonComparer实现了IComparer<Person>接口,可以按照FirstName或LastName对象排序.枚举PersonComparerType定义了可用于PersonComparer的排序选项:FirstName和LastName.排序方式由PersonComparer类的构造函数定义,在该构造函数中设置了一个PersonComparerType值.实现Compare()方法时用一个switch语句指定是按照FirstName还是LastName排序.

这样就可以按照你的需要来排序;是按照姓排序,还是按照名排序?

Array类还提供了Sort方法,需要将一个委托作为参数,这个参数可以传递给方法,从而比较两个对象,而不需要依赖IComparable或IComparer接口.

时间: 2024-08-18 17:09:08

C#编程(三十三)----------Array类的相关文章

java-第十三章-类的无参方法(一)-代参方法的编程计算器

package 本章总结; public class A01class { public int ope(int Operator, int num1, int num2) { switch (Operator) { case 1: num1 += num2; break; case 2: num1 -= num2; break; case 3: num1 *= num2; break; case 4: num1 /= num2; break; default: System.out.print

java-第十三章-类的无参方法(一)-根据三角形的三条边长,判断是直角,锐角还是钝角三角形

package 本章总结; public class A03class { public boolean showA(int a ,int b ,int c){ boolean con=false; if((a+b)>c&&(a+c)>b&&(c+b)>a){ con=true; } return con; } public String Shape(int a,int b,int c){ String shape=""; if((a=

ActionScript3游戏中的图像编程(连载三十三)

2.2.6 Photoshop投影扩展参数在Flash滤镜中的体现 拖动Photoshop扩展项的滑块,和拉动Flash强度项的数值框,会发现它们要做的事情都一样,在于控制阴影扩展的强度,数值越大,强度越高,阴影色越不透明,阴影的有效区域也就越大. 然而,它们的取值范围让我感到相当地迷茫.Photoshop的范围为0%~100%,而Flash则是0%~25500%,而且它们的变化规律也有点难以捉摸,在Photoshop里,匀速向右拖动滑块,投影变大的速度比较均匀(事实上受小数像素的影响,有时投影

[原创]ActionScript3游戏中的图像编程(连载三十三)

2.2.6 Photoshop投影扩展参数在Flash滤镜中的体现 拖动Photoshop扩展项的滑块,和拉动Flash强度项的数值框,会发现它们要做的事情都一样,在于控制阴影扩展的强度,数值越大,强度越高,阴影色越不透明,阴影的有效区域也就越大. 然而,它们的取值范围让我感到相当地迷茫.Photoshop的范围为0%~100%,而Flash则是0%~25500%,而且它们的变化规律也有点难以捉摸,在Photoshop里,匀速向右拖动滑块,投影变大的速度比较均匀(事实上受小数像素的影响,有时投影

C#高级编程第11版 - 第三十三章

导航 C# 全版本特性一览 全书目录 第三十三章 Windows Apps 33.1 Windows 应用程序简介 855 33.1.1 Windows 运行库 856 33.1.2 Hello, Windows 856 33.1.3 应用程序清单文件 857 33.1.4 应用程序启动 859 33.1.5 主页 859 33.2 XAML 861 33.2.1 XAML 标准 861 33.2.2 将元素映射到类 861 33.2.3 通过XAML 使用定制的.NET 类 862 33.2.

JAVA之旅(三十三)——TCP传输,互相(伤害)传输,复制文件,上传图片,多并发上传,多并发登录

JAVA之旅(三十三)--TCP传输,互相(伤害)传输,复制文件,上传图片,多并发上传,多并发登录 我们继续网络编程 一.TCP 说完UDP,我们就来说下我们应该重点掌握的TCP了 TCP传输 Socket和ServiceSocket 建立客户端和服务端 建立连接后,通过Socket中的IO流进行数据的传输 关闭Socket 同样的,我们的客户端和服务端都是两个独立的应用 我们通过查阅API文档发现,该对象在建立的时候,就可以去连接指定主机,因为tcp是面向连接的,所以在建立socket服务时,

iOS网络编程(三) 异步加载及缓存图片----&gt;SDWebImage

@SDWebImage提供一个UIImageView的类别以支持加载来自网络的远程图片.具有缓存管理.异步下载.同一个URL下载次数控制和优化等特征. @SDWebImage的导入1.https://github.com/rs/SDWebImage 下载SDWebImage开源包2.将类包拖入工程,再导入MapKit.framework.ImageIO.framework两个框架3.SDWebImage是支持ARC的,在MRC的工程中要注意,可参考MRC工程配置ARC4.注意:SDWebImag

Java笔记二十.深入解析I/O编程之文件访问类

深入解析I/O编程之文件访问类 转载请表明出处:http://blog.csdn.net/u012637501(嵌入式_小J的天空) 开始学习字节流类之前,我们来先看下与文件有关的类-File类.File类是IO包中唯一代表磁盘文件本身的对象,File类定义了一些与平台无关的方法来操作文件,通过调用File类提供的各种方法,我们能够创建.删除文件.重命名文件以及判断文件的读写权限及其是否存在,设置和查询文件的最近修改时间等.在Java中,目录也被当作File使用,只是多了一些目录特有的功能---

网络编程模型及网络编程三要素

网络模型 计算机网络之间以何种规则进行通信,就是网络模型研究问题. 网络模型一般是指 OSI(Open SystemInterconnection开放系统互连)参考模型 TCP/IP参考模型 网络模型7层概述: 1.物理层:主要定义物理设备标准,如网线的接口类型.光纤的接口类型.各种传输介质的传输速率等.它的主要作用是传输比特流(就是由1.0转化为电流强弱来进行传输,到达目的地后在转化为1.0,也就是我们常说的数模转换与模数转换).这一层的数据叫做比特. 2. 数据链路层:主要将从物理层接收的数