在类中如何重写和格式化ToString方法?

如何解决在类中如何重写和格式化ToString方法?

| 我已经搜索了Google和该网站,以找到答案。我在课堂上也读过它,但是我仍然不明白它是如何应用的。 这是我所知道的: 它用于显示对象对自身的了解。 它可以用来格式化输出,使其了解自己的知识。 在要使用的方法中,它已被覆盖。     

解决方法

认为您有一个类似的课程:
public class Person
{
   public string FirstName { get; set;}
   public string LastName { get; set;}
   private string age;
}
使用这个:
public override string ToString()
{
   return string.Format(\"[First Name: {0}; Last Name: {1}; Age: {2}]\",FirstName,LastName,age);
}
将揭示该课程的所有内部内容。实际上,它最好用于以预先格式化的方式快速检索类的公共字段(从而有效地将封装在类中的数据转换为字符串)。 这也是Pro C#2010和.NET 4 Platform书中的一个非常有用的建议:\“您创建的许多类(和结构)可以从重写ToString()中受益,以便返回该类型当前字符串的文本表示形式。状态(这对于调试目的非常有用(除其他原因外)。如何选择构造此字符串是个人选择的问题;但是,建议的方法是用分号分隔每个名称/值对并包装整个在方括号中的字符串。但是,请始终记住,正确的ToString()重写也应该考虑继承链中定义的任何数据。当您为扩展自定义基类的类重写ToString()时,首要业务是可以使用base关键字从父级获取ToString()值。获得父级的字符串数据后,可以附加派生类的自定义信息。     ,所有.NET类的基类都是
object
类型。对象类为您提供了默认的实现
ToString()
,默认情况下只会打印出类的名称,除非该类已重写
ToString()
方法以打印其他内容。类的名称不是特别有用,因此通常在您编写的任何类中重写
ToString()
都是一个好习惯,因为它提供了易于理解的类表示形式。当您要检查类的实例时,默认情况下,调试器实际上将使用
ToString()
实现。 在您的课程中,您要做的就是添加以下方法:
public override string ToString()
{
    // return a string that has something to do with your class
}
例:
public class Person
{
    public string FirstName {get;set;}
    public string LastName {get;set;}
    public int Age {get;set;}

    public override void ToString()
    {
        // return whatever makes sense here...
        return string.Format(\"[Person: FirstName={0},LastName={1},Age={2}]\",Age);
    }
}
请注意,“ 9”方法只是创建字符串的一种方法。 string.Format的第一个参数是\“ format,\”,它可以包含文字文本以及将作为其他参数提供的值的占位符。上面的
{0}
{1}
{2}
是在格式之后传递的FirstName,LastName和Age参数的占位符。如果您想了解更多,我会读string.Format。     ,覆盖
ToString()
方法:
public class Test
{
   public string FirstName { get; set; }

   public string LastName { get; set; }

   public override string ToString()
   {
      // Do your formatting here
      return LastName + \",\" + FirstName;
   }
}
    ,您必须在类中重写ToString()。假设我有一个包含m_nDays,m_nHours,m_nMinutes的类……那么我可以如下重写ToString():
public override string ToString()
{
    return string.Format(\"{0,5}d - {1:00}:{2:00}\",m_nDays,m_nHours,m_nMinutes);
}
    

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 <select id="xxx"> SELECT di.id, di.name, di.work_type, di.updated... <where> <if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 <property name="dynamic.classpath" value="tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-