RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / user-607963

Чёрный Монах's questions

Martin Hope
Black Monk
Asked: 2025-02-24 23:35:01 +0000 UTC

当在 C 语言中保证不需要该对象时,选择释放分配的内存的时间的依据是什么?

  • 6

我没有针对这个问题的任何特定代码,因为手头的主题基本上适用于所有 C 程序。我主要对调用内置自由函数和准备其调用的策略和原则感兴趣,例如将所有变量存储在一个对象中或尽可能多地使用静态变量。例如,Gigachat建议我使用后立即释放资源,但在我看来,这不是唯一可能的解决方案,对吗?

c
  • 2 个回答
  • 58 Views
Martin Hope
Black Monk
Asked: 2025-02-24 05:26:04 +0000 UTC

C# HttpListener 或 PHP php-fpm:Linux 上的稳定性和性能问题 [关闭]

  • 4
已关闭。对这个问题不可能给出一个客观的答案。目前不接受对此问题的答复。

想改进这个问题吗? 重新构建问题,以便可以使用事实和引述来回答。

昨天休息。

改进问题

我使用服务器后面的 HttpListener 来实现 HTTPS,并没有引起任何抱怨。我想切换到 php-fpm,但我不知道它会有什么效果。有谁知道这个问题,告诉我 Linux 上最新版本的 php-fpm 有多可靠,相同算法在相同数据集上的性能是否可以比较?

php-fpm
  • 1 个回答
  • 18 Views
Martin Hope
Чёрный Монах
Asked: 2025-01-06 21:04:17 +0000 UTC

终端命令根据命令 file -i *.txt 的输出删除带有 txt 扩展名的文件

  • 6

控制台中的命令file -i *.txt显示文件名、MIME 和编码的列表。如何编写终端表达式来过滤输出行不包含子字符串的文件text/plain; charset=utf-8?您只需在当前文件夹中触摸它即可。

lubuntu
  • 1 个回答
  • 17 Views
Martin Hope
Чёрный Монах
Asked: 2025-01-05 20:13:08 +0000 UTC

从指针到指针的常量指针到常量数据

  • 8
#include <stdio.h>
#include <iso646.h>
#include <stdlib.h> 

#define FAIL exit(EXIT_FAILURE);

void check_params(const int params_count, char ** params) // const char ** const params - error
{
    if (not ((params_count == 2) and (params != NULL) and (params[1] != NULL)))
    {
        puts("Input params check failed. Program terminated.");
    
        FAIL
    }
}

int main(int params_count, char * params[])
{           
    check_params(params_count, params);     
}

如何在被调用函数中正确创建指向常量数据的常量指针,这可能吗?函数中必须不能更改参数中的任何数据。

更新 @Harry 提出的解决方案抛出一个错误:

$ gcc test.c -Wall -Wextra --pedantic --std=c23
   test.c: In function ‘main’:
   test.c:19:32: error: passing argument 2 of ‘check_params’ from incompatible pointer type [-Wincompatible-pointer-types]
  19 |     check_params(params_count, params);
     |                                ^~~~~~
     |                                |
     |                                char **
   test.c:7:70: note: expected ‘const char * const* const’ but argument is of type ‘char **’
   7 | void check_params(const int params_count, const char * const * const params)
c
  • 1 个回答
  • 63 Views
Martin Hope
Чёрный Монах
Asked: 2025-01-05 18:36:49 +0000 UTC

列出从 1 开始的素数的最快算法?

  • 7

SO上也有这样的问题,但争议一直拖在那里。有没有一种快速方法可以找到给定素数之后的下一个素数来扩展哈希表?

示例(根据@MBo的推荐更新代码)

size_t get_next_prime_number(size_t current_prime_number)
{
size_t saved = current_prime_number;
bool is_prime = true;

if (current_prime_number >= MIN_PRIME_NUMBER)
    for(current_prime_number = current_prime_number + 2; current_prime_number < SIZE_MAX; current_prime_number += 2)    
        {
            // previous: for(size_t j = 2; j < current_prime_number; ++j)
            for(size_t j = 3; j*j <= current_prime_number; j +=2)
                if (current_prime_number % j == 0)
                {
                    is_prime = false;
                    
                    break;  
                }
                else
                    is_prime = true;

            if (is_prime)
                break;      
        }

 return (current_prime_number == saved) ? 0 : current_prime_number;
 }

更新

我尝试使用分成简单的建议,但没有成功Floating point exception。

#include <stdlib.h>
#include <stdint.h>
#include <stdio.h>
#include <string.h>
#include <math.h>

#define MIN_PRIME_NUMBER 2 // > 1
#define DIVIDER_LIMIT 65535 // sqrt(4294967295)
#define INDEX_DIFFERENCE 10 // > 1

void resize_array_up(size_t * stored_primes, const size_t prime_position)
{   
if (prime_position % INDEX_DIFFERENCE == INDEX_DIFFERENCE - 1)          
    if (!realloc(stored_primes, (prime_position + INDEX_DIFFERENCE + 1) * sizeof(size_t)))
        exit(EXIT_FAILURE);
        
stored_primes = memset(stored_primes, 0, sizeof(size_t));
}

size_t get_next_prime_number(const size_t current_prime_number, const size_t prime_position, size_t * stored_primes)
{   
resize_array_up(stored_primes, prime_position); 

size_t saved_current = current_prime_number,
       prime_number = 1;    

if ((current_prime_number >= MIN_PRIME_NUMBER) && (prime_position < SIZE_MAX) && (current_prime_number < SIZE_MAX))
{
    for(size_t divider = sqrt(current_prime_number), number = divider * divider, temporary_number = current_prime_number + 2; 
            (divider < DIVIDER_LIMIT) && (number <= temporary_number); divider += 2, number = divider * divider, temporary_number += 2)
        for(size_t counter = 0; counter <= prime_position; ++counter)
        {
            if ((number % stored_primes[counter]) == 0)
                break;              
            else                       
                prime_number = number;                
        }   
}

return (prime_number == saved_current) ? 0 : prime_number;
}

int main(void)
{   
size_t * primes = calloc(INDEX_DIFFERENCE, sizeof(size_t));

if (primes)
{
    size_t prime_position = 0, 
           prime_number = MIN_PRIME_NUMBER;
    primes[prime_position] = prime_number;  

    do
    {
        prime_number = get_next_prime_number(prime_number, prime_position++, primes);
    
        printf("%zu\n\n", prime_number);
    }
    while (prime_number != 0);

    if (prime_number == 0)
        free(primes);
}
else
    exit(EXIT_FAILURE);
    
return EXIT_SUCCESS;
}
алгоритм
  • 3 个回答
  • 167 Views
Martin Hope
Чёрный Монах
Asked: 2025-01-02 00:47:29 +0000 UTC

Deitelov 的书《How to Program in C》第 7 版有错别字?

  • 8

第297页有一个函数原型是这样的:

void bubble( int work[], const int size, int (*compare) ( int a, int b) );

第 300 页说函数bubble可以有这样的原型:

int (*) (int, int )

怎么一件事变成了另一件事,是不是有错别字?

c
  • 1 个回答
  • 42 Views
Martin Hope
Чёрный Монах
Asked: 2024-12-28 23:17:10 +0000 UTC

如何为 Ruby ELK 7.17.0 插件正确编写正则表达式模式以捕获任何输入字符串中任意位置的 IPv4 地址?

  • 5

这里有一些例子,但它不适用于它们。

我выражение从互联网上获取任何用于在字符串中搜索匹配项的内容,并执行以下操作:/(^(выражение))|(выражение)|((выражение)$)|(^(выражение)$)/,但如果它位于字符串末尾,则它不会捕获字符串中的地址,并且一切都在服务器端表达式模拟器中运行。如何写出正确的表达方式?我看到有些人$使用\z严格的行尾来代替,但我仍然不明白如何在这个插件中正确捕获开头或结尾。

ruby
  • 1 个回答
  • 18 Views
Martin Hope
Чёрный Монах
Asked: 2024-12-08 18:55:34 +0000 UTC

根据 ISO/IEC 9899:2024 对齐内存中的对象

  • 5

请解释我是否正确理解这个概念。

关于术语对齐的标准摘录:

要求特定类型的对象位于存储边界上,其地址是字节地址的特定倍数。

翻译:

要求特定类型的对象位于存储边界,其地址是字节地址的特定倍数。

我对此的理解是,内存中任何变量的值必须通过实现分布在整数个字节上,这意味着位字段小于一个字节的结构将占用一个或多个字节,对吗?

c
  • 1 个回答
  • 32 Views
Martin Hope
Чёрный Монах
Asked: 2024-07-20 15:50:03 +0000 UTC

错误:无法加载源 https://api.nuget.org/v3/index.js 的服务索引

  • 7

问题背景

不同之处在于我有不同的防病毒软件。但我的防病毒软件已经提供了现成的 .pem 文件。有什么方法可以安装吗?

openssl
  • 1 个回答
  • 20 Views

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5