UNICODE:它是用两个字节表
示一个字符的方法。比如字符'A'在ASCII下面是一个字符,可'A'在UNICODE下面是两个字符,高字符用0填充,而且汉字'程'在ASCII下
面是两个字节,而在UNICODE下仍旧是两个字节
。UNICODE的用处就是定长表示世界文字,据统计,用两个字节可以编码现存的所有文字而没
有二义。
MBCS,
它是多字节字符集,它是不定长表示世界文字的编码。MBCS表示英文字母时就和ASCII一样(这也是我们容易把MBCS和ASCII搞混的原因),但表
示其他文字时就需要用多字节。
WINDOWS
下面的程序设计可以支持MBCS和UNICODE两种编码的字符串,具体用那种就看你定义了MBCS宏还是UNICODE宏。MBCS宏对应的字符串指针
是char*也就是LPSTR,UNICODE对应的指针是unsigned
short*也就是LPWSTR,为了写程序方便微软定义了类型LPTSTR,在MBCS下他就是char*,
在UNICODE下它是unsigned char*,这样你就可以重定义一个宏进行不同字符集的转换了。
LPTSTR、LPCSTR、LPCTSTR、LPSTR的意义:
LPSTR:32bit指针 指向一个字符串,每个字符占1字节
LPC
STR:32-
bit指针 指向一个常
字符串,每个字符占1字节
LPCT
STR:32-bit指针
指向一个常字符串,每字符可能占1字节或2字节,取决于Unicode
是
否定义
LPTSTR:32-bit指针 每字符可能占1字节或2字节,取决于Unicode是否定义
Windows
使用两种字符集ANSI和UNICODE,前者就是通常使用的单字节方式,但这种方式处理象中文这样的双字节字符不方便,容易出现半个汉字的情况。而后者
是双字节方式,方便处理双字节字符。
WindowsNT
的所有与字符有关的函数都提供两种方式的版本,而Windows9x只支持ANSI方式。_T一般同字常数相关,如_T("Hello"。如果你编译一个
程序为ANSI方式,_T实际不起任何作用。而如果编译一个程序为UNICODE方式,则编译器会把"Hello"字符串以UNICODE方式保存。_T
和_L的区别在于,_L不管你是以什么方式编译,一律UNICODE方式保存.
Windows
核心编程的第一章。
L是表示字符串
资源为Unicode的。
比如
wchar_t
Str[] = L"Hello World!";
这个就是双子节存储字符了。
_T是一个适配
的宏~
当
#ifdef
_UNICODE的时候
_T就是L
没有#ifdef _UNICODE的时候
_T就是ANSI的。
比如
LPTSTR
lpStr = new TCHAR[32];
TCHAR* szBuf = _T("Hello");
以上两句使得无论是在
UNICODE编译条件下都是正确编译的。
而且MS推荐你
使用相匹配的字符串函数。
比如处理LPTSTR或者LPCTSTR 的时候,不要用strlen ,而是要用_tcslen
否则在
UNICODE的编译条件下,strlen不能处理 wchar_t*的字符串。
T是非常有意思
的一个符号(TCHAR、LPCTSTR、LPTSTR、_T()、_TEXT()...),它表示使用一种中间类型,既不明确表示使用
MBCS,也不明确表示使用 UNICODE。那到底使用哪种字符集?编译的时候才决定
在vc++中有着各种字符串的表示法,如您所说。
首先char*
是指向ANSI字符数组的指针,其中每个字符占据8位(有效数据是除掉最高位的其他7位),这里保持了与传统的C,C++的兼容。
LP的含义是长指针(long pointer)。
LPSTR是一个指向以‘\0’结尾的ANSI字符数组的指针,与char*可以互换使用,在win32中较多地使用
LPSTR。而LPCSTR中增加的‘C’的含义是“CONSTANT”(常量),表明这种数据类型的实例不能被使用它的API函数改变,除此之外,它与
LPSTR是等同的。
为了满足程序代码国际化的需要,业界推出了Unicode标准,它提供了一种简单和一致的表达字符串的方法,所有字符中的字节都是16位的值,其数量也可
以满足差不多世界上所有书面语言字符的编码需求,开发程序时使用Unicode(类型为wchar_t)是一种被鼓励的做法。
LPWSTR与LPCWSTR由此产生,它们的含义类似于LPSTR与LPCSTR,只是字符数据是16位的wchar_t而不是
char。
然后为了实现两种编码的通用,提出了TCHAR的定义:
如果定义_UNICODE,声明如下: typedef wchar_t TCHAR;
如果没有定义_UNICODE,则声明如下: typedef char TCHAR;
LPTSTR和LPCTSTR中的含义就是每个字符是这样的TCHAR。
CString类中的字符就是被声明为TCHAR类型的,它提供了一个封装好的类供用户方便地使用。
如果您还需要进一步的信息,请参看http://msdn.microsoft.com/library/default.asp?url=/library/en-us/vclib/html/_crt_data_type_mappings.asp
等
其他有关信息。
LPTSTR、LPCSTR、LPCTSTR、LPSTR之间的转换:
如何理解LPCTSTR类型?
2007-11-10 21:43
L表示long指针
这是为了兼容Windows 3.1等16位操作系统遗留下来的,在win32中以及其他的32为操作系统中,
long指针和near指针及far修饰符都是为了兼容的作用。没有实际意义。
P表示这是一个指针
C表示是一个常量
T表示在Win32环境中, 有一个_T宏
这个宏用来表示你的字符是否使用UNICODE,
如果你的程序定义了UNICODE或者其他相关的宏,那么这个字符或者字符串将被作为UNICODE字符串,否则就是标准的ANSI字符串。
STR表示这个变量是一个字符串
所以LPCTSTR就表示一个指向常固定地址的可以根据一些宏定义改变语义的字符串。
同
样, LPCSTR就只能是一个ANSI字符串,在程序中我们大部分时间要使用带T的类型定义。
LPCTSTR == const TCHAR *
CString 和 LPCTSTR 可以说通用。 原因在于CString定义的自动类型转换,没什么奇特的,最简单的C++操作符重载而已。
常
量字符串ansi和unicode的区分是由宏_T来决定的。但是用_T("abcd")时,
字符串"abcd"就会根据编译时的是否定一_UNICODE来决定是char* 还是 w_char*。 同样,TCHAR 也是相同目的字符宏。
看看定义就明白了。简单起见,下面只介绍 ansi 的情况,unicode 可以类推。
ansi情况下,LPCTSTR 就是
const char*, 是常量字符串(不能修改的)。
而LPTSTR 就是 char*, 即普通字符串(非常量,可修改的)。
这
两种都是基本类型, 而CString 是 C++类, 兼容这两种基本类型是最起码的任务了。
由于const char*
最简单(常量,不涉及内存变更,操作迅速), CString 直接定义了一个类型转换函数
operator LPCTSTR()
{......}, 直接返回他所维护的字符串。
当你需要一个const char* 而传入了CString时,
C++编译器自动调用 CString重载的操作符 LPCTSTR()来进行隐式的类型转换。
当需要CString , 而传入了
const char* 时(其实 char* 也可以),C++编译器则自动调用CString的构造函数来构造临时的 CString对象。
因此CString 和 LPCTSTR 基本可以通用。
但
是 LPTSTR又不同了,他是 char*,
意味着你随时可能修改里面的数据,这就需要内存管理了(如字符串变长,原来的存贮空间就不够了,则需要重新调整分配内存)。
所以 不能随便的将
const char* 强制转换成 char* 使用。
楼主举的例子
LPSTR lpstr =
(LPSTR)(LPCTSTR)string;
就是这种不安全的使用方法。
这个地方使用的是强制类型转换,你都强制转换
了,C++编译器当然不会拒绝你,但同时他也认为你确实知道自己要做的是什么。因此是不会给出警告的。
强制的任意类型转换是C(++)的一项强
大之处,但也是一大弊端。这一问题在 vc6 以后的版本(仅针对vc而言)中得到逐步的改进(你需要更明确的类型转换声明)。
其实在
很多地方都可以看到类似
LPSTR lpstr =
(LPSTR)(LPCTSTR)string;
地用法,这种情况一般是函数的约束定义不够完善的原因
,
比如一个函数接受一个字符串参数的输入,里面对该字符串又没有任何的修改,那么该参数就应该定义成 const char*,
但是很多初学者弄不清const地用法,或者是懒, 总之就是随意写成了 char* 。 这样子传入CString时就需要强制的转换一下。
这种做法是不安全的,也是不被建议的用法,你必须完全明白、确认该字符串没有被修改
。
CString 转换到 LPTSTR
(char*), 预定的做法是调用CString的GetBuffer函数,使用完毕之后一般都要再调用ReleaseBuffer函数来确认修改 (
某
些情况下也有不调用ReleaseBuffer的,同样你需要非常明确为什么这么做时才能这样子处理,一般应用环境可以不考虑这种情况)。
同
时需要注意的是, 在GetBuffer 和
ReleaseBuffer之间,CString分配了内存交由你来处理,因此不能再调用其他的CString函数。
CString 转LPCTSTR:
CString cStr;
const char
*lpctStr=(LPCTSTR)cStr;
LPCTSTR转CString:
LPCTSTR lpctStr;
CString
cStr=lpctStr;
分享到:
相关推荐
LPSTR、LPCSTR、LPTSTR和LPCTSTR的意义及区别; ANSI和UNICODE的使用; Unicode宽字符转化; VC中的字符串类型和处理函数;
"LPTSTR.LPCSTR.LPCTSTR.LPSTR的来源及意义" LPTSTR、LPCSTR、LPCTSTR 和 LPSTR 是 Windows 编程中四个基本的字符串类型,它们都是指针类型,但它们之间存在着一定的区别和联系。 LPTSTR 是一个通用的字符串指针...
### LPTSTR、LPCSTR、LPCTSTR、LPSTR的来源及意义详解 #### 一、背景介绍 在计算机编程领域,尤其是Windows应用程序开发中,字符串处理是一项基本且重要的任务。Windows提供了多种字符编码方式来支持不同语言和...
标题和描述中提到的关键概念包括LPTSTR、LPCSTR、LPCTSTR和LPSTR,这些都是在Windows API中常见的字符串类型指针。下面将详细讲解这些类型以及它们之间的相互转化。 1. **宽字符与多字符集**: - **宽字符(Wide ...
myChars = (LPTSTR)(LPCTSTR)strHello; ``` 4. LPBYTE与Cstring之间的转化: LPBYTE是`unsigned char*`类型。可以将Cstring转化为LPCSTR或LPCTSTR后再转换为LPBYTE: ```cpp LPBYTE lpByte = (LPBYTE)strHello...
当_UNICODE未定义时,TCHAR为char,LPCTSTR和LPTSTR分别对应于LPSTR和LPCSTR;当_UNICODE定义时,TCHAR为wchar_t,LPCTSTR和LPTSTR则对应于LPWSTR和LPCWSTR。TCHAR宏如_T()和_TEXT()用于创建与当前编码匹配的字符串...
LPCSTR和LPSTR分别代表常量和可变的ANSI字符串指针。 4. TCHAR家族:TCHAR、LPTSTR和LPCTSTR等类型是微软为了支持多字节字符集(MBCS)和Unicode的兼容性而设计的。在Unicode编译模式下,TCHAR是宽字符(wchar_t),在...
如果定义了UNICODE,LPTSTR和LPCTSTR将分别映射为LPWSTR和LPCWSTR,否则它们映射为LPSTR和LPCSTR。 Visual C++.NET引入了CStringT类,作为ATL和MFC共享的通用字符串类。它有三个特定的派生类:CString、CStringA和...
8. LPCSTR、LPSTR、LPCTSTR和LPTSTR:这些都是字符串指针类型。LPCSTR和LPCTSTR指向常量字符串,LPSTR和LPTSTR则可以指向可修改的字符串。在Unicode环境下,LPCTSTR和LPTSTR会自动转换为宽字符版本(WCHAR*),以...
#### 四、LPSTR、LPCSTR、LPWSTR、LPCWSTR、LPTSTR、LPCTSTR详解 ##### 1. MBCS与UNICODE - **MBCS** (Multi-byte Character Set): 使用多字节字符集,即使用不同长度的字节序列来表示不同的字符。当未定义UNICODE...
Windows编程中常见的数据类型包括LONG(32位有符号整数)、DWORD(32位无符号整数)、UINT(同样为32位无符号整数)、BOOL(布尔值,表示真或假)、以及各种指向字符串的指针...,如LPTSTR、LPCTSTR、LPSTR和LPCSTR...
##### LPSTR 和 LPCSTR - **LPSTR**:是一个指向以`\0`结尾的ANSI字符数组的指针,与`char*`可以互换使用。 - **LPCSTR**:增加了`C` 的含义,表示该指针指向的字符串是只读的,不能被修改。这通常用于函数参数中,...
`LPCTSTR`是一个常量的TCHAR指针,`LPSTR`和`LPCSTR`分别代表指向ANSI字符数组的长指针和常量长指针。在Win32环境下,`LP`表示长指针,与32位指针相匹配。`C`则表示常量,意味着该指针所指向的数据不可修改。`STR`则...
+ LPCTSTR/LPTSTR/PCTSTR:指向一 8 位或 16 位字符串类型指针。 + LPVOID:指向一个未指定类型的 32 位指针。 + LPDWORD:指向一个 DWORD 型指针。 * 句柄型: + HANDLE:Object 句柄。 + HBITMAP:bitmap ...
6. **从char* / LPSTR / LPCSTR到BSTR**: 对于ASCII字符串(如`char*`),需要先将其转换为Unicode字符串(`WCHAR*`)。可以使用`MultiByteToWideChar`函数进行转换,然后创建BSTR。例如: ```cpp char str[MAX_...
11. LPTSTR:与LPCTSTR类似,但指向的字符串可以修改,同样具有平台无关性。 12. LPVOID:32位指针,用于指向任何类型的数据,灵活性很高,但需要类型转换。 13. LPRESULT:32位数值,用作窗口函数或回调函数的...
//郁金香灬老师 ...LPCTSTR:32-bit指针指向一个常字符串,每字符可能占1字节或2字节,取决于Unicode是否定义 LPTSTR:32-bit指针每字符可能占1字节或2字节,取决于Unicode是否定义 ---------------------
在非Unicode环境中,`LPCTSTR`和`LPCSTR`分别等同于`const char*`和`LPSTR`,即指向ANSI字符串的常量和非常量指针;在Unicode环境中,它们分别等同于`const wchar_t*`和`LPWSTR`,指向宽字符字符串的常量和非常量...