using System.IO;
using System.Runtime.InteropServices;
[DllImport("kernel32.dll")]
public static extern IntPtr _lopen(string lpPathName, int iReadWrite);
[DllImport("kernel32.dll")]
public static extern bool CloseHandle(IntPtr hObject);
public const int OF_READWRITE = 2;
public const int OF_SHARE_DENY_NONE = 0x40;
public readonly IntPtr HFILE_ERROR = new IntPtr(-1);
private void button1_Click(object sender, EventArgs e)
{
string vFileName = @"c:\temp\temp.bmp";
if (!File.Exists(vFileName))
{
MessageBox.Show("文件都不存在!");
return;
}
IntPtr vHandle = _lopen(vFileName, OF_READWRITE | OF_SHARE_DENY_NONE);
if (vHandle == HFILE_ERROR)
{
MessageBox.Show("文件被占用!");
return;
}
CloseHandle(vHandle); //判断之后一定要关闭!!!
MessageBox.Show("没有被占用!");
}
相关文章
- 07-17宏判断是否为Excel打开,若不是则关闭表格
- 07-17当outlook打开附件的EXCEL表报出 文件已经损坏 但别人能打开时
- 07-17当outlook打开附件的EXCEL表报出 文件已经损坏 但别人能打开时
- 07-17判断该文件是否是Excel文档
- 07-17搬家第13天-169.Wincc V7.3 VBS 判断Excel文件是否打开,避免重复打开
- 07-17C#中的Excel操作【1】——设置Excel单元格的内容,打开Excel文件的一种方式
- 07-17C#判断窗体是否存在重复打开
- 07-17C# Aspose.Cells导出xlsx格式Excel,打开文件报“Excel 已完成文件级验证和修复。此工作簿的某些部分可能已被修复或丢弃”
- 07-17paip.判断文件是否存在uapi python php java c#
- 07-17C# 判断(Excel)文件是否已经打开