5.9-Java-抽象方法和抽象类、接口、引用类型数组

补充:

        1.设计规则:①:将派生类共有的属性和行为,抽到超类中-----抽共性

                             ②:若派生类的行为/代码都一样,设计为普通方法

                                     若派生类的行为/代码不一样,设计为抽象方法(abstract修饰)

                             ③:将部分派生类共有的行为/代码,设计为接口

                                        接口是对继承单根性的扩展,实现多继承

                                        接口是一种标准、规范,若实现了某接口就具备某个功能,若不实现接口就不具备

        2.不包含抽象方法的类同样可以被声明为抽象类,但同样不能实例化

一、抽象方法和抽象类

        1.abstract修饰抽象方法,只有方法的定义,没有具体的实现

        2.类中出现抽象方法,类也必须用abstract修饰

        3.抽象类不能被实例化(new对象)

        4.抽象类是需要继承的,派生类中抽象方法重写

        5.意义:①:封装共有的属性和行为,实现代码复用

                      ②:可以包含抽象方法,为所有派生类统一入口(名字统一),强制必须重写

二、接口

        1.是一种引用数据类型(目前学了三种:数组,类,接口)

        2.由interface(接口)定义:interface Inter{  抽象方法(常量、默认方法、静态方法、私有方法)  }

        3.不能被实例化

        4.接口是需要被实现的,实现类:必须重写接口中的所有抽象方法(实现:implements)

                注意:重写接口中的方法时,必须加public

        5.一个类可以实现多个接口。若又继承又实现,先继承后实现

        6.接口可以继承接口

三、引用类型数组

        1.数组元素为引用类型的数组

        2.给引用类型数组的元素赋值时,需要new个对象

        3.访问引用类型数组元素的属性/行为时,需要打点调用

四、null

        1.表示空,没有指向任何对象

        2.若引用的值为null,则不能进行任何点操作,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
XML-RPC是一种轻量级的远程过程调用(RPC)协议,它使用XML格式来编码调用请求和响应。在Qt 5.9中,可以使用QXmlRpc库来实现XML-RPC客户端和服务端。 实现XML-RPC客户端 以下是使用QXmlRpcClient类实现XML-RPC客户端的示例代码: ```c++ #include <QtCore/QCoreApplication> #include <QtXmlRpc/QXmlRpcClient.h> int main(int argc, char *argv[]) { QCoreApplication app(argc, argv); QUrl url("http://localhost:8000/RPC2"); // XML-RPC服务端的URL QXmlRpcClient client(url); // 调用XML-RPC方法 QVariantList params; params << 2 << 3; QXmlRpcValue result = client.call("sample.add", params); if (result.isValid() && result.type() == QXmlRpcValue::TypeInt) qDebug() << "Result:" << result.toInt(); else qDebug() << "Error:" << result.toString(); return app.exec(); } ``` 在上面的示例中,我们首先创建了一个QUrl对象来指定XML-RPC服务端的URL,然后使用QXmlRpcClient类创建了一个客户端对象。接下来,我们使用call()方法调用了一个名为“sample.add”的XML-RPC方法,并传递了两个整数作为参数。最后,我们检查了返回值的类型,并打印了结果或错误消息。 注意,调用XML-RPC方法是一个同步操作,它会阻塞当前线程,直到服务端返回结果或超时。 实现XML-RPC服务端 以下是使用QXmlRpcServer类实现XML-RPC服务端的示例代码: ```c++ #include <QtCore/QCoreApplication> #include <QtXmlRpc/QXmlRpcServer.h> int main(int argc, char *argv[]) { QCoreApplication app(argc, argv); QXmlRpcServer server; server.registerMethod("sample.add", [&](QXmlRpcValue params, QXmlRpcValue& result) { if (params.isArray() && params.size() == 2 && params[0].type() == QXmlRpcValue::TypeInt && params[1].type() == QXmlRpcValue::TypeInt) { int a = params[0].toInt(); int b = params[1].toInt(); result = a + b; } else { result = "Invalid parameters"; } }); if (!server.listen(QHostAddress::Any, 8000)) { qDebug() << "Failed to start XML-RPC server"; return 1; } qDebug() << "XML-RPC server started on port 8000"; return app.exec(); } ``` 在上面的示例中,我们首先创建了一个QXmlRpcServer对象,然后使用registerMethod()方法注册了一个名为“sample.add”的XML-RPC方法。在回调函数中,我们首先检查传递的参数是否为两个整数,如果是,则将它们相加并将结果存储在返回值中。否则,我们将返回一个错误消息。 最后,我们使用listen()方法启动服务端,并检查是否成功。如果成功,我们打印一条消息表示服务端已经启动。 注意,启动XML-RPC服务端是一个异步操作,它会在另一个线程中运行,直到服务端停止或出现错误。在上面的示例中,我们使用app.exec()来保持主线程在运行状态,直到服务端停止。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值