• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            MyMSDN

            MyMSDN記錄開發新知道

            關于宏MAX_PATH與文件名長度的關系

            目的:測試MAX_PATH路徑與文件名的關系。

            結論:MAX_PATH代表從盤符開始到文件名結尾的C字符串長度(長度+1)的最大長度。也就是假設C:\a.txt共8個字符,長度為9,MAX_PATH通常為260,其中這個文件全名的長度不能大于260。

            測試代碼:

            image

            #include "stdafx.h"
            #include <atlbase.h>
            #include <windows.h>
            #include <atlfile.h>
            #include <atlstr.h>
            #include <iostream>
            #include <string>
            
            BOOL IsFileExist( LPCTSTR lpszFileName )
            {
                DWORD dwAttr = ::GetFileAttributes( lpszFileName );
                if ( dwAttr == 0xFFFFFFFF )
                {
                    return FALSE;
                }
                if ( ( dwAttr & FILE_ATTRIBUTE_DIRECTORY ) > 0 )
                {
                    return FALSE;
                }
                return TRUE;
            }
            
            BOOL DeleteFiles( LPCTSTR lpszPath )
            {
                TCHAR szFrom[_MAX_PATH+1] = {_T( '\0' )};
                lstrcpy( szFrom , lpszPath );
                SHFILEOPSTRUCT shf;
                memset( &shf, 0, sizeof( SHFILEOPSTRUCT ) );
                shf.hwnd = NULL;
                shf.pFrom = szFrom;
                shf.wFunc = FO_DELETE;
                shf.fFlags = FOF_NOCONFIRMMKDIR | FOF_NOCONFIRMATION |
                    FOF_NOERRORUI | FOF_SILENT;
                return SHFileOperation( &shf ) == 0;
            
            }
            
            BOOL WriteBinaryBytesToFile( LPCTSTR fileName, unsigned char* data, 
                                   unsigned int datasize , BOOL bAppend )
            {
                CAtlFile file;
                if( !bAppend && IsFileExist( fileName ))
                    DeleteFiles( fileName );
            
                HRESULT ret = file.Create( fileName, FILE_WRITE_DATA, FILE_SHARE_WRITE, bAppend?OPEN_ALWAYS:CREATE_ALWAYS );
                if ( !SUCCEEDED( ret ) )
                    return FALSE;
                if( bAppend )
                {
                    file.Seek( 0, FILE_END );
                }
                unsigned char *pos = data;
                while( datasize > 0 )
                {
                    DWORD dwWrite = 0;
                    if ( file.Write( pos , datasize , &dwWrite ) != S_OK )
                    {
                        file.Close();
                        return FALSE;
                    }
                    datasize -= dwWrite;
                    pos += dwWrite;
                }
                file.Close();
                return TRUE;
            }
            
            BOOL GCreateFile(std::string& fileNamePath,
                            std::string& fileNameExt,
                            int shortNameLength,
                            std::string& data)
            {
                char c[] = "a";
                std::string fileName;
                fileName.append(fileNamePath);
                while( shortNameLength-- )
                {
                    fileName.append(c);
                    ++*c;
                    if( *c > 'z' )
                    {
                        *c = 'a';
                    }
                }
                fileName.append(fileNameExt);
            
                std::cout << "fileName:" << fileName << std::endl;
                std::cout << "fileName.size():"<< fileName.size() << std::endl;
                std::cout << "MAX_PATH" << MAX_PATH << std::endl;
            
                if( WriteBinaryBytesToFile(fileName.c_str(), (unsigned char*)data.data(), data.size(), FALSE ) )
                {
                    std::cout << "++++++++++++++WriteBinaryBytesToFile successful.++++++++++++++" << std::endl;
                    return TRUE;
                }
                else
                {
                    std::cout << "==============WriteBinaryBytesToFile error==============." << std::endl;
                    return FALSE;
                }
            }
            
            int _tmain(int argc, _TCHAR* argv[])
            {
                std::string fileNamePath = "E:\\MyCPlusProject\\TestFileNameMaxLength\\TestFileNameMaxLength\\Output\\";
                std::string fileNameExt = ".txt";
                std::string data("This is a content.");
                
                int shortNameLength;
                shortNameLength = MAX_PATH - fileNameExt.size() - fileNamePath.size();
                GCreateFile(fileNamePath, fileNameExt, shortNameLength, data);
            
                std::cout << "------------------" << std::endl;
                shortNameLength = MAX_PATH - fileNameExt.size() - fileNamePath.size() - 1;
                GCreateFile(fileNamePath, fileNameExt, shortNameLength, data);
            
                return 0;
            }

            提示:右鍵項目屬性,將字符集設置為“未設置”。

            posted on 2010-09-04 13:59 volnet 閱讀(4031) 評論(0)  編輯 收藏 引用

            特殊功能
             
            狠狠人妻久久久久久综合| 国产午夜福利精品久久2021| 精品综合久久久久久88小说| 久久婷婷五月综合色99啪ak| 久久精品国产亚洲AV影院| 久久噜噜电影你懂的| 久久影视综合亚洲| 996久久国产精品线观看| 久久九九久精品国产免费直播| 久久无码AV一区二区三区| 久久r热这里有精品视频| 伊人色综合久久天天人守人婷| 国产精品久久久久jk制服| 热RE99久久精品国产66热| 99精品国产在热久久| 蜜桃麻豆WWW久久囤产精品| 国内精品久久久久久久久| 日本久久久久亚洲中字幕| 要久久爱在线免费观看| 久久综合久久综合久久| 久久久久亚洲精品无码蜜桃| 久久久久久久亚洲精品| 久久精品成人免费看| 久久精品国产清高在天天线| 亚洲国产天堂久久综合| 久久精品国产精品亚洲下载| 久久久久国产精品| 久久国产亚洲精品无码| 精品久久人人爽天天玩人人妻| 久久久受www免费人成| 国产亚州精品女人久久久久久 | 99久久精品免费国产大片| 亚洲精品乱码久久久久久| 国产69精品久久久久9999APGF| 精品多毛少妇人妻AV免费久久| 韩国无遮挡三级久久| 伊人色综合久久| 狠狠综合久久综合中文88| 精品久久人人妻人人做精品| 中文字幕一区二区三区久久网站| 欧美综合天天夜夜久久|