许多来源,包括微软,都将int和long类型都引用为4个字节,并且范围为(带符号)-2,147,483,648到2,147,483,647.如果实际上没有提供更大范围的值,那么拥有长基本类型有什么意义呢?
这是一个相当简单的泛型类.通用参数被约束为引用类型.IRepository并且DbSet还包含相同的约束.
public class Repository<TEntity> : IRepository<TEntity>
where TEntity : class, IEntity
{
protected readonly DbSet<TEntity> _dbSet;
public void Insert(TEntity entity)
{
if (entity == null)
throw new ArgumentNullException("entity", "Cannot add null entity.");
_dbSet.Add(entity);
}
}
Run Code Online (Sandbox Code Playgroud)
编译的IL包含box指令.这是发布版本(虽然调试版本也包含它).
.method public hidebysig newslot virtual final
instance void Insert(!TEntity entity) cil managed
{
// Code size 38 (0x26)
.maxstack 8
IL_0000: ldarg.1
>>>IL_0001: box !TEntity
IL_0006: brtrue.s IL_0018
IL_0008: ldstr "entity"
IL_000d: ldstr "Cannot add null entity."
IL_0012: …Run Code Online (Sandbox Code Playgroud) 我在Web配置中有以下连接字符串,在Visual Studio中工作正常.
<connectionStrings>
<add name="DefaultConnection" connectionString="Data Source=(LocalDb)\MSSQLLocalDB;AttachDbFilename=|DataDirectory|\aspnet-MyPortal-20170627104450.mdf;Initial Catalog=aspnet-MyPortal-20170627104450;Integrated Security=True" providerName="System.Data.SqlClient" />
</connectionStrings>
Run Code Online (Sandbox Code Playgroud)
我尝试使用Azure App服务和Azure AD将我的ASP.NET MVC应用程序移植到Azure.我更改了AttachDbFilename属性,如下所示
AttachDbFilename=\App_Data\aspnet-MyPortal-20170620051631.mdf
我收到以下错误:
键'attachdbfilename'的值无效.
描述:执行当前Web请求期间发生未处理的异常.请查看堆栈跟踪以获取有关错误及其源自代码的位置的更多信息.
异常详细信息:System.ArgumentException:键"attachdbfilename"的值无效.
源错误:
在执行当前Web请求期间生成了未处理的异常.可以使用下面的异常堆栈跟踪来识别有关异常的起源和位置的信息.
App Data文件夹包含mdf文件.如何在Web配置的连接字符串中引用它?
是否有Azure Web应用程序的示例程序通过Azure AD进行身份验证?

我long int对16位CPU 的大小有疑问.看看它的架构:

没有寄存器超过16位长.那么,怎么会有long int超过16位.事实上,根据我的任何处理器,数据类型的最大大小必须是通用寄存器的大小.我对吗?