-
c# 一些警告的处理方法
在使用.Net 6开发程序时,发现多了很多新的警告类型。这里总结一下处理方法。
CS8618 在退出构造函数时,不可为 null 的 属性“Name”必须包含非 null 值
经常遇到的有CS8618警告:如果定义属性可能为空时,在编译时会报这个警告,比如下面的代码:
public class Play
{
public string Name { get; set; }
public Play()
{
}
警告如下:
CS8618 在退出构造函数时,不可为 null 的 属性“Name”必须包含非 null 值。请考虑将 属性 声明为可以为 null。
处理办法是将属性声明为可以为空:
public class Play
{
public string? Name { get; set; }
public Play()
{
}
}
或者,给属性设置初始值:
public class Play
{
public string Name { get; set; } = "";
public Play()
{
}
}
但遇到下面的情况,这两种办法就不能用了:
public class GameSocialDbContext : DbContext
{
public DbSet<GameMessage> GameMessages { get; set; }
public DbSet<Player> Players { get; set; }
public GameSocialDbContext(DbContextOptions<GameSocialDbContext> options) : base(options)
{
}
}
这种情况下,可以将属性设置default!来避免警告:
public DbSet<Game> Games { get; set; } = default!;
public DbSet<Player> Players { get; set; } = default!;
CS1998 此异步方法缺少await运算符
这种情况通常出现在重载或者实现某个异步方法时,没有可调用的异步函数。比如下面的方法:
public async Task RemoveAsync(Player player)
{
Players.Remove(player);
}
这种情况下,可以在退出前增加 await Task.CompletedTask;来避免警告。
如果需要返回值,比如:
public async Task<List<Player>> GetAllAsync()
{
return colTemp.AsQueryable<Player>().ToList();
}
这时,可以使用await Task.FromResult()作为返回值:
public async Task<List<Player>> GetAllAsync()
{
return await Task.FromResult(colTemp.AsQueryable<Player>().ToList());
}
CS8602 解引用可能出现空引用
如果采用as进行转换,可能出现这个警告:
await (handler as IEventHandler).HandleEvent(data);
可以改为强制转换:
await ((IEventHandler)handler).HandleEvent(data);
也可以使用!操作符:
await (handler as IEventHandler)!.HandleEvent(data);
还可以在调用前判断是否为空,如果为空,抛出异常。
CS8603 可能返回null引用
这种警告多出现在过滤时,比如:
public async Task<Player> GetPlayerByNameAsync(string name)
{
return await gameDbContext.Players
.Include(p => p.SentFriendRequests)
.Include(p => p.ReceievedFriendRequests).FirstOrDefaultAsync(p => p.UserName == name);
}
由于FirstOrDefault可能返回空值,所以会出现警告。可以改为使用First:
public async Task<Player> GetPlayerByNameAsync(string name)
{
return await gameDbContext.Players
.Include(p => p.SentFriendRequests)
.Include(p => p.ReceievedFriendRequests).FirstAsync(p => p.UserName == name);
}
或者允许返回值为空:
public async Task<Player?> GetPlayerByNameAsync(string name)
{
return await gameDbContext.Players
.Include(p => p.SentFriendRequests)
.Include(p => p.ReceievedFriendRequests).FirstOrDefaultAsync(p => p.UserName == name);
}
最后需要说明的是,警告是为了提示程序可能的潜在问题,消除警告时,需要结合具体情况确定使用哪种方式,不要为了去掉警告忽略潜在的问题。
本文来自博客园,作者:寻找无名的特质,转载请注明原文链接:https://www.cnblogs.com/zhenl/p/16197865.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数