CodeSnitch显然不够聪明,不知道InitializeCriticalSection()期望处理包含未初始化指针的结构.
从CodeSnitch的角度来看它.你正在做什么和这之间有什么区别:
struct Customer { char * name; }; extern void greetCustomer(Customer* c); class CheckoutLine { private: Customer m_customer; public CheckoutLine() { greetCustomer(&m_customer); } };
这看起来对人眼更加腥,因为我们推断greetCustomer可能会依赖于m_customer被初始化,这显然不是.但从语义上讲,这与您的代码完全相同.
可能值得向Entrek提交一个错误; InitializeCriticalSection()是"结构应该在传递给函数之前初始化"规则的合理例外.
CodeSnitch显然不够聪明,不知道InitializeCriticalSection()期望处理包含未初始化指针的结构.
从CodeSnitch的角度来看它.你正在做什么和这之间有什么区别:
struct Customer { char * name; }; extern void greetCustomer(Customer* c); class CheckoutLine { private: Customer m_customer; public CheckoutLine() { greetCustomer(&m_customer); } };
这看起来对人眼更加腥,因为我们推断greetCustomer可能会依赖于m_customer被初始化,这显然不是.但从语义上讲,这与您的代码完全相同.
可能值得向Entrek提交一个错误; InitializeCriticalSection()是"结构应该在传递给函数之前初始化"规则的合理例外.