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
        }
    }
}
相关推荐
测试界柠檬几秒前
面试真题 | web自动化关闭浏览器,quit()和close()的区别
前端·自动化测试·软件测试·功能测试·程序人生·面试·自动化
多多*1 分钟前
OJ在线评测系统 登录页面开发 前端后端联调实现全栈开发
linux·服务器·前端·ubuntu·docker·前端框架
2301_801074152 分钟前
TypeScript异常处理
前端·javascript·typescript
小阿飞_3 分钟前
报错合计-1
前端
caperxi5 分钟前
前端开发中的防抖与节流
前端·javascript·html
霸气小男5 分钟前
react + antDesign封装图片预览组件(支持多张图片)
前端·react.js
susu10830189115 分钟前
前端css样式覆盖
前端·css
学习路上的小刘7 分钟前
vue h5 蓝牙连接 webBluetooth API
前端·javascript·vue.js
&白帝&7 分钟前
vue3常用的组件间通信
前端·javascript·vue.js
小白小白从不日白18 分钟前
react 组件通讯
前端·react.js