免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1527 | 回复: 4
打印 上一主题 下一主题

[C++] 请问c++释放问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-10-28 15:52 |只看该作者 |倒序浏览
假设动态配置了
int *a=new int;
*a=1
delete a;
发现只释放了a指标指向的int
a本身这个指标并没有被释放
请问a本身这个指标会占记忆体空间和需要释放吗?

论坛徽章:
0
2 [报告]
发表于 2013-10-28 15:58 |只看该作者
使用OTL操作Oracle数据库

一、编写代码

注:以下代码来自OTL示例


/*
* otl_test.cpp
*
*/

#include <iostream>
using namespace std;

#include <cstdio>

#define OTL_ORA10G_R2 // Compile OTL 4.0/OCI10gR2
#include <otlv4.h> // include the OTL 4.0 header file
otl_connect db; // connect object

void insert()
// insert rows into table
{
    otl_stream o(50, // buffer size
            "insert into test_tab values(:f1<int>,:f2<char[31]>",
            // SQL statement
            db // connect object
            );
    o.set_commit(0); // turn off stream's "auto-commit"

    char tmp[32];

    for (int i = 1; i <= 123; ++i) {
        sprintf(tmp, "Name%d", i);
        o << i << tmp;
    }
    o.flush(); // flush the stream's dirty buffer:
    // execute the INSERT for the rows
    // that are still in the stream buffer

    db.commit_nowait(); // commit with no wait (new feature of Oracle 10.2)
}

void select() {
    otl_stream i(50, // buffer size
            "select * from test_tab where f1>=:f<int> and f1<=:f*2",
            // SELECT statement
            db // connect object
            );
    // create select stream

    float f1;
    char f2[31];

    i << 8; // assigning :f = 8
    // SELECT automatically executes when all input variables are
    // assigned. First portion of output rows is fetched to the buffer

    while (!i.eof()) { // while not end-of-data
        i >> f1 >> f2;
        cout << "f1=" << f1 << ", f2=" << f2 << endl;
    }

    i << 4; // assigning :f = 4
    // SELECT automatically executes when all input variables are
    // assigned. First portion of output rows is fetched to the buffer

    while (!i.eof()) { // while not end-of-data
        i >> f1 >> f2;
        cout << "f1=" << f1 << ", f2=" << f2 << endl;
    }

}

int main() {
    otl_connect:tl_initialize(); // initialize OCI environment
    try {

        db.rlogon("xuanyuan/xuanyuan"; // connect to Oracle

        otl_cursor::direct_exec(db, "drop table test_tab",
                otl_exception::disabled // disable OTL exceptions
        ); // drop table

        otl_cursor::direct_exec(db,
                "create table test_tab(f1 number, f2 varchar2(30))"; // create table

        insert(); // insert records into table
        select(); // select records from table

    }

    catch (otl_exception& p) { // intercept OTL exceptions
        cerr << p.msg << endl; // print out error message
        cerr << p.stm_text << endl; // print out SQL that caused the error
        cerr << p.var_info << endl; // print out the variable that caused the error
    }

    db.logoff(); // disconnect from Oracle

    return 0;

}

二、编译代码


g++ -o"otl_test" otl_test.cpp -lclntsh -I"$ORACLE_HOME/rdbms/public"

三、运行程序 otl_test


$ ./otl_test

结果如下:


f1=8, f2=Name8
f1=9, f2=Name9
f1=10, f2=Name10
f1=11, f2=Name11
f1=12, f2=Name12
f1=13, f2=Name13
f1=14, f2=Name14
f1=15, f2=Name15
f1=16, f2=Name16
f1=4, f2=Name4
f1=5, f2=Name5
f1=6, f2=Name6
f1=7, f2=Name7
f1=8, f2=Name8

四、关于OTL更多的信息

请访问OTL的主页:http://otl.sourceforge.net/
Linux下C/C++、ACE、Boost、高性能服务器端应用 开发技术
http://www.xuanyuan-soft.cn

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
3 [报告]
发表于 2013-10-28 16:19 |只看该作者
a 本身是个局部变量。
正如int b,*a;
上文和a,b都是局部变量, 不能Delete。

论坛徽章:
0
4 [报告]
发表于 2013-10-28 20:14 |只看该作者
本帖最后由 801901987 于 2013-10-28 20:14 编辑
folklore 发表于 2013-10-28 16:19
a 本身是个局部变量。
正如int b,*a;
上文和a,b都是局部变量, 不能Delete。

豁然開朗,非常感謝!

论坛徽章:
4
白羊座
日期:2013-09-17 21:59:30技术图书徽章
日期:2013-10-12 22:16:03白羊座
日期:2013-10-14 11:01:40双子座
日期:2013-12-17 18:26:39
5 [报告]
发表于 2013-10-28 21:51 |只看该作者
回复 4# 801901987
栈和堆的区别

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP