C语言第三方库---Melon安装(Linux)

C语言第三方库—Melon安装(Linux)

Melon库是C语言开发时常用的一个第三方库,内部包含了一些常用的数据结构和算法,因为C语言标准库中没有像C++或者Java里的一些强大的库,最近想深入学习更多C语言,下面也是自己学习记录的过程 :
这里使用的是Ubuntu20.04,首先你的Linux需要先安装好git,make等工具,既然你要安装第三方库,这里默认你已经安装过一些必要的软件了。
使用git命令从GitHub下载melon:

git clone https://github.com/water-Melon/Melon.git

如果执行以上命令报错:

fatal: unable to access 'https://github.com/water-Melon/Melon.git/': GnuTLS recv error (-54): Error in the pull function.

将链接中https改为git即可解决。
然后依次执行:

./configure

我使用的时候这里报错了,因为configure不在该目录下,执行

find -name configure

找到configure所在目录,进入到该目录下执行上述步骤。
然后执行:

make
sudo make install
sudo echo "/usr/local/melon/lib/" >> /etc/ld.so.conf

上面第三个命令我在使用的时候报错了:
在这里插入图片描述
如果你在使用的时候也报了相同的错误,则将命令改为

sudo sh -c "echo '/usr/local/melon/lib/' >> /etc/ld.so.conf"

即可。
最后一步执行以下命令:

sudo ldconfig

代码主要参考代码
下面用vim创建一个例程,迫不及待测试一下melon库的使用:

//这段代码主要是初始化了一个全局变量,然后给每一个子进程创建了一个定时事件,即每一秒中输出一个hello world。
#include <stdio.h>
#include "mln_core.h"
#include "mln_log.h"
#include "mln_event.h"

char text[1024];

static int global_init(void);
static void worker_process(mln_event_t *ev);
static void print_handler(mln_event_t *ev, void *data);

int main(int argc, char *argv[]) {
    struct mln_core_attr cattr;
    cattr.argc = argc;
    cattr.argv = argv;
    cattr.global_init = global_init;
    cattr.worker_process = worker_process;
    return mln_core_init(&cattr);
}

static int global_init(void) {
    //global variable init function
    int n = snprintf(text, sizeof(text)-1, "hello worldn");
    text[n] = 0;
    return 0;
}

static void worker_process(mln_event_t *ev) {
    //we can set event handler here
    //let's set a timer
    mln_event_set_timer(ev, 1000, text, print_handler);
}

static void print_handler(mln_event_t *ev, void *data) {
    mln_log(debug, "%sn", (char *)data);
    mln_event_set_timer(ev, 1000, data, print_handler);
}

生成可执行文件:

gcc -o hello hello.c -I /usr/local/melon/include/ -L /usr/local/melon/lib/ -lmelon

配置melon:

sudo vim /usr/local/melon/conf/melon.conf

修改为以下部分内容:
在这里插入图片描述
修改后启用了多进程框架,执行刚刚的程序会产生三个子进程
可以参考这个大佬的博客:https://blog.csdn.net/weixin_40960130/article/details/113768162
然后保存并退出。
执行刚刚生成的可执行文件:

./hello

结果:
在这里插入图片描述
显示有些混乱,但是已经成功了
如果在执行 hello可执行文件时,提示被拒绝,则是因为权限不够的原因
更改命令为:

sudo ./hello

大家加油!!!

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
华为od机试 - melon的难题是一道考察基础算法和编程能力的问题。该问题要求编写一个程序,找出给定字符串中最长的无重复字符的子串的长度。 解决该问题的关键是使用滑动窗口算法。我们可以定义一个窗口,窗口的左边界为字符串的起始位置,右边界为当前无重复字符子串的结尾位置。通过移动右边界,我们可以不断扩大无重复字符子串的长度。当遇到重复字符时,我们需要移动左边界来缩小窗口,直到窗口中不再有重复的字符。 具体解题思路如下: 1. 定义一个哈希表,用于存储字符和它在字符串中的索引的对应关系。 2. 遍历字符串中的每个字符,通过判断字符是否已经在哈希表中出现来确定是否重复。 3. 若字符未重复,则将字符及其索引添加到哈希表中,并更新当前子串长度。同时,比较当前子串长度与最大子串长度,更新最大子串长度。 4. 若字符重复,则需要移动左边界,并更新哈希表和当前子串长度。移动左边界时,我们需要将重复字符之前的所有字符从哈希表中删除,并更新左边界为重复字符的下一个位置。 5. 重复步骤2至4,直到遍历完整个字符串。 最后,返回最大子串长度即为所求。 这道题目考察了对基础算法的理解和应用,特别是滑动窗口算法的使用。通过编写这道题目的解答,可以提升对算法和数据结构的掌握能力,培养解决问题的思维能力。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值