Com组件的内存分配和释放,CredentialProvider SHStrDup 字符串拷贝问题

一、简介

熟悉CredentialProvider的同学应该知道,他为一个Com组件,于是,在这里的内存分配(字符串拷贝)的一系列操作就要按照con的标准来。

二、Com组件的内存分配和释放

COM提供的任务内存分配器,通过IMalloc接口调用。此接口由CoGetMalloc返回。分配内存可以使用IMalloc::Alloc,释放可由IMalloc::Free完成。

为了简化COM库封装了3个API函数来用于内存的分配和释放,如下:

void *CoTaskMemAlloc(ULONG cb);

void CoTaskMemFree(void *pv);

void CoTaskMemRealloc(void *pv, ULONGcb);

三个函数的含义与C语言的malloc,relloc和free函数类似,分别用于内存分配、重新分配和释放内存的操作。

例如:

WORD length = MAX_LENGTH;

HRESULT hr;

psz = CoTaskMemAlloc( length );

if( psz  == NULL)

{

//return failure

}

..........

pszText = psz;

注意:在不使用的时候,一定要调用CoTaskMemFree函数释放分配的内存。

三 、应用

再介绍1个API函数:

SHStrDupW( LPCTSTR pszSource,
LPTSTR *ppwsz);

含义:Makes a copy of a string in newly allocated memory 具体见:http://technet.microsoft.com/zh-cn/bb759924(v=vs.71).aspx

其中参数 ppwsz 的注解为

A pointer to an allocated Unicode string that contains the result. SHStrDup allocates
memory for this string with CoTaskMemAlloc.
You should free the string with CoTaskMemFree when
it is no longer needed.

意思就是说:SHStrDup 返回一个拷贝后的Unicode
字符串指针,函数内部使用CoTaskMemAlloc分配内存,当我们不使用这个字符串以后应该释放掉。

例如:

//
Our credential doesn‘t have any settable strings.

HRESULT CUSBKeyCredential::SetStringValue(

__in DWORD dwFieldID,

__in PCWSTR pwz

)

{

HRESULT hr;

// Validate parameters.

if (dwFieldID < ARRAYSIZE(_rgCredProvFieldDescriptors) &&

(CPFT_EDIT_TEXT == _rgCredProvFieldDescriptors[dwFieldID].cpft ||

CPFT_PASSWORD_TEXT == _rgCredProvFieldDescriptors[dwFieldID].cpft))

{

PWSTR* ppwszStored = &_rgFieldStrings[dwFieldID];

CoTaskMemFree(*ppwszStored);

hr = SHStrDupW(pwz, ppwszStored);

}

else

{

hr = E_INVALIDARG;

}

return hr;

}

时间: 2024-09-30 07:40:25

Com组件的内存分配和释放,CredentialProvider SHStrDup 字符串拷贝问题的相关文章

内存管理概述、内存分配与释放、地址映射机制(mm_struct, vm_area_struct)、malloc/free 的实现

http://blog.csdn.net/pi9nc/article/details/23334659 注:本分类下文章大多整理自<深入分析linux内核源代码>一书,另有参考其他一些资料如<linux内核完全剖析>.<linux c 编程一站式学习>等,只是为了更好地理清系统编程和网络编程中的一些概念性问题,并没有深入地阅读分析源码,我也是草草翻过这本书,请有兴趣的朋友自己参考相关资料.此书出版较早,分析的版本为2.4.16,故出现的一些概念可能跟最新版本内核不同.

c++跨动态库DLL的内存分配与释放问题

先说结论: 1.如果两个DLL(或者EXE调用DLL)的CRT链接均为MD,则可以跨动态库分配和释放,如果一个是MT,另外一个是MD则会有问题. 2.利用虚函数的动态绑定技术,动态绑定分配释放内存的new和delete等,可以解决这个问题,例如shared_ptr.但如果shared_ptr包装是vector等类型,在调用和被调用中都涉及到vector的修改的话,仍然会有问题,因为两个地方都会有释放和分配. 似乎最好的办法还是用原始指针加数组长度的方式传递. 参见下面两个文章. 1.跨DLL的内

JAVA模拟内存分配与释放——首次适应算法

前言 首次适应算法(FF,first fit)是内存基于顺序搜索的动态分配分区算法,在分配内存时,从链首开始顺序查找,直至找到一个大小能满足要求的空闲分区为止,然后在按照作业的大小从该分区中划出一块内存空间,分配给请求者,余下的空闲分区仍留在空闲链中.若从链首直至链尾都不能找到一个能满足要求的分区,则表明系统中已没有足够大的内存分配给该进程,内存分配失败,返回. 该算法倾向于优先利用内存中低地址部分的空闲分区,从而保留了高地址部分不断被划分.这为以后到达的大作业分配大的的内存空间创造了条件.其缺

c++动态内存分配与释放

一般变量的分配与释放 #include<iostream> using namespace std; int main() {     int *p = new int(4);     *p = 10;     cout << *p << endl;     delete p;     return 0; } 数组变量的分配与释放 #include #include<iostream> using namespace std; int main() {   

19 内存分配和释放的函数

1. malloc,calloc,realloc,free属于C函数库,而new/delete则是C++函数库: 2. 多个-alloc的比较: alloc:唯一在栈上申请内存的,无需释放: malloc:在堆上申请内存,最常用: calloc:malloc+初始化为0: realloc:将原本申请的内存区域扩容,参数size大小即为扩容后大小,因此此函数要求size大小必须大于ptr内存大小. 函数原型:void *calloc(size_t n, size_t size): 功 能: 在内存

内存分配和释放的函数

多个-alloc的比较: alloc:唯一在栈上申请内存的,无需释放: malloc:在堆上申请内存,最常用: calloc:malloc+初始化为0: realloc:将原本申请的内存区域扩容,参数size大小即为扩容后大小,因此此函数要求size大小必须大于ptr内存大小 malloc和calloc的区别是1块与n块的区别和初始化 realloc调用形式为(类型*)realloc(*ptr,size):将ptr内存大小增大到size.

netty源码解解析(4.0)-23 ByteBuf内存管理:分配和释放

ByteBuf内存分配和释放由具体实现负责,抽象类型只定义的内存分配和释放的时机. 内存分配分两个阶段: 第一阶段,初始化时分配内存.第二阶段: 内存不够用时分配新的内存.ByteBuf抽象层没有定义第一阶段的行为,但定义了第二阶段的方法: public abstract ByteBuf capacity(int newCapacity) 这个方法负责分配一个长度为newCapacity的新内存. 内存释放的抽象实现在AbstractReferenceCountedByteBuf中实现,这个类实

SQLite剖析之动态内存分配

SQLite通过动态内存分配来获取各种对象(例如数据库连接和SQL预处理语句)所需内存.建立数据库文件的内存Cache.以及保存查询结果.我们做了很多努力来让SQLite的动态内存分配子系统可靠.可预测.健壮并且高效.本文概述SQLite的动态内存分配,软件开发人员在使用SQLite时可以据此获得最佳性能. 1.特性    SQLite内核和它的内存分配子系统提供以下特性:    (1)对内存分配失败的健壮处理.如果一个内存分配请求失败(即malloc()或realloc()返回NULL),SQ

c++中函数中变量内存分配以及返回指针、引用类型的思考

众所周知,我们在编程的时候经常会在函数中声明局部变量(包括普通类型的变量.指针.引用等等). 同时,为了满足程序功能的需要,函数的返回值也经常是指针类型或是引用类型,而这返回的指针或是引用也经常指向函数中我们自己声明的局部变量. 这样,程序在某些情况下就可能存在一定的问题.看似很简单的问题,通过仔细的分析,我们就能够更好的理解c++中内存分配和释放的问题. 好,废话不多说,我们进入正题.首先,简单介绍一下程序的内存区域的分配: 程序的内存分配 ①堆区(heap).这一部分主要是由程序开发人员自己