读书笔记二

作者: 午字横 | 来源:发表于2017-04-25 22:13 被阅读24次
    Array数组

    创建的方式

    int[] array1 = new int[5];
    int[] array2 = new int[]{1,2,3,4,5};
    int[] array3 = {1,2,3,4,5};
    

    由于是在储存在连续的内存上,所以他的索引速度非常快,访问一个元素的时间是恒定的。但是在两个元素之间插入新的元素会不方便。

    ArrayList数组

    目的就是为了解决Array创建时必须制定长度,以及只能存放相同类型的缺点而推出的数据结构。ArrayList是System.Collections命名空间下的一部分,所以若要使用它,则必须引入System.Collections。ArrayList解决了Array的一些缺点。
    1)不必在声明ArrayList时指定它的长度,ArrayList对象的长度可以按照其中存储的数据来动态的增长与缩减。
    2)ArrayList可以存储不同类型的元素。这是由于ArrayList会把它的元素都当作Object来处理。因此加入不同的类型是被允许的。
    创建方式

    using System.Collcetions;
    ArrayList array1= new ArrayList();
    //新增数据
    array1.Add("j");
    //修改数据
    Array1[0]="i";
    //删除数据
    array1.RemoveAt(0);
    

    缺点
    1)类型不安全,因为把不同类型都当作Object处理,很有可能会在使用ArrayList时发生类型不匹配的情况。
    2)数组存储类型时为发生装箱,损耗性能。

    List<T>数组

    可以认为List<T>类是ArrayList类的泛型等效类。它们之间最大的区别在于声明List集合时,同时需要为其声明List集合内数据的对象类型。这点由于Array相似,其实List<T>内部使用的Array来实现,创建时无需制定长度,添加元素时无需关系数组大小,更加方便使用。
    创建方式

    List<string> array1= new List<string>();
    //增删改与ArrayList相同
    

    优点
    1)确保类型安全。
    2)取消装箱与拆箱操作,高性能。
    3)融合Array可以快速访问的优点,以及ArrayList长度可以灵活变化的优点。

    练习

    using System;
    using System.Collections.Generic;
    using System.Collections;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace Array
    {
        class Program
        {
            static void Main(string[] args)
            {
                int[] array1 = new int[] {1,2,3 };
                int[] array2 = new int[3];
                ArrayList array3 = new ArrayList();
                array3.Add("chen");
                array3.Add(1);
                foreach (var item in array3)
                {
                    Console.WriteLine(item);
                }
                List<string> array4 = new List<string>();
    
                Console.ReadKey();
            }
        }
    }
    
    
    C#中的链表----LinkedList<T>

    优点
    1)向链表中插入和删除节点时,无需考虑调整结构的容量。相反的对于数组来说容量始终是固定的,且数组的内容就在内存中是连续的。
    2)特别适合以排序的顺序动态的添加新元素。
    Unity3D中C#已经为开发者封装了对应链表的类LinkedList<T>类,和他相匹配的C#提供了链表的结点类LinkedListNode<T>类以用来代表链表中的结点,LinkedList<T>对象中的每一个节点都属于LinkedListNode<T>类型。由于LinkedList<T>是双向链表,因此每个节点都向前指向Next节点,向后指向Previous节点。

    using System.Collections;
    using System.Collections.Generic;
    using UnityEngine;
    using System.Text;
    using System;
    
    public class test : MonoBehaviour {
        
        void Start () {
            string[] words = { "这", "是", "一", "个", "游", "戏" };
            LinkedList<string> sentence = new LinkedList<string>(words);
            Display(sentence, "初始化字符串");
    
            //将“好”加在链表的最前面。
            sentence.AddFirst("好");
            Display(sentence, "将“好”加在链表的最前面。");
    
            //将第一个结点移到最后一个结点
            LinkedListNode<string> mark1 = sentence.First;
            sentence.RemoveFirst();
            sentence.AddLast(mark1);
            Display(sentence, "将第一个结点移到最后一个结点");
    
            //将最后一个结点的内容从"好"变成"坏"。
            sentence.RemoveLast();
            sentence.AddLast("坏");
            Display(sentence, "将最后一个结点的内容从好变成坏");
    
           
            //在链表的最后增加一个结点,同时从后查找“游”所在节点
            sentence.AddLast("游");
            LinkedListNode<string> current = sentence.FindLast("游");
        }
    
    
    
        private static void Display(LinkedList<string>words,string test) {
            Debug.Log(test);
            foreach (string word in words)
            {
                Debug.Log(word + "");
            }
        }
    }
    

    相关文章

      网友评论

        本文标题:读书笔记二

        本文链接:https://www.haomeiwen.com/subject/blhbzttx.html