- 浏览: 21195 次
- 性别:
- 来自: 新乡
最近访客 更多访客>>
文章分类
- 全部博客 (24)
- WIDE JAVA (2)
- SHARE JAVA (1)
- DAY JAVA (2)
- ERROR JAVA (1)
- ENGLISH JAVA (0)
- OSA JAVA (0)
- CORE JAVA (0)
- BOOK JAVA (0)
- TEMP JAVA (0)
- WIDE DELPHI (0)
- SHARE DELPHI (0)
- DAY DELPHI (2)
- ERROR DELPHI (0)
- ENGLISH DELPHI (1)
- OSA DELPHI (0)
- CORE DELPHI (0)
- TEMP DELPHI (0)
- BOOK DELPHI (0)
- SHARE CPP (1)
- TEMP CPP (1)
- BOOK CPP (2)
- PS (0)
- LINUX (1)
- WINDOWS (0)
- THE ART OF ALGORITHM (1)
- ENGLISH CPP (4)
- DAY CPP (3)
- PROBLEMS (1)
- ENGLISH (1)
- 黑马程序员Heima (0)
- Help Yourself (0)
最新评论
TIEM:18:21 2011/10/24
chapter1:Error Handling
overview
Before we jump in and start examining the many features that Microsoft Windows has to offer,
you should understand how the various Windows functions perform their error handling.
When you call a Windows function,it validates the parameters that you pass to it and then attempts to perform its duty.
If you pass an invalid parameter or if for some other reason the action cannot be performed,
the function's return value indicates that the function failed in some way.
Table 1.1 shows the return value data types that most Windows functions use.
-------------------------------------------------
Table1.1:Common Return Types for Windows Functions.
Data Type Value to Indicate Failure
VOID This function can not possibly fail.Very few Windows functions have a return type of VOID.
BOOL If the function fails,the return value is 0;otherwise,the return value is non-zero.
Avoid testing the return value to see if it is TRUE:it is alway best to test this return value to see
if it is different from FALSE.(HYP:And the reason ,and why that goes)
Handle If the function fails,the return value is usually NULL;otherwise,the HANDLE identifies an object that
you can manipulate.Be careful with this one because some functions return a handle value of INVALID_HANDLE_VALUE,
which is defined as -1.The Platform SDK documentation for the function will clearly state whether the
function return NULL or INVALID_HANDLE_VALUE to indicate failure.
PVOID If the function fails,the return value is NULL;otherwise,PVOID identifies the memory address of a data block.
LONG/DWORD This is a tough one.Functions that return counts usually return a LONG or DWORD.
If for some reason the function can't count the thing you want counted,
the function usually returns 0 or -1(depending on the function).
If you are calling a function that returns a LONG/DWORD,
please read the Platform SDK documentation carefully to ensure that you are properly checking for potential errors.
----------------------------------------------------
When a Windows function returns with an error code,
it's frequently useful to understand why the function failed.
Microsoft has compiled a list of all possible error codes and has assigned each error code a 32-bit number.
Internally,when a Windows function detects an error,
it uses a mechanism called thread-local storage to associate the appropriate error-code number with the calling thread.
(Thread-local storage is discussed in Chapter 21,"Thread-Local Storage")
This mechanism allows threads to run independently of each other without affecting each other's error codes.
When the function returns to you ,its return value indicates that an error has occurred.
To see exactly which error this is,call the GetLastError function:
DWORD GetLastError();
This function simply returns the thread's 32-bit error code set by the last function call.
Now that you have the 32-bit error code number,you need to translate that number into something more useful.
The WinError.h header file contains the list of Microsoft-defined error codes.
I'll reproduce some of it here so that you can see what it looks like:
//MessageId:ERROR_SUCCESS
//
//MessageText;
//
//The operaton complete sucessfully
//
#define ERROR_SUCCESS 0L
(HYP:More details to see,please see my other passage showing the whole of WinError.h.
Oh ,sorry to say that,i failed to paste the text of winerror.h to my blog passage.
so ,now i assign the file with this passage.)
……
……
As you can see,each error has three representations:
a message ID(a macro that you can use in your source code to compare against the return value of GetLastError),
message Text(an English text description of the error),
and a number(Which you should avoid using and instead use the messge ID).
Keep in mind that i selected only a very tiny portion of the WinError.h header file to show you;
the complete file is more than 39000 lines long !
(hyp:amazing about it..in the previous editon of this book ,it says it's about more than 21000 lines long
,becasue it is win98 and win2000.now ,when comes to win nt,and win vista.it changes to so big number.
so ,i have to say that windows is really a large project...more and more powerful in the future and more and more complex in the future)
When a Windows function fails,you should call GetLastError right away because the value is very likely to be overwritten if you call anothr Windows function.
Notice that a Windows function that succeeds might overwrite this value with ERROR_SUCCESS.
(HYP:SO You must know how to use it actually)
Some Windows functions can succeed for several reasons.
For example,attempting to create a named event kernel object can succeed either because you actually create the object or because an event kernel object with the same name already exists.
Your application might need to know the reason for success.
To return this information to you,Microsoft chose to use the last error-code mechanism.
So when certain functions succeed,you can dertermine addtitional information by calling GetLastError.
For functions with this behavior,the Platform SDK documentation clearly states that GetLastError can be used this way.
See the documentation for the CreateEvent function for an example where ERROR_ALREADY_EXISTS is returned when a named event already exists.
(HYP:OK,to see the context of CreateEvent references ,please see my other passage)
While debugging,i find it extremely useful to monitor the thread's last error code.
In Microsoft Visual Studio,Microsoft's debugger supports a useful feature--you can configure the Watch windows to always show you the thread's last error code number and the text description of the error.
This is done by selecting a row in the Watch window and typing $err,hr.
Examine FIGURE 1.1:You'll see that i've called the CreateFile function.
This function returned a HANDLE of INVALID_HANDLE_VALUE(-1),indicating that it failed to open the specified file.
But the Watch window shows us that the last error code(the error code that would be returned by the GetLastError function if i called it)is 0x00000002.
Thanks to the ,hr qualifier ,the Watch window further indicates that error code 2 is "The system cannot find the file specified."
You'll notice that this is the same string mentioned in the WinError.h header file for error code number 2.
-----------------------------------------
Figure1.1:
Using $err,hr in Visual Studio's Watch window to view the current thread's last error code.
-----------------------------------------
Visual Studio also ships with a small utility called Error Lookup.
You can use Error Lookup to convert an error code number into its textual description.
(hyp tips:Tools>Error Lookup)
If i detect an error in an application i've written,
i might want to show the text description to the user.
Windows offers a function that converts an error code into its text description.
This function is called FormatMessage:
(hyp:suddenly,i think of qq and JinshanTpan,when internet can not be connected ,both its logon will fail,and shows one error code
with error text descriptin.so that are really useful skills.Do i need to convert winerror.h into chinese format error description.
may be that would be nice.Not all,but some necessary and important ones.Not directly ,but indirectly)
DWORD FormatMessage(
DWORD dwFlags,
LPCVOID pSource,
DWORD dwMessageId,
DWORD dwLanguageId,
PTSTR pszBuffer,
DWORD nSize,
va_list *Arguments);
FormatMessage is actually quite rich in functionality and is the preferred way of constructing strings that are to be shown to the user.
One reason for this function's usefulness is that it works easily with multiple languages.
This function takes a language identifier as a parameter and returns the appropriate text.
Of course,first you must translate the strings yourself and embed the translated message table resource inside your .exe or
DLL module,but then the function will select the correct one.
The ErrorShow sample application(shown later in this chapter) demonstrates how to call this function to convert a Microsoft-defined error code number into its text description.
Every now and then,someone asks me if Microsoft produces a master list indicating all the possible error codes that can be returned from every Windows function.
The answer ,unfortunately,is no.
What's more,Microsoft will never produce this list--it's just too difficult to construct and maintain as new versions of the system are created.
The problem with assembling such a list is that you can call one Windows functin,
but internally that funtion might call another function,and so on.
Any of these functions could fail,
for lots of different reasons.
Sometimes when a function fails,the higher-level function can recover and still perform what you want it to do.
To create this master list,Microsoft would have to trace the path of every function and build the list of all possible error codes.
This is difficult.
And as new versions of the system were created,these function-execution paths would change.
(YEAH,the author says the truth,maybe just because he is one man of the coders for windows developing.He knows much about it.
he is familiar enough with it,so experience make hime never think about this question.it just cannot be approachable( [ə'prəutʃəbl]) absolutely.)
############################################################3
Defining Your Own Error Codes
OK,i've shown you how Windows functions indicate errors to their callers.
Microsoft also makes this mechanism available to you for use in your own function.
Let's say you're writing a function that you expect others to call.
Your function might fail for one reason or another and you need to indicate that failure back to your caller.
[
TAG001:
appropriate [ə'prəuprieit]
a. 适当的,合适的
v. 拨出,挪用,盗用
Five thousand dollars has been appropriated for the new school buildings.
已拨款五千元为建设新校舍之用
He appropriated public funds for his own private use.
他挪用公款
]
To indicate failure,simply set the thread's last error code and then have your function return FALSE,
INVALID_HANDLE_VALUE,NULL,or whatever is appropriate.
To set the thread's last error code,you simply call
VOID SetLastErro(DWORD dwErrCode);
passing into the function whatever 32-bit number you think is appropriate.
I try to use codes that already exists in WinError.h--as long as the code maps well to the error i'm trying to report.
If you don't think that any of the codes in WinError.h actually reflect the error ,you can create your own code.
The error code is a 32-bit number that is divided into the fields shown in Table 1.2.
---------------------------------------------------
Table1.2:Error Code Fields
Bits: 31-30 29 28 27-16 15-0
Contents Severity Microsoft/customer Reserved Facility code Exception Code
Meaning 0=Success 0=Microsoft-defined code Must be 0 The first 256 values are Microsoft/customer-defined code
1=Information 1=customer-defined code reserved by Microsoft
2=Warning
3=Error
------------------------------------------------------------
These fields are discussed in detail in Chapter 24,
"Exception Handlers and Software Exceptions."
For now,the only important field you need to be aware of is in bit 29.
Microsoft promises that all error codes it produces will have a 0 in this bit.
If you create your own error codes,you must put a 1 in this bit.
This way,you're guaranteed that your error code will never conflict with a Microsoft-defined error code that currently exists or is created in the future.
Note that the Facility field is large enough to hold 4096 possible values.
Of these,the first 256 values are reserved for Microsoft;
the remaining values can be defined by your own application.
(
hyp:
29-bit is a real utility...When designing it,The Microsoft engineers concern about future.
It distinct Windows and customer level error code perfectly.
So,if you design something ,think about future as much as you can...
that do much good to you...
)
(
hyp:(word design can both be a noun and a verb)
WOW,vey beautiful design ,ok,now ,just let me open the WinError.h please,and i get this which tells the truth matching words up.
//
// Note: There is a slightly modified layout for HRESULT values below,
// after the heading "COM Error Codes".
//
// Values are 32 bit values laid out as follows:
//
// 3 3 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1
// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0
// +---+-+-+-----------------------+-------------------------------+
// |Sev|C|R| Facility | Code |
// +---+-+-+-----------------------+-------------------------------+
//
// where
//
// Sev - is the severity code
//
// 00 - Success
// 01 - Informational
// 10 - Warning
// 11 - Error
//
// C - is the Customer code flag
//
// R - is a reserved bit
//
// Facility - is the facility code
//
// Code - is the facility's status code
//
//
// Define the facility codes
//
)
chapter1:Error Handling
overview
Before we jump in and start examining the many features that Microsoft Windows has to offer,
you should understand how the various Windows functions perform their error handling.
When you call a Windows function,it validates the parameters that you pass to it and then attempts to perform its duty.
If you pass an invalid parameter or if for some other reason the action cannot be performed,
the function's return value indicates that the function failed in some way.
Table 1.1 shows the return value data types that most Windows functions use.
-------------------------------------------------
Table1.1:Common Return Types for Windows Functions.
Data Type Value to Indicate Failure
VOID This function can not possibly fail.Very few Windows functions have a return type of VOID.
BOOL If the function fails,the return value is 0;otherwise,the return value is non-zero.
Avoid testing the return value to see if it is TRUE:it is alway best to test this return value to see
if it is different from FALSE.(HYP:And the reason ,and why that goes)
Handle If the function fails,the return value is usually NULL;otherwise,the HANDLE identifies an object that
you can manipulate.Be careful with this one because some functions return a handle value of INVALID_HANDLE_VALUE,
which is defined as -1.The Platform SDK documentation for the function will clearly state whether the
function return NULL or INVALID_HANDLE_VALUE to indicate failure.
PVOID If the function fails,the return value is NULL;otherwise,PVOID identifies the memory address of a data block.
LONG/DWORD This is a tough one.Functions that return counts usually return a LONG or DWORD.
If for some reason the function can't count the thing you want counted,
the function usually returns 0 or -1(depending on the function).
If you are calling a function that returns a LONG/DWORD,
please read the Platform SDK documentation carefully to ensure that you are properly checking for potential errors.
----------------------------------------------------
When a Windows function returns with an error code,
it's frequently useful to understand why the function failed.
Microsoft has compiled a list of all possible error codes and has assigned each error code a 32-bit number.
Internally,when a Windows function detects an error,
it uses a mechanism called thread-local storage to associate the appropriate error-code number with the calling thread.
(Thread-local storage is discussed in Chapter 21,"Thread-Local Storage")
This mechanism allows threads to run independently of each other without affecting each other's error codes.
When the function returns to you ,its return value indicates that an error has occurred.
To see exactly which error this is,call the GetLastError function:
DWORD GetLastError();
This function simply returns the thread's 32-bit error code set by the last function call.
Now that you have the 32-bit error code number,you need to translate that number into something more useful.
The WinError.h header file contains the list of Microsoft-defined error codes.
I'll reproduce some of it here so that you can see what it looks like:
//MessageId:ERROR_SUCCESS
//
//MessageText;
//
//The operaton complete sucessfully
//
#define ERROR_SUCCESS 0L
(HYP:More details to see,please see my other passage showing the whole of WinError.h.
Oh ,sorry to say that,i failed to paste the text of winerror.h to my blog passage.
so ,now i assign the file with this passage.)
……
……
As you can see,each error has three representations:
a message ID(a macro that you can use in your source code to compare against the return value of GetLastError),
message Text(an English text description of the error),
and a number(Which you should avoid using and instead use the messge ID).
Keep in mind that i selected only a very tiny portion of the WinError.h header file to show you;
the complete file is more than 39000 lines long !
(hyp:amazing about it..in the previous editon of this book ,it says it's about more than 21000 lines long
,becasue it is win98 and win2000.now ,when comes to win nt,and win vista.it changes to so big number.
so ,i have to say that windows is really a large project...more and more powerful in the future and more and more complex in the future)
When a Windows function fails,you should call GetLastError right away because the value is very likely to be overwritten if you call anothr Windows function.
Notice that a Windows function that succeeds might overwrite this value with ERROR_SUCCESS.
(HYP:SO You must know how to use it actually)
Some Windows functions can succeed for several reasons.
For example,attempting to create a named event kernel object can succeed either because you actually create the object or because an event kernel object with the same name already exists.
Your application might need to know the reason for success.
To return this information to you,Microsoft chose to use the last error-code mechanism.
So when certain functions succeed,you can dertermine addtitional information by calling GetLastError.
For functions with this behavior,the Platform SDK documentation clearly states that GetLastError can be used this way.
See the documentation for the CreateEvent function for an example where ERROR_ALREADY_EXISTS is returned when a named event already exists.
(HYP:OK,to see the context of CreateEvent references ,please see my other passage)
While debugging,i find it extremely useful to monitor the thread's last error code.
In Microsoft Visual Studio,Microsoft's debugger supports a useful feature--you can configure the Watch windows to always show you the thread's last error code number and the text description of the error.
This is done by selecting a row in the Watch window and typing $err,hr.
Examine FIGURE 1.1:You'll see that i've called the CreateFile function.
This function returned a HANDLE of INVALID_HANDLE_VALUE(-1),indicating that it failed to open the specified file.
But the Watch window shows us that the last error code(the error code that would be returned by the GetLastError function if i called it)is 0x00000002.
Thanks to the ,hr qualifier ,the Watch window further indicates that error code 2 is "The system cannot find the file specified."
You'll notice that this is the same string mentioned in the WinError.h header file for error code number 2.
-----------------------------------------
Figure1.1:
Using $err,hr in Visual Studio's Watch window to view the current thread's last error code.
-----------------------------------------
Visual Studio also ships with a small utility called Error Lookup.
You can use Error Lookup to convert an error code number into its textual description.
(hyp tips:Tools>Error Lookup)
If i detect an error in an application i've written,
i might want to show the text description to the user.
Windows offers a function that converts an error code into its text description.
This function is called FormatMessage:
(hyp:suddenly,i think of qq and JinshanTpan,when internet can not be connected ,both its logon will fail,and shows one error code
with error text descriptin.so that are really useful skills.Do i need to convert winerror.h into chinese format error description.
may be that would be nice.Not all,but some necessary and important ones.Not directly ,but indirectly)
DWORD FormatMessage(
DWORD dwFlags,
LPCVOID pSource,
DWORD dwMessageId,
DWORD dwLanguageId,
PTSTR pszBuffer,
DWORD nSize,
va_list *Arguments);
FormatMessage is actually quite rich in functionality and is the preferred way of constructing strings that are to be shown to the user.
One reason for this function's usefulness is that it works easily with multiple languages.
This function takes a language identifier as a parameter and returns the appropriate text.
Of course,first you must translate the strings yourself and embed the translated message table resource inside your .exe or
DLL module,but then the function will select the correct one.
The ErrorShow sample application(shown later in this chapter) demonstrates how to call this function to convert a Microsoft-defined error code number into its text description.
Every now and then,someone asks me if Microsoft produces a master list indicating all the possible error codes that can be returned from every Windows function.
The answer ,unfortunately,is no.
What's more,Microsoft will never produce this list--it's just too difficult to construct and maintain as new versions of the system are created.
The problem with assembling such a list is that you can call one Windows functin,
but internally that funtion might call another function,and so on.
Any of these functions could fail,
for lots of different reasons.
Sometimes when a function fails,the higher-level function can recover and still perform what you want it to do.
To create this master list,Microsoft would have to trace the path of every function and build the list of all possible error codes.
This is difficult.
And as new versions of the system were created,these function-execution paths would change.
(YEAH,the author says the truth,maybe just because he is one man of the coders for windows developing.He knows much about it.
he is familiar enough with it,so experience make hime never think about this question.it just cannot be approachable( [ə'prəutʃəbl]) absolutely.)
############################################################3
Defining Your Own Error Codes
OK,i've shown you how Windows functions indicate errors to their callers.
Microsoft also makes this mechanism available to you for use in your own function.
Let's say you're writing a function that you expect others to call.
Your function might fail for one reason or another and you need to indicate that failure back to your caller.
[
TAG001:
appropriate [ə'prəuprieit]
a. 适当的,合适的
v. 拨出,挪用,盗用
Five thousand dollars has been appropriated for the new school buildings.
已拨款五千元为建设新校舍之用
He appropriated public funds for his own private use.
他挪用公款
]
To indicate failure,simply set the thread's last error code and then have your function return FALSE,
INVALID_HANDLE_VALUE,NULL,or whatever is appropriate.
To set the thread's last error code,you simply call
VOID SetLastErro(DWORD dwErrCode);
passing into the function whatever 32-bit number you think is appropriate.
I try to use codes that already exists in WinError.h--as long as the code maps well to the error i'm trying to report.
If you don't think that any of the codes in WinError.h actually reflect the error ,you can create your own code.
The error code is a 32-bit number that is divided into the fields shown in Table 1.2.
---------------------------------------------------
Table1.2:Error Code Fields
Bits: 31-30 29 28 27-16 15-0
Contents Severity Microsoft/customer Reserved Facility code Exception Code
Meaning 0=Success 0=Microsoft-defined code Must be 0 The first 256 values are Microsoft/customer-defined code
1=Information 1=customer-defined code reserved by Microsoft
2=Warning
3=Error
------------------------------------------------------------
These fields are discussed in detail in Chapter 24,
"Exception Handlers and Software Exceptions."
For now,the only important field you need to be aware of is in bit 29.
Microsoft promises that all error codes it produces will have a 0 in this bit.
If you create your own error codes,you must put a 1 in this bit.
This way,you're guaranteed that your error code will never conflict with a Microsoft-defined error code that currently exists or is created in the future.
Note that the Facility field is large enough to hold 4096 possible values.
Of these,the first 256 values are reserved for Microsoft;
the remaining values can be defined by your own application.
(
hyp:
29-bit is a real utility...When designing it,The Microsoft engineers concern about future.
It distinct Windows and customer level error code perfectly.
So,if you design something ,think about future as much as you can...
that do much good to you...
)
(
hyp:(word design can both be a noun and a verb)
WOW,vey beautiful design ,ok,now ,just let me open the WinError.h please,and i get this which tells the truth matching words up.
//
// Note: There is a slightly modified layout for HRESULT values below,
// after the heading "COM Error Codes".
//
// Values are 32 bit values laid out as follows:
//
// 3 3 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1
// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0
// +---+-+-+-----------------------+-------------------------------+
// |Sev|C|R| Facility | Code |
// +---+-+-+-----------------------+-------------------------------+
//
// where
//
// Sev - is the severity code
//
// 00 - Success
// 01 - Informational
// 10 - Warning
// 11 - Error
//
// C - is the Customer code flag
//
// R - is a reserved bit
//
// Facility - is the facility code
//
// Code - is the facility's status code
//
//
// Define the facility codes
//
)
- WinError.rar (154.5 KB)
- 下载次数: 8
发表评论
-
MSDN:Drawing a Shaded Triangle
2011-10-27 08:46 0Originally Adapted From: http:/ ... -
MSDN:Drawing a Shaded Rectangle
2011-10-27 08:45 0Originally Adapted From: http:/ ... -
MSDN:GradientFill
2011-10-27 08:17 0Originally Adapted From: http:/ ... -
Windows Via C/Cpp:Appendix A
2011-10-25 13:33 1348It will never be too early to t ... -
Windows Via C/Cpp:Overview2
2011-10-24 13:12 1195Love:Language never scale,but a ... -
HYP_2010_10_24
2011-10-24 09:20 0Languages's don't Scale, Archit ... -
Windows Via C/Cpp:Overview1
2011-10-23 21:49 583Life is not what you show other ...
相关推荐
在《Windows Via C/C++: Appendix A》这个主题中,我们主要探讨的是使用C或C++编程语言在Windows操作系统上的开发技术。这篇博客文章可能是对《Windows Via C/C++》一书的补充材料,其中“Appendix A”可能涵盖了与...
Windows核心编程第五版,中文版(1-6章为清晰版,第7章以后为扫描版)
《Windows Via C/C++》是一本专为C/C++开发者深入理解Windows操作系统内核而编写的经典教程。这本书详尽地介绍了如何利用C/C++语言进行Windows系统的底层编程,涵盖了从系统调用到驱动开发等多个层面的技术知识。...
《Windows Via C/C++》是编程领域中一本深入探讨如何使用C/C++语言开发Windows应用程序的经典著作。本书针对Microsoft Windows操作系统,提供了详细的编程指南和技术解析,旨在帮助开发者掌握Windows API的核心概念...
《Windows Via C/C++, Fifth Edition》是一本由Jeffrey Richter和Christophe Nasarre编写的书籍,专注于通过C和C++语言探索Windows操作系统的核心功能和技术。本书详细讲解了如何在Windows平台上使用C/C++进行编程,...
《Windows via C/C++》是Windows编程领域的一本经典著作,尤其在第五版中,它深入探讨了如何利用C/C++语言进行Windows平台的应用程序开发。这本书覆盖了大量的知识点,包括但不限于: 1. **Windows API**: Windows ...
Windows Via-C/C++ 核心编程 中文版Chm
《Windows via C/C++源代码解析》是一本深入探讨如何使用C/C++语言在Windows操作系统平台上进行系统级编程的书籍。随书提供的源代码涵盖了多个关键主题,包括系统信息获取、进程调度、内存管理、多进程间通信以及...
Windows核心编程第五版,中文版(1-6章为清晰版,第7章以后为扫描版)
原windows核心编程,现在改为Windows via C/C++ ,2007年12月12日出版
Windows via C/C++, Fifth Edition Jeffrey Richter (Wintellect) Christophe Nasarre PUBLISHED BY Microsoft Press A Division of Microsoft Corporation One Microsoft Way Redmond, Washington 98052-6399 ...
### Windows Via C/C++ - Jeffrey Richter - Christophe Nasarre #### 书籍概述 《Windows Via C/C++》第五版是由Jeffrey Richter和Christophe Nasarre共同编著的一本经典著作,该书主要介绍了如何使用C/C++语言...
《Windows Via C/C++》是一本深入探讨Windows操作系统编程的经典著作,主要面向使用C++语言进行系统级开发的程序员。本书通过源代码的形式,详细解释了如何利用Microsoft的Windows API来构建底层应用程序、驱动程序...
// via the digital "mifare in" and "mifare out" interface. Therefore // one reader acts as a master and sends commands via "mifare out". // The other reader ic acts as a slave and receives data via //...
Windows via C C++(5th) 英文无水印pdf 第5版 pdf所有页面使用FoxitReader和PDF-XChangeViewer测试都可以打开 本资源转载自网络,如有侵权,请联系上传者或csdn删除 本资源转载自网络,如有侵权,请联系上传者...