zoukankan      html  css  js  c++  java
  • data代码C#中struct的2个小问题

    题记:写这篇博客要主是加深自己对data代码的认识和总结实现算法时的一些验经和训教,如果有错误请指出,万分感谢。

        1、设置链表,平日代码如下:
    public struct Links
    {
        public int data;
        public Links next;

    下面的代码编译时会出错:“Links”类型的结构成员“Links.next”在结构布局中导致循环

        解决方法有2个:
    a、不必struct,改用class就ok了
    b、保持应用struct,那么须要折衷一下,加一个object成员和Links属性来曲线救国,代码如下:
    public struct Links
    {
        public int data;
        private object _next;
        public Links next

        {
            get { return (Links)_next; }
            set { _next = value; }
        }

     

        每日一道理
    有些冷,有些凉,心中有些无奈,我一个人走在黑夜中,有些颤抖,身体瑟缩着,新也在抖动着,我看不清前方的路,何去何从,感觉迷茫,胸口有些闷,我环视了一下周围,无人的街头显得冷清,感到整个世界都要将我放弃。脚步彷徨之间,泪早已滴下……

        2、对struct数组或类的struct成员赋值,示例代码:
    List<Links> arr = new List<Links>();
    arr.Add(new Links());
    arr[0].data = 123;

    下面的代码编译时出错:没法修改“System.Collections.Generic.List<Links>.this[int]”的返回值,因为它不是变量
    出错的原因,是因为struct是值类型,首先arr[0]返回了一个Links,返回的只是一个副本,并不是arr数组里的0这个位置的引用,
    直接对副本的data属性停止修改,是没有任何意义的,因为修改完成后,这个副本就被抛弃了
    为了避免开发者犯这个错误,微软就把它定义为编译错误了,具体参考:http://msdn.microsoft.com/zh-cn/library/wydkhw2c(vs.80).aspx

        如果是希望修改数组里第0个元素的data属性,代码改成:
    List<Links> arr = new List<Links>();
    arr.Add(new Links());

        Links tmp = arr[0];
    tmp.data = 123;
    arr[0].data = tmp;

    下面这一步是把第0个元素直接整个替换,旧的数据等待回收中

        


        首发:http://beinet.cn

    文章结束给大家分享下程序员的一些笑话语录: 有一天,一个男人穿越森林的时候,听到一个细微的声音叫住他。他低头一看,是一只青蛙。
    “如果你亲我一下,我会变成一个美丽的公主哦。”男人一言不发,把青蛙捡起来,放入口袋。
    “如果你亲我一下,我会变成一个美丽的公主哦。而且,我会告诉我遇到的每一个人,你是多么聪明和勇敢,你是我的英雄。”男人把青蛙拿出来,对着它微微一笑,又把它放回口袋。
    “如果你亲我一下,我会变成一个美丽的公主,然后我愿意成为你的爱人一星期。”男人又把青蛙拿出来,对着它微微一笑,把它放回口袋。
    “如果你亲我一下,我会变成一个美丽的公主,然后我愿意成为你的爱人一年,而且你可以对我做任何事。”再一次,男人把青蛙拿出来,对着它微微一笑,又把它放回口袋。
      最后,青蛙无力地问:“我开出了这么好的条件,为什么你还不肯吻我?”男人说:“我是一个程序员,我可没时间和什么公主鬼混。不过,拥有一个会说话的青蛙,倒是蛮酷的。”

    --------------------------------- 原创文章 By
    data和代码
    ---------------------------------

  • 相关阅读:
    2017 Wuhan University Programming Contest (Online Round) Lost in WHU 矩阵快速幂 一个无向图,求从1出发到达n最多经过T条边的方法数,边可以重复经过,到达n之后不可以再离开。
    2017 Wuhan University Programming Contest (Online Round) C. Divide by Six 分析+模拟
    2017 Wuhan University Programming Contest (Online Round) B Color 树形dp求染色方法数
    GCD
    HighCharts SVN IReport进行PDF报表设计--模板
    项目二:品优购 第二天 AngularJS使用 brand商品页面的增删改查
    项目二 品优购第一天
    solr第一天 基础增删改查操作
    solr第二天 京东案例 课程文档 有用
    solr第二天 京东案例
  • 原文地址:https://www.cnblogs.com/jiangu66/p/3111419.html
Copyright © 2011-2022 走看看