| 网站首页 | 业界新闻 | 群组 | 交易 | 人才 | 下载频道 | 博客 | 代码贴 | 编程论坛
大量收QQ微信精准粉/交友粉,非诚勿扰千里之行 始于足下
共有 269 人关注过本帖
标题:关于 void *
只看楼主 加入收藏
Jonny0201
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:23
帖 子:354
专家分:1733
注 册:2016-11-7
结帖率:100%
  已结贴   问题点数:20  回复次数:5   
关于 void *
程序代码:
void *find(const void *first, const void *last, const void *value, size_t size) {
    const char *f = (const char *)first;
    while(f != last) {
        if(!memcmp(f, value, size)) {
            return (void *)f;
        }
        f += size;
    }
    return NULL;
}

有个地方不可以用 C++ 的 template, 所以只能用 void * 实现
对于 const void *value 来说, 传入左值可以运行的很好, 但是右值这个函数就无法正常运作了
是否有方法让这个函数对传入的右值也很好的运作
例如 :
程序代码:
#include <stdio.h>
#include <memory.h>

void *find(const void *first, const void *last, const void *value, size_t size) {
    const char *f = (const char *)first;
    while(f != last) {
        if(!memcmp(f, value, size)) {
            return (void *)f;
        }
        f += size;
    }
    return NULL;
}
int main(int argc, char *argv[]) {
    int a[] = {1, 2, 3, 4, 5, 6, 7, 8};
    int value = 2;
    printf("%p", find(a, a + sizeof a / sizeof(int), 2, sizeof value));        //2 为右值, 无法被传入 const void *
}

C 学的不是很好
上面所说的左值和右值是 C++ 中的概念, 此处 C 和 C++ 的概念差别应该不大

[此贴子已经被作者于2018-10-11 22:05编辑过]

2018-10-11 22:02
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:160
帖 子:6218
专家分:27258
注 册:2014-5-20
  得分:3 
2可能被视作整数了,用(void*)转下试试
2018-10-11 22:38
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:266
帖 子:5837
专家分:33355
注 册:2011-1-18
  得分:17 
从你的代码上看,你应该传入 &value,而不是 2
如果你想问的是能不能做到传入2的话,那答案应该是不可能。因为你这个函数还想适用于int之外的类型,除非 void* find(const void* first, const void* last, ... )

2018-10-12 08:49
烟雨晨曦
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:6
帖 子:145
专家分:579
注 册:2017-3-5
  得分:0 
你这个是类型的问题,不是左值右值的问题
2018-10-12 09:47
Jonny0201
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:23
帖 子:354
专家分:1733
注 册:2016-11-7
  得分:0 
回复 2楼 吹水佬
2 强转之后就是 0x2
吃个 segment fault
2018-10-12 10:18
烟雨晨曦
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:6
帖 子:145
专家分:579
注 册:2017-3-5
  得分:0 
一定要这样使用只能再写一个函数强转一次
程序代码:
#include <stdio.h>
#include <memory.h>

void *find(const void *first, const void *last, const void *value, size_t size)
{
    const char *f = (const char *)first;
    while(f != last) {
        if(!memcmp(f, value, size)) {
            return (void *)f;
        }
        f += size;
    }
    return NULL;
}

void *find(const void *first, const void *last, int&& value, size_t size)
{
    const void * p = (const void *)&value;
    find(first,last,p,size);
}

int main(int argc, char *argv[])
{
    int a[] = {1, 2, 3, 4, 5, 6, 7, 8};
    int value=2;
    printf("%p", find(a, a + sizeof a / sizeof(int), 2, sizeof(value)));
}

2018-10-12 10:52







关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.045035 second(s), 8 queries.
Copyright©2004-2018, BCCN.NET, All Rights Reserved