我知道这个问题可能与其他一些问题重复,但我想在做出这个改变之前确定我是正确的,所以无论如何我都会问这里。在一个旧项目中,我维护的是这行代码:
TCHAR m_sLogPath[MAX_LOGPATH_LEN];
有一行代码可以初始化和使用数组,但过了一段时间就有了这个检查:
if(NULL== m_sLogPath || _tcsicmp(m_sLogPath, trace_path)!=0){//code here}
我猜这个if语句正在检查m_sLogPath是否为空,但是NULL == m_sLogPath是一个无意义的检查,因为将数组与NULL进行比较是没有意义的。我将不得不删除NULL == m_sLogPath peice,我的问题是应该去那里检查数组是否为空?感谢所有答案和帮助,
答案 0 :(得分:8)
你是对的,如果在同一个环境中完成,这是一个毫无意义的检查。
如果将它作为参数传递给函数,则数组会衰减为指针并且它不是那么无意义。
应该去那里检查数组是否为空
好吧,数组永远不会是空的。它将始终包含MAX_LOGPATH_LEN
TCHAR
s。但以下可以做到这一点:
if( m_sLogPath[0] == _T('\0') || _tcsicmp(m_sLogPath, trace_path)!=0)
答案 1 :(得分:3)
m_sLogPath
数组始终包含MAX_LOGPATH_LEN
个字符。假设MAX_LOGPATH_LEN
是一个大于0的常量,那么数组永远不会为空。
我猜你真正要检查的是这个数组中存储的C风格的字符串是否为空。如果是这种情况,那么最简单的方法是:
#include <tchar.h>
#include <windows.h>
const size_t MAX_LOGPATH_LEN = MAX_PATH;
TCHAR m_sLogPath[MAX_LOGPATH_LEN];
int main()
{
if (m_sLogPath[0] == _T('\0'))
{
// m_sLogPath contains empty string.
}
}