CreateDirectory 함수(winbase.h)
새 디렉터리를 만듭니다. 기본 파일 시스템에서 파일 및 디렉터리에 대한 보안을 지원하는 경우 함수는 지정된 보안 설명자를 새 디렉터리에 적용합니다.
템플릿 디렉터리를 지정하려면 CreateDirectoryEx 함수를 사용합니다.
이 작업을 트랜잭션 작업으로 수행하려면 CreateDirectoryTransacted 함수를 사용합니다.
통사론
BOOL CreateDirectory(
[in] LPCTSTR lpPathName,
[in, optional] LPSECURITY_ATTRIBUTES lpSecurityAttributes
);
매개 변수
[in] lpPathName
만들 디렉터리의 경로입니다.
이 함수의 ANSI 버전의 경우 248자의 경로에 대한 기본 문자열 크기 제한이 있습니다(MAX_PATH - 8.3 파일 이름에 충분한 공간). 이 제한을 32,767개의 와이드 문자로 확장하려면 함수의 유니코드 버전을 호출하고 경로 앞에 "\?"를 추가합니다. 자세한 내용은 파일 이름 지정 참조하세요.
[in, optional] lpSecurityAttributes
SECURITY_ATTRIBUTES 구조체에 대한 포인터입니다. 구조체의 lpSecurityDescriptor 멤버는 새 디렉터리에 대한 보안 설명자를 지정합니다.
대상 파일 시스템은 이 매개 변수가 적용되려면 파일 및 디렉터리에 대한 보안을 지원해야 합니다.
(GetVolumeInformation
반환 값
함수가 성공하면 반환 값은 0이 아닌 값입니다.
함수가 실패하면 반환 값은 0입니다. 확장 오류 정보를 얻으려면 GetLastError호출합니다. 가능한 오류는 다음과 같습니다.
반환 코드 | 묘사 |
---|---|
|
지정된 디렉터리가 이미 있습니다. |
|
하나 이상의 중간 디렉터리를 존재하지 않습니다. 이 함수는 경로에 최종 디렉터리만 만듭니다. |
발언
NTFS 파일 시스템과 같은 일부 파일 시스템은 개별 파일 및 디렉터리에 대한 압축 또는 암호화를 지원합니다. 이러한 파일 시스템에 대한 형식이 지정된 볼륨에서 새 디렉터리가 부모 디렉터리의 압축 및 암호화 특성을 상속합니다.
애플리케이션은 FILE_FLAG_BACKUP_SEMANTICS 플래그가 설정된 CreateFile 호출하여 디렉터리에 대한 핸들을 가져올 수 있습니다. 코드 예제는 CreateFile참조하세요.
이 개체의 보안 설명자를 쿼리하는 상속 함수를 지원하기 위해 추론적으로 상속이 적용되는지 확인하고 보고할 수 있습니다. 자세한 내용은 상속 가능한 ACE
Windows 8 및 Windows Server 2012에서 이 함수는 다음 기술에서 지원됩니다.
기술 | 지원 |
---|---|
SMB(서버 메시지 블록) 3.0 프로토콜 | 예 |
SMB 3.0 TFO(투명한 장애 조치(failover) | 예 |
SO(스케일 아웃 파일 공유)가 있는 SMB 3.0 | 예 |
CsvFS(클러스터 공유 볼륨 파일 시스템) | 예 |
ReFS(복원 파일 시스템) | 예 |
예제
예를 들어 파일 특성 검색 및 변경참조하세요.
요구 사항
요구 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows XP [데스크톱 앱 | UWP 앱] |
지원되는 최소 서버 | Windows Server 2003 [데스크톱 앱 | UWP 앱] |
대상 플랫폼 | Windows |
헤더 | winbase.h(Windows.h 포함) |
라이브러리 | Kernel32.lib |
DLL | Kernel32.dll |
참고 항목
CreateDirectoryEx
createDirectoryTransacted
CreateFile
RemoveDirectory