牛客网 http://www.nowcoder.com/test/question/done?tid=2198842&qid=14753#summary

下面这段代码运行时会出现什么问题?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
class A
{
public :
     void f()
     {
         printf( "A\n" );
     }
};
 
class B:  public A
{
public :
     virtual  void f()
     {
         printf( "B\n" );
     }
};
 
int main()
{
     A *a =  new B;
     a->f();
     delete a;
     return 0 ;
}
 
    

正确答案: B   你的答案: C (错误)

没有问题,输出B
不符合预期的输出A
程序不正确
以上答案都不正确

本题知识点

参考解析添加解析

  • 推荐
    墨儿头像

    墨儿

    答案:B

    基类A 的f()没有声明为虚函数,所以没有B覆盖。
    编辑于 2015-02-02 15:04:15 回复(1)
  • 更多回答(5条)
  • kindle1212xxcc头像

    kindle1212xxcc

    确实会输出A,但同时程序也会崩溃。
    因为delete a这一句会出错,a实际还是一个B类型,但是析构函数没有声明为虚函数,导致调用了A的默认析构函数,内存溢出了。
    发表于 2015-09-
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这段代码定义了一个名为 read 的函数,用于读取指定数据集(train、dev 或 test)的数据,并将其转换为适合 PaddlePaddle 框架训练的格式。具体来说,这段代码的含义如下: - `def read(split='train'):`:定义一个名为 read 的函数,它有一个名为 split 的参数,默认值为 'train',用于指定要读取的数据集。 - `data_dict={'train':'ChnSentiCorp/train.tsv', "dev":'ChnSentiCorp/dev.tsv', 'test':'ChnSentiCorp/test.tsv'}`:定义一个名为 data_dict 的字典,用于存储不同数据集的文件路径。 - `with open(data_dict[split],'r') as f:`:打开指定数据集的文件,并使用 with 语句来自动关闭文件。 - `head = None`:将 head 变量初始化为 None。 - `for line in f.readlines():`:对于文件中的每一行数据,执行以下操作: - `data = line.strip().split("\t")`:将当前行的数据按制表符分割,并去除字符串两端的空白字符。 - `if not head:`:如果 head 变量为空(即是第一行数据)则执行以下操作: - `head = data`:将当前行的数据赋值给 head 变量。 - `else:`:如果不是第一行数据则执行以下操作: - `if split == 'train':`:如果当前读取的是训练集数据,则执行以下操作: - `label, text = data`:将当前行的数据分别赋值给 label 和 text 变量。 - `yield {"text": text, "label": label, "qid": ''}`:使用 yield 语句生成一个字典,其中 text 键对应当前行的文本数据,label 键对应当前行的标签数据,qid 键为空字符串。 - `elif split == 'dev':`:如果当前读取的是开发集数据,则执行以下操作: - `qid, label, text = data`:将当前行的数据分别赋值给 qid、label 和 text 变量。 - `yield {"text": text, "label": label, "qid": qid}`:使用 yield 语句生成一个字典,其中 text 键对应当前行的文本数据,label 键对应当前行的标签数据,qid 键对应当前行的 qid 数据。 - `elif split == 'test':`:如果当前读取的是测试集数据,则执行以下操作: - `qid, text = data`:将当前行的数据分别赋值给 qid 和 text 变量。 - `yield {"text": text, "label": '', "qid": qid}`:使用 yield 语句生成一个字典,其中 text 键对应当前行的文本数据,label 键为空字符串,qid 键对应当前行的 qid 数据。 - `train_ds= load_dataset(read, split="train",lazy=False)`:使用 load_dataset 函数加载训练集数据,并将其赋值给 train_ds 变量。 - `dev_ds= load_dataset(read, split="dev",lazy=False)`:使用 load_dataset 函数加载开发集数据,并将其赋值给 dev_ds 变量。 - `test_ds= load_dataset(read, split="test",lazy=False)`:使用 load_dataset 函数加载测试集数据,并将其赋值给 test_ds 变量。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值