Throw an exception while construct an object

博主在阅读《thinking in c++ 2》时给出一段代码。代码定义了buffer类,包含构造函数和析构函数,构造函数中使用new分配内存,析构函数用delete释放内存,还定义了处理函数,最后在main函数中创建对象并调用处理函数。

while reading the book < thinking in c++ 2>, I got the codes below:

#include <stdlib.h>
#include <iostream>

#pragma warning(disable : 4297)

using namespace std;

class buffer
{
public:
 explicit buffer(size_t) throw();
 ~buffer() throw();
private:
 char *const p;
};

buffer::buffer(size_t const count)
try
: p(new char[count])
{
 cout << "constructor goes well......" << endl;
}
catch (...)
{
 throw "hello";
 abort();
}

buffer::~buffer()
{
 delete[] p;
 cout << "destructor also goes well......" << endl;
}

static void do_something_with(buffer &) throw()
{
 cout << "something is done !" << endl;
}

int main()
{
 buffer b(100);
 do_something_with(b);
 return 0;
}

object AdbConnector { private const val TAG = "AdbConnector" private val base64Impl: AdbBase64 get() = object : AdbBase64 { override fun encodeToString(data: ByteArray?): String? { return Base64.encodeToString(data, Base64.DEFAULT) } } // This function loads a keypair from the specified files if one exists, and if not, // it creates a new keypair and saves it in the specified files @Throws( NoSuchAlgorithmException::class, InvalidKeySpecException::class, IOException::class ) private fun setupCrypto(pubKeyFile: String, privKeyFile: String): AdbCrypto { val pub = File(pubKeyFile) val priv = File(privKeyFile) var c: AdbCrypto? = null // Try to load a key pair from the files if (pub.exists() && priv.exists()) { c = try { AdbCrypto.loadAdbKeyPair(base64Impl, priv, pub) } catch (e: Exception) { // Failed to read from file null } } if (c == null) { // We couldn't load a key, so let's generate a new one c = AdbCrypto.generateAdbKeyPair(base64Impl) // Save it c.saveAdbKeyPair(priv, pub) Log.d(TAG, "Generated new keypair") } else { Log.d(TAG, "Loaded existing keypair") } return c } @Throws(Exception::class) fun connection(context: Context, host: String?, port: Int): AdbConnection { // Setup the crypto object required for the AdbConnection val path = context.cacheDir.absolutePath Log.e(TAG, "connection path $path") val crypto = setupCrypto( path + File.separatorChar + "pub.key", path + File.separatorChar + "priv.key" ) Log.e(TAG, "Socket connecting...") val sock = Socket(host, port) // Connect the socket to the remote host Log.e(TAG, "Socket connected") // Construct the AdbConnection object val adb = AdbConnection.create(sock, crypto) // Start the application layer connection process Log.e(TAG, "ADB connecting...") adb.connect() Log.e(TAG, "ADB connected") return adb } @Throws(Exception::class) fun buildConnect(context: Context, host: String?, port: Int): AdbConnection { // Setup the crypto object required for the AdbConnection val path = context.cacheDir.absolutePath Log.e(TAG, "connection path $path") val crypto = setupCrypto( path + File.separatorChar + "pub.key", path + File.separatorChar + "priv.key" ) Log.e(TAG, "Socket connecting...") val sock = Socket(host, port) // Connect the socket to the remote host Log.e(TAG, "Socket connected") // Construct the AdbConnection object return AdbConnection.create(sock, crypto) } @Throws(Exception::class) fun openShell(context: Context, host: String?, port: Int): AdbStream { val connection = connection(context, host, port) return connection.open("shell:") } } 用kotlin 开发通过wifiadb发送APPOPS命令的应用,补全操作界面,生成完整代码
最新发布
10-26
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值