C# 构造函数依赖注入 使用out向外传递参数

天真

csharp 复制代码
using System;

namespace forCode20191 {
    class Program {
        static void Main(string[] args) {
            bool flag = false;
            Tmp tt = new Tmp(out flag);
            Console.WriteLine(flag); // 将输出 false
            tt.Doit();
            Console.WriteLine(flag); // 将输出 true
            Console.ReadKey();
        }
    }

    class Tmp {
        public bool Flag { get; private set; } // 将flag作为公共属性,只能通过类内部set

        public Tmp(out bool flag) {
            Flag = false; // 初始化成员变量
            flag = Flag; // 将成员变量的值赋给out参数
        }

        public void Doit() {
            Flag = true; // 修改成员变量的值
        }
    }
}

目前解决方法

C#中,out参数是在方法调用时才创建的,它的作用域仅限于方法调用的上下文。这意味着,一旦构造函数Tmp执行完毕,out参数flag就不再存在了。因此,您不能在Tmp类的其他方法中访问这个flag变量。

在构造函数中,您可以将flag设置为某个值,但是一旦构造函数执行完毕,您就无法再修改这个flag了。如果您希望在类的其他方法中修改这个标志,您需要将这个标志作为类的成员变量。

下面是修改后的代码,其中flagTmp类的成员变量,可以在类的任何方法中访问和修改:

csharp 复制代码
using System;

namespace forCode20191 {
    class Program {
        static void Main(string[] args) {
            Tmp tt = new Tmp();
            Console.WriteLine(tt.Flag); // 输出 false,因为Flag在构造时被设置为false
            tt.Doit();
            Console.WriteLine(tt.Flag); // 输出 true,因为Doit方法将Flag设置为true
            Console.ReadKey();
        }
    }

    class Tmp {
        public bool Flag { get; private set; } // 将flag作为只读公共属性

        public Tmp() {
            Flag = false; // 初始化Flag为false
        }

        public void Doit() {
            Flag = true; // 在Doit方法中将Flag设置为true
        }
    }
}
相关推荐
武子康1 小时前
Java-71 深入浅出 RPC Dubbo 上手 父工程配置编写 附详细POM与代码
java·分布式·程序人生·spring·微服务·rpc·dubbo
武子康3 小时前
Java-72 深入浅出 RPC Dubbo 上手 生产者模块详解
java·spring boot·分布式·后端·rpc·dubbo·nio
_殊途3 小时前
《Java HashMap底层原理全解析(源码+性能+面试)》
java·数据结构·算法
椰椰椰耶4 小时前
【Spring】拦截器详解
java·后端·spring
没有bug.的程序员5 小时前
JAVA面试宝典 - 《MyBatis 进阶:插件开发与二级缓存》
java·面试·mybatis
brzhang5 小时前
我操,终于有人把 AI 大佬们 PUA 程序员的套路给讲明白了!
前端·后端·架构
止观止6 小时前
React虚拟DOM的进化之路
前端·react.js·前端框架·reactjs·react
goms6 小时前
前端项目集成lint-staged
前端·vue·lint-staged
谢尔登6 小时前
【React Natve】NetworkError 和 TouchableOpacity 组件
前端·react.js·前端框架
Lin Hsüeh-ch'in6 小时前
如何彻底禁用 Chrome 自动更新
前端·chrome