问题列表 - 第24362页

解除内存需要时间吗?

我有一个C++程序,在执行期间,将分配大约3-8Gb的内存来存储哈希表(我使用tr1/unordered_map)和各种其他数据结构.

但是,在执行结束时,返回shell之前会有很长的停顿时间.

例如,在我的主要功能的最后,我有

std::cout << "End of execution" << endl;
Run Code Online (Sandbox Code Playgroud)

但是我的程序执行会像

$ ./program
do stuff ...
执行结束
[可能长达2分钟的停顿]
$ - 返回shell

这是预期的行为还是我做错了什么?

我猜这个程序最终会释放内存.但是,当您关闭应用程序时,使用大量内存的商业应用程序(如photoshop)不会出现此暂停.

请指教 :)

编辑:最大的数据结构是一个unordered_map键入string和存储listintegers.

g++ -O2在linux上使用,我使用的计算机有128GB的内存(其中大部分是免费的).有一些巨大的物体

解决方案:我最终摆脱了哈希表,因为它几乎已经满了.这解决了我的问题.

c++ linux memory memory-management

13
推荐指数
5
解决办法
5022
查看次数

将值显式乘以long

我知道所有数学都是作为处理当前值所需的最大数据类型完成的,但当你横向循环时,如何明确地乘以long?我怀疑,由于溢出,下面的代码返回0.

long result = 0L;
List<Long> temp = (List<Long>) getListOfIntegers();
for (int i = 0; i < temp.size(); i++) {
   result *= temp.get(i).longValue();
}
System.out.println(result);
Run Code Online (Sandbox Code Playgroud)

java math

0
推荐指数
2
解决办法
125
查看次数

打印div的内容

以下div的内容是动态派生的:即使用某个按钮动态地将表添加到此div.

我的问题是如何打印此div(window.print)的内容而不是页面中的其他内容

<div id="newdiv" name="newdiv"></div>
Run Code Online (Sandbox Code Playgroud)

谢谢.

html javascript printing

0
推荐指数
1
解决办法
1041
查看次数

使用Octave估算数据周期的最快方法是什么?

我有一组周期性的数据(但不是正弦的).我在一个向量中有一组时间值,在第二个向量中有一组幅度.我想快速估算一下这个函数的周期.有什么建议?

具体来说,这是我目前的代码.我想近似矢量x(:,2)对矢量t的周期.最后,我想在很多初始条件下执行此操作并计算每个条件的周期并绘制结果.

function xdot = f (x,t)
         xdot(1) =x(2);
         xdot(2) =-sin(x(1));
endfunction

x0=[1;1.75];     #eventually, I'd like to try lots of values for x0(2)
t = linspace (0, 50, 200);


x = lsode ("f", x0, t)

plot(x(:,1),x(:,2));
Run Code Online (Sandbox Code Playgroud)

谢谢!

约翰

matlab signal-processing fft octave

4
推荐指数
1
解决办法
9256
查看次数

C系统调用open/read/write/close和O_CREAT | O_EXCL

给出以下代码(它应该在"helloworld"文件中编写"helloworld",然后阅读文本):

#include <fcntl.h>
#include <sys/types.h>
#include <sys/stat.h>

#define FNAME "helloworld"

int main(){ 
    int filedes, nbytes;
    char buf[128];

    /* Creates a file */
    if((filedes=open(FNAME, O_CREAT | O_EXCL | O_WRONLY | O_APPEND, 
        S_IRUSR | S_IWUSR)) == -1){
            write(2, "Error1\n", 7);
    }

    /* Writes hello world to file */
    if(write(filedes, FNAME, 10) != 10)
        write(2, "Error2\n", 7);

    /* Close file */
    close(filedes);

    if((filedes = open(FNAME, O_RDONLY))==-1)
        write(2, "Error3\n", 7);

    /* Prints file contents on screen */    
    if((nbytes=read(filedes, buf, 128)) == -1)
        write(2, "Error4\n", …
Run Code Online (Sandbox Code Playgroud)

c system-calls

6
推荐指数
1
解决办法
2万
查看次数

如何在同一个套接字上托管WCF服务和TCP服务器?

Tooday我使用ServiceHost来托管WCF服务.

我想在我的WCF服务附近托管我自己的TCP程序,用于直接套接字操作(比如某种广播TCP流的留置权)

我需要控制URL名称空间(所以我可以让我的客户端使用一些不错的URL直接将TCP流发送到我的服务中,例如example.com:port/myserver/stream?id=1或example.com:port/myserver/stream?id =任何东西,所以我不会在1个socket的1个客户端的想法中受到困扰,我真的希望将我的WCF服务保留在与我自己的服务器相同的端口上,或者它是什么样的能够调用www.example.com:port/myWCF/stream?id=222 ...我希望它的任何端口上工作 - 不仅80)

任何人都可以帮我这个吗?

我现在只使用WCF.我不喜欢它是如何工作的.这是为什么我要开始迁移以清除TCP =)的众多原因之一

我不能使用net-tcp绑定或任何其他酷WS-*绑定(今天我使用最简单的绑定,以便我的客户像Flash,AJAX等轻松连接到我).

我需要快速简单地实现连接协议,就像我在套接字中创建的那样,实时用于数据传输.

那么......有什么想法?请 - 我需要帮助.

c# sockets wcf tcp servicehost

5
推荐指数
1
解决办法
1721
查看次数

从文件中读取并添加数字

我有文本文件,条目如123 112 3333 44 2

如何添加这些数字并获得这些数字的总和.

bash add

10
推荐指数
2
解决办法
2万
查看次数

选择按X排序的前N个记录,但是按逆序排序结果

我正在尝试获得前N个记录(当按某些列X排序时),但结果设置的顺序相反.以下陈述不正确,但可能演示了我所追求的内容:

SELECT * FROM (SELECT TOP 10 * FROM FooTable ORDER BY X DESC) ORDER BY X ASC
Run Code Online (Sandbox Code Playgroud)

例如,列X可以是ID或时间戳; 我想要最新的10条记录,但希望它们按照时间顺序返回.

sql selection

7
推荐指数
2
解决办法
3万
查看次数

DataContractSerializer如何写入私有字段?

我理解XMLSerializer如何通过使用反射来确定它应该用于序列化或反序列化XML的公共读/写字段或属性.然而,XMLSerializer要求字段是公共的和读/写.

但是,DataContractSerializer能够读取或写入类中的完全私有字段.所以我想知道如何明确给出DataContractSerializer对我的类的附加访问权限.

.net c# xml datacontractserializer xmlserializer

6
推荐指数
1
解决办法
2534
查看次数

重置对象与构造新对象

为特定对象创建"重置"函数是否被认为是更好的实践和/或更有效,它清除/默认所有必要的成员变量以允许进一步操作,或者简单地从外部构造新对象?

我已经看到两种方法都使用了很多,但我无法确定哪种方法更好.当然,对于代表数据库连接的类,你必须使用重置方法而不是构造一个新方法,导致不必要的连接/断开,但我在抽象类方面更多.

谁能给我一些关于何时使用每种方法的真实例子?在我的特定情况下,我主要考虑ORM或MVC中的模型.例如,如果我想要检索一堆数据库对象以供显示,并在一次操作中修改它们.

php mysql oop

5
推荐指数
1
解决办法
204
查看次数