小编ima*_*mak的帖子

何时使用公用表表达式(CTE)

我已经开始阅读有关Common Table Expression的内容,并且无法想到我需要使用它们的用例.它们似乎是多余的,因为派生表可以做到这一点.有什么我缺少或不理解?有人能给我一个简单的限制例子,通过常规的select,derived或temp表查询来说明CTE的情况吗?任何简单的例子都将受到高度赞赏.

sql t-sql sql-server common-table-expression

219
推荐指数
7
解决办法
33万
查看次数

找不到类型或命名空间名称"T"

我有以下代码,我正在.NET 4.0项目中编译

namespace ConsoleApplication1  
{  
    class Program  
    {  
        static void Main(string[] args)  
        {  

        }  
    }  

    public static class Utility  
    {  
        public static IEnumerable<T> Filter1(this IEnumerable<T> input, Func<T, bool> predicate)  
        {  
            foreach (var item in input)  
            {  
                if (predicate(item))  
                {  
                    yield return item;  
                }  
            }  
        }  
    }  
}  
Run Code Online (Sandbox Code Playgroud)

但得到以下错误.我已将System.dll作为默认值包含在引用中.我可能做错了什么?

Error   1   The type or namespace name 'T' could not be found (are you missing a using directive or an assembly reference?) 

Error   2   The type or namespace name 'T' could not …
Run Code Online (Sandbox Code Playgroud)

c# generics

41
推荐指数
3
解决办法
6万
查看次数

Enterprise Logging Block vs NLog vs log4net

我需要在我的项目中使用日志库,并考虑在Enterprise Logging Block与NLog vs log4net之间.我在比较中发现了一些链接,但大多数链接已经很老了,并抱怨没有新版本的log4net等等.

任何人都建议根据当前数据在易用性,易配置性,性能,可扩展性等方面哪一个更好.

c# log4net enterprise-library nlog

26
推荐指数
3
解决办法
2万
查看次数

绩效计数器与ETW

性能计数器是ETW的一部分吗?如果没有,两者有什么区别?

performance performancecounter etw

22
推荐指数
2
解决办法
5760
查看次数

了解32位与64位之间的CLR对象大小

我试图了解32位和64位处理器之间的对象大小差异.假设我有一个简单的课程

class MyClass   
{  
    int x;  
    int y;  
}  
Run Code Online (Sandbox Code Playgroud)

所以在32位机器上,整数是4个字节.如果我将Syncblock添加到其中(另外4个字节),则对象大小将为12个字节.为什么显示16个字节?

0:000> !do 0x029d8b98  
Name: ConsoleApplication1.Program+MyClass  
MethodTable: 000e33b0  
EEClass: 000e149c  
Size: 16(0x10) bytes  
 (C:\MyTemp\ConsoleApplication1\ConsoleApplication1\bin\x86\Debug\ConsoleApplication1.exe)  
Fields:  
      MT    Field   Offset                 Type VT     Attr    Value Name  
71972d70  4000003        4         System.Int32  1 instance        0 x  
71972d70  4000004        8         System.Int32  1 instance        0 y  

在64位机器上,一个整数仍然是4个字节,唯一改变的是Syncblock将是8个字节(因为指针是64位机器上的8个字节).这意味着对象大小将是16个字节.为什么显示24个字节?

0:000> !do 0x00000000028f3c90  
Name: ConsoleApplication1.Program+MyClass  
MethodTable: 000007ff00043af8  
EEClass: 000007ff00182408  
Size: 24(0x18) bytes  
 (C:\MyTemp\ConsoleApplication1\ConsoleApplication1\bin\Debug\ConsoleApplication1.exe)  
Fields:  
              MT    Field   Offset                 Type VT     Attr            Value Name  
000007fef4edd998  4000003        8         System.Int32  1 instance                0 x  
000007fef4edd998 …

.net windbg sos

16
推荐指数
2
解决办法
2787
查看次数

获取数组中第一个条目的指针

我想得到数组中第一个条目的指针.这就是我尝试的方式

int[] Results = { 1, 2, 3, 4, 5 };

unsafe
{
    int* FirstResult = Results[0];
}
Run Code Online (Sandbox Code Playgroud)

获取以下编译错误.任何想法如何解决它?

您只能在固定语句初始值设定项中获取未固定表达式的地址

c# unsafe-pointers

13
推荐指数
3
解决办法
2万
查看次数

CLR 4.0中新的ETW功能究竟是什么?

我的同事提到CLR 4.0 在Windows事件跟踪方面有一些重大改进,但我找不到具体内容的细节.很少有博客文章仅提及改进,但没有提供有关新内容的详细信息.任何人都有更深入的了解吗?

.net clr etw clr4.0

11
推荐指数
1
解决办法
1769
查看次数

如何在跟踪中包含用户友好的时间戳

我试图理解Trace.Writevs Trace.TraceInformation和应该使用哪个之间的区别.

我尝试配置traceOutputOptions时间戳/日期时间.我只需要为我正在编写的每条消息添加时间戳.我得到的日期时间有点混乱,因为它在下一行中附加应用程序名称和较少用户友好的时间戳,如下所示.

ConsoleApplication1.exe Information: 0 : Hello  - Trace!  
DateTime=2011-01-31T14:26:11.1538509Z  
ConsoleApplication1.exe Error: 0 : Hello  - Trace!  
DateTime=2011-01-31T14:26:11.1538509Z  
Run Code Online (Sandbox Code Playgroud)

我所需要的就像是

2011-01-31 11:32 Information: Hello - Trace!  
2011-01-31 11:33 Error: Hello - Trace!
Run Code Online (Sandbox Code Playgroud)

App.config这样做有什么简单的方法吗?

c# trace system.diagnostics

10
推荐指数
2
解决办法
2963
查看次数

是否存在不应使用任务的情况?

我正在阅读有关使用4.0进行异步编程的首选方法.我只是想知道是否有任何用例不应该优先使用任务而不是普通的c#线程?

.net c# multithreading task-parallel-library

9
推荐指数
2
解决办法
261
查看次数

Windows错误报告在哪里创建转储文件

我只是想知道WER写入转储文件的位置?这个位置也是特定于OS的吗?

windows windbg windows-error-reporting

6
推荐指数
1
解决办法
2万
查看次数