- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在编写一个小型应用程序,我想在其中检查特定应用程序是否正在运行。我创建了一个窗口,它有一个 ListView 子窗口,另一个子窗口有一个计时器,它倒计时为 0。我想不断地检查我监视的进程是否已关闭,或者时间是否已到。无论哪种方式,窗口都应该关闭。
我的问题是,我想创建一个线程来监视进程并更新 ListView 。我有一个全局变量 ProcArrayCountDisplay
,它包含当前正在显示(正在运行)的项目数。因为我在线程中更改了这个变量,并且也对其进行了监视,所以窗口可以关闭,显然出了点问题,因为有时我会遇到 Access Violation
我尝试在函数中使用 InterlockedIncrement( &ProcArrayCountDisplay );
和 InterlockedDecrement( &ProcArrayCountDisplay );
,其中结构将被修改,但没有成功。
所以很明显我做错了什么。但是我应该如何正确地做呢?有时,Listview 会闪烁。我可以做些什么吗?
提前致谢!
我的代码:
// globals
typedef struct
{
BOOL bKill;
}PARAMS, *PPARAMS;
struct ProcToDisplay
{
wchar_t * ProcessName;
wchar_t * DisplayName;
};
struct ProcToDisplay **ProcArrayDisplay = NULL;
int ProcArrayCountDisplay = 0;
BOOL InitInstance( HINSTANCE hInstance, int nCmdShow )
{
g_hInst_Main = hInstance;
int Width, Height, xPos, yPos;
Width = 400;
Height = 400;
xPos = ( GetSystemMetrics( SM_CXSCREEN ) / 2 ) - ( Width / 2 );
yPos = ( GetSystemMetrics( SM_CYSCREEN ) / 2 ) - ( Height / 2 );
g_hWnd_Main = CreateWindowEx( WS_EX_TOPMOST, WindowClassName, WindowName, WS_OVERLAPPEDWINDOW, xPos, yPos, Width, Height, NULL, NULL, hInstance, NULL );
if ( !g_hWnd_Main )
{
return FALSE;
}
ShowWindow( g_hWnd_Main, nCmdShow );
UpdateWindow( g_hWnd_Main );
return TRUE;
}
LRESULT CALLBACK MainWndProc( HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam )
{
static HBRUSH hbrBackground;
PAINTSTRUCT ps;
HDC hdc;
static unsigned ThreadId;
static HANDLE hThread = NULL;
static PARAMS params;
switch ( message )
{
case WM_CREATE:
{
INITCOMMONCONTROLSEX iccx;
iccx.dwSize = sizeof( INITCOMMONCONTROLSEX );
iccx.dwICC = ICC_LISTVIEW_CLASSES;
if ( !InitCommonControlsEx( &iccx ) )
{
// handle error
}
g_hWnd_ListView = CreateWindow( WC_LISTVIEW, NULL, WS_BORDER | WS_CHILD | WS_VISIBLE | LVS_REPORT, xStartPos, yStartPos, MaxWidth, MaxHeight, hWnd, NULL, g_hInst_Main, NULL );
if ( !g_hWnd_ListView )
{
// handle error
}
HWND hWnd_Counter = CreateWindow( WindowClassNameChild, NULL, WS_VISIBLE | WS_CHILD | SS_LEFT | WS_BORDER, 10, 370, 380, 17, hWnd, NULL, g_hInst_Main, NULL );
if ( !hWnd_Counter )
{
// handle error
}
SetTimer( hWnd_Counter, 1, 1000, NULL );
hThread = ( HANDLE )_beginthreadex( NULL, 0, Thread, ¶ms, 0, &ThreadId );
}
break;
case WM_PAINT:
{
hdc = BeginPaint( hWnd, &ps );
EndPaint( hWnd, &ps );
}
break;
case WM_CLOSE:
{
if ( wParam == 1 )
{
DestroyWindow( hWnd );
}
}
break;
case WM_DESTROY:
params.bKill = TRUE;
WaitForSingleObject( hThread, 2000 );
CloseHandle( hThread );
FreeStruct();
PostQuitMessage( 0 );
break;
default:
return DefWindowProc( hWnd, message, wParam, lParam );
}
return 0;
}
LRESULT CALLBACK ChildCounterWndProc( HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam )
{
PAINTSTRUCT ps;
HDC hdc;
switch ( message )
{
case WM_PAINT:
{
hdc = BeginPaint( hWnd, &ps );
if ( ProcArrayCountDisplay == 0 )
{
EndPaint( hWnd, &ps );
PostMessage( g_hWnd_Main, WM_CLOSE, 1, 0 );
}
RECT clientRect;
GetClientRect( hWnd, &clientRect );
//DrawText( hdc, timeString, -1, &clientRect, DT_LEFT | DT_VCENTER | DT_SINGLELINE );
ExtTextOut( hdc, 0, 0, TA_LEFT | TA_CENTER | ETO_OPAQUE, &clientRect, timeString, wcslen( timeString ), NULL );
EndPaint( hWnd, &ps );
}
break;
case WM_TIMER:
InvalidateRect( hWnd, NULL, FALSE );
break;
case WM_DESTROY:
// Destroy the timers.
KillTimer( hWnd, 1 );
PostQuitMessage( 0 );
break;
default:
return DefWindowProc( hWnd, message, wParam, lParam );
}
return 0;
}
unsigned __stdcall Thread( void *ArgList )
{
PPARAMS pparams;
pparams = ( PPARAMS )ArgList;
while ( ( !pparams->bKill ) || ( ProcArrayCountDisplay > 0 ) )
{
// clear previous data
ListView_DeleteAllItems( g_hWnd_ListView );
FreeStructDisplay(); // frees the array and decrements ProcArrayCountDisplay
for ( int i = 0; i < ProcArrayCountQuery; i++ )
{
// querys the processes and adds them to the array
if ( !IsProcessRunning( ProcArrayQuery[ i ]->ProcessName, ProcArrayQuery[ i ]->DisplayName ) )
{
// IsProcessRunning failed
}
}
if ( ProcArrayCountDisplay == 0 )
{
// no package to display
break;
}
// display processes
InsertListViewItems();
Sleep( 1000 );
}
_endthread();
return 0;
}
最佳答案
仅根据您的描述(线程和访问冲突),您的数据可能无法防止多个进程(线程)访问它。如果为真,这又可能是您访问冲突的原因。谷歌 critical sections , semaphores , mutex ,(这些链接只是一个开始)所有这些都与为需要在进程之间共享的数据实现线程安全有关。
这是一个使用临界区的例子( from HERE)
这是最容易查看和理解的方法之一。您基本上定义了一个 protected 逻辑区域。只有共享数据才能被编辑。在这个例子中,每次进入线程处理函数,逻辑流入临界区,数据被编辑,然后逻辑流出临界区。
DWORD WINAPI ThreadProc( LPVOID lpParameter )
{
...
// Request ownership of the critical section.
EnterCriticalSection(&CriticalSection);
// Access the shared resource.
// Release ownership of the critical section.
LeaveCriticalSection(&CriticalSection);
...
return 1;
}
查看提供的链接 上面,了解如何创建全局 (CriticalSection) 以及如何在使用前进行初始化。
关于c - 持续更新 ListView 的正确方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29903100/
如果我错了,但身份验证 session 有 30 天的最大限制,请纠正我?如果是这种情况,有没有办法让我的服务器节点应用程序永远监听经过身份验证的 dataRef? 干杯, 旅行。 最佳答案 自 on
我目前正在阅读 book Continuos Delivery由 Humble/Farley 撰写,虽然里面的很多东西都是有道理的,但有一件事让我烦恼: 似乎作者只针对基于服务器的(单客户端?)应用程
好吧,我非常了解每个人对自制密码管理器的看法,但我希望得到帮助。 不用于实际使用,仅供学习。 我想知道,在 C++ 中如何拥有长期变量。或者真的,有什么长期的。 长期是什么意思?在下次运行 .exe
我在文本文件中有以下三行(最后 3 行): } } } 我想做的是做这样的事情: } } blablabla blablabla blabla
在 iOS 中,有没有一种简单的方法可以在每天的同一时间发送 10 天的推送通知?我不想向所有用户发送推送通知。我的应用程序的工作方式是,用户可以选择连续十天推送通知的时间。您有推荐的 API 吗?或
我正在努力寻找一种当前最先进的方法来处理频繁更新的通知(例如每 3 分钟一次)。似乎在较新的 Android 版本中内置了如此多的电源效率调整(幸运的是!),我之前成功使用的方法(使用 Broadca
我不得不在一些糟糕的房地产网站上花费大量时间。我比较精通 CSS,并且可以(在 FireFox 中)“检查元素”并更改 CSS 以隐藏或缩小特定页面的华而不实的元素。但我想将此自定义 CSS 应用于特
目前正在研究如何使用 signalR 在处理文件时向用户呈现文件的进度报告。我正在使用 asp.net MVC 4。通过 Ajax 进行发布/获取时,我可以轻松获取状态更改。 因为我需要上传一个文件(
这个问题在这里已经有了答案: How can I round up the time to the nearest X minutes? (15 个答案) Is there a simple fun
我有一个 php 脚本,我想运行特定的时间(例如 5 分钟),但只能运行一次。对于 cron 作业,这将无限期地运行。还有别的办法吗? 最佳答案 处理这个问题的方法是: 当某些事件触发需要 cron
我弄乱了我的 apache 和 php.ini 文件,我网站的用户仍然提示该网站在很短的时间后或每次他们关闭并打开同一个浏览器时将他们注销。 我正在运行 Apache 和 PHP。 我应该进行哪些设置
如何查询今天的总和需要减去前一天的总和,每天持续一个月。 SELECT COUNT(DISTINCT member_profile.memberProfileNumber) FROM member_p
这个问题在这里已经有了答案: How do I add a delay in a JavaScript loop? (32 个答案) 关闭 8 年前。 我认为这个问题之前一定有人问过,但我找不到其他
用户在我的网站上注册后,我们会向他发送一封确认电子邮件。我想要的是 - 三天内每 24 小时为用户重新发送一次电子邮件。例如: user_table id , name, date_registere
最近我从 Codeigniter 换到了 Laravel,一切都很顺利,除了我遇到了 Session::flash 的问题。 当我创建新用户时,我收到成功消息,但它会持续 2 个请求,即使我没有通过验
如果有人能帮助我解决这个问题,我将非常感激。 我正在尝试针对 CPU 使用率 >= 80% 持续 30 分钟或更长时间创建 Azure 监视器警报 我已附上警报规则条件的屏幕截图。在“评估依据”下,聚
如果有人能帮助我解决这个问题,我将非常感激。 我正在尝试针对 CPU 使用率 >= 80% 持续 30 分钟或更长时间创建 Azure 监视器警报 我已附上警报规则条件的屏幕截图。在“评估依据”下,聚
希望大家平安 1。我的目标 我正在尝试模拟 3 天的真实情况。系统每天只能工作 8 小时。 我的目标是模型运行 8 小时,持续 3 天,以获得足够的数据进行分析。 2。我的问题 我有一个代理预约时间表
我需要在 8 小时内每 5 分钟调用一次函数。问题是它必须是同一天。例如,如果用户在 3/29 晚上 11:59 登录系统,而现在是 3/30 凌晨 12:01,则不应再调用该函数。 我知道如何每
我正在开发一个 React Native 应用程序,该应用程序使用 Firebase 的 Firestore 作为后端。现在,每次收到新消息时,我都会从 Firestore 获取所有消息并更新我的状态
我是一名优秀的程序员,十分优秀!