随笔 - 547  文章 - 213 评论 - 417 阅读 - 107万

  我想在一个web应用程序中运行一段控制台应用程序,于是新建了一个类,写下了如下的代码:

using System;
using System.Reflection;

namespace Test
{
    
/// <summary>
    
/// TestReflector 的摘要说明。
    
/// </summary>
    public class TestReflector
    {
        
public TestReflector()
        {
            
//
            
// TODO: 在此处添加构造函数逻辑
            
//
        }

        
#region Main() // 控制台应用程序的入口点
        
/// <summary>
        
/// 控制台应用程序的入口点
        
/// </summary>
        public static void Main()
        {    
            Assembly assem 
= Assembly.GetExecutingAssembly();
            Reflector.ReflectOnAssembly( assem );
        
        }

        
#endregion
    }


    
public class Reflector
    {
        
public static void ReflectOnAssembly( Assembly assem )
        {
            WriteLine( 
0 , "Assembly:{0}" , assem );

            
//查找模块
            foreach( Module m in assem.GetModules() )
            {
                WriteLine( 
1 , "Module: {0}" , m );
                
                
//查找类型
                foreach( Type t in m.GetTypes() )
                {
                    WriteLine( 
2 , "Type : {0}" , t );

                    
//查找成员
                    foreach( MemberInfo mi in t.GetMembers() )
                    {
                        WriteLine( 
3 , "{0}:{1}" , mi.MemberType , mi );
                    }
                }

            }
        }

        
private static void WriteLine( Int32 indent , String format , params Object[] args )
        {
            Console.WriteLine( 
new String( ' ' , 3 * indent ) + format , args );
        }

        
        
    }


}

然后将该应用程序设置为启动项目,按F5键,结果运行的还是web应用程序,看来这种方法不成,只有新建一个控制台项目了。


 

posted on   今夜太冷  阅读(461)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示