在android中同时调用多个麦克风报错:android.media.MediaRecorder.start(Native Method) 5C

1.问题描述:
在android中同时调用多个麦克风报错:

报错位置mr2.strat():第二个麦克风启动操作时报错。

报错内容:

android.media.MediaRecorder.start(Native Method)

代码如下:

图片说明




图片说明

录音权限和存储权限已授予。


    private void startRecord(){
        if(mr == null){
            File dir = new File(Environment.getExternalStorageDirectory(),"sounds");
            if(!dir.exists()){
                dir.mkdirs();
            }
            String filename = string1.getText().toString();
            SimpleDateFormat df = new SimpleDateFormat("yyyy_MM_dd_HH_mm_ss");//设置日期格式
            File soundFile = new File(dir,filename+df.format(new Date())+"_MIC"+".amr");
            File soundFile2 = new File(dir,filename+df.format(new Date())+"_VOICE_COMMUNICATION"+".amr");
            if(!soundFile.exists()){
                try {
                    soundFile.createNewFile();
                } catch (IOException e) {
                    e.printStackTrace();
                }

            }
            if(!soundFile2.exists()){
                try {
                    soundFile2.createNewFile();
                } catch (IOException e) {
                    e.printStackTrace();
                }

            }

            mr = new MediaRecorder();
            mr.setAudioSource(MediaRecorder.AudioSource.DEFAULT);
            mr.setOutputFormat(MediaRecorder.OutputFormat.AMR_WB);   //设置输出格式
            mr.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_WB);   //设置编码格式
            mr.setOutputFile(soundFile.getAbsolutePath());

            mr2 = new MediaRecorder();
            mr2.setAudioSource(MediaRecorder.AudioSource.VOICE_COMMUNICATION);  //音频输入源
            mr2.setOutputFormat(MediaRecorder.OutputFormat.AMR_WB);
            mr2.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_WB);
            mr2.setOutputFile(soundFile2.getAbsolutePath());


            try {
                mr.prepare();
                mr.start();//
                mr2.prepare();
                mr2.start();//**在这个位置报错**

            } catch (IOException e) {
                e.printStackTrace();
            }

        }
    }

    //停止录制,资源释放
    private void stopRecord(){
        if(mr != null){
            mr.stop();
            mr2.stop();

            mr.release();
            mr2.release();

            mr = null;
            mr2 = null;
        }
    }

2个回答

weixin_37863063
月夜忆 我想知道的是如何在Android studio中通过代码实现,目前只有小米手机不会报错,华为和原生Android都不行
9 个月之前 回复

第一次创建的时候没有释放就又接着调用,肯定会出错呀

weixin_37863063
月夜忆 在手机内部,是如何同时调用两个麦克风实现降噪的呢?
9 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Android:ProgressDialog.show() 和getApplicationContext冲突
我不能理解为什么会有冲突发生。下边的代码没有什么问题: mProgressDialog= ProgressDialog.show(this, "", getString(R.string.loading), true); 但是这个代码抛出异常: mProgressDialog= ProgressDialog.show(getApplicationContext(), "", getString(R.string.loading), true); W/WindowManager( 569): Attempted to add windowwith non-application tokenWindowToken{438bee58 token=null}. Aborting. D/AndroidRuntime( 2049): Shutting down VMW/dalvikvm( 2049): threadid=3: thread exitingwith uncaught exception(group=0x4001aa28) E/AndroidRuntime( 2049): Uncaught handler: thread main exiting due to uncaught exceptionE/AndroidRuntime( 2049): java.lang.RuntimeException: Unable to start activityComponentInfo{com.tastekid.TasteKid/com.tastekid.TasteKid.YouTube}: android.view.WindowManager$BadTokenException: Unable to add window-- tokennull is not for an application E/AndroidRuntime( 2049): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2401) E/AndroidRuntime( 2049): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2417) E/AndroidRuntime( 2049): at android.app.ActivityThread.access$2100(ActivityThread.java:116) E/AndroidRuntime( 2049): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1794) E/AndroidRuntime( 2049): at android.os.Handler.dispatchMessage(Handler.java:99) E/AndroidRuntime( 2049): at android.os.Looper.loop(Looper.java:123) E/AndroidRuntime( 2049): at android.app.ActivityThread.main(ActivityThread.java:4203) E/AndroidRuntime( 2049): at java.lang.reflect.Method.invokeNative(Native Method) E/AndroidRuntime( 2049): at java.lang.reflect.Method.invoke(Method.java:521) E/AndroidRuntime( 2049): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:791) E/AndroidRuntime( 2049): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:549) E/AndroidRuntime( 2049): at dalvik.system.NativeStart.main(Native Method) E/AndroidRuntime( 2049): Caused by: android.view.WindowManager$BadTokenException: Unable to add window-- tokennull is not for an application E/AndroidRuntime( 2049): at android.view.ViewRoot.setView(ViewRoot.java:460) E/AndroidRuntime( 2049): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:177) E/AndroidRuntime( 2049): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91) E/AndroidRuntime( 2049): at android.app.Dialog.show(Dialog.java:238) E/AndroidRuntime( 2049): at android.app.ProgressDialog.show(ProgressDialog.java:107) E/AndroidRuntime( 2049): at android.app.ProgressDialog.show(ProgressDialog.java:90) E/AndroidRuntime( 2049): at com.tastekid.TasteKid.YouTube.onCreate(YouTube.java:45) E/AndroidRuntime( 2049): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1123) E/AndroidRuntime( 2049): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2364) E/AndroidRuntime( 2049): ... 11 more 有人知道为什么会发生这个么?我从onCreate方法调用的这个。
android:MapActivity报错:Nullpointerexception
当我第一次加载我的app时,mapActivity是可以调用的,而且我能看到地图。现在当我关掉networkconnectivity再打开,改变屏幕,回到mapactivity,地图显示为空,在new MapUtils().drawMap(this); in onResume()方法这一行得到空指针异常。 @Override protected void onResume() { Utils utils = new Utils(); manager = (LocationManager) getSystemService(Context.LOCATION_SERVICE); listener = new ManageLocation(); listener.setSucessCallBack(this, "setLocation"); listener.setFailureCallBack(this, "setNoLocation"); manager.requestLocationUpdates( utils.getCurrentPlaceLocationProvider(manager), 0, 0, listener); super.onResume(); Log.d(TAG, "Constants.isDataLoadedPAB " + Constants.isMaptobeLoaded + " Constants.isDataLoadedPAB : " + Constants.isDataLoadedPAB); if (Constants.isMaptobeLoaded) { if (Constants.isDataLoadedPAB) { try { new MapUtils().drawMap(this); } catch (Exception e) { Log.e(TAG, "Error", e); } } else { if (Constants.currentLocation != null && Constants.searchLocation != null) { if (Constants.searchResultData == null) { Constants.searchResultData = new ArrayList<AttractionData>(); } new MapUtils().drawMap(this); } } } ((ImageView) activity.findViewById(R.id.left)).setEnabled(true); ((ImageView) activity.findViewById(R.id.right)).setEnabled(true); ((ImageView) findViewById(R.id.searchicon)).setEnabled(true); ((ImageView) activity.findViewById(R.id.facebookintegration)).setEnabled(true); } 我尝试在onResume()再次调用它,但是仍然得到空。我不知道我做错了什么,有没有谁能帮帮我? my log 01-29 11:23:36.325: E/AndroidRuntime(6668): Caused by: java.lang.NullPointerException 01-29 11:23:36.325: E/AndroidRuntime(6668): at org.appright.myneighborhood.maps.MapUtils.drawMap(MapUtils.java:59) 01-29 11:23:36.325: E/AndroidRuntime(6668): at org.appright.myneighborhood.activity.CityAttractions.onResume(CityAttractions.java:505) 01-29 11:23:36.325: E/AndroidRuntime(6668): at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1199) 01-29 11:23:36.325: E/AndroidRuntime(6668): at android.app.Activity.performResume(Activity.java:5280) 01-29 11:23:36.325: E/AndroidRuntime(6668): at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2606) 01-29 11:23:36.325: E/AndroidRuntime(6668): ... 10 more
Android 调用SparseArray的put方法报数组越界.
突然报SystemUI crash,查看log是数组越界: 04-23 05:23:58.484 2838 3037 E AndroidRuntime: FATAL EXCEPTION: Recents-TaskResourceLoader 04-23 05:23:58.484 2838 3037 E AndroidRuntime: Process: com.android.systemui, PID: 2838 04-23 05:23:58.484 2838 3037 E AndroidRuntime: java.lang.ArrayIndexOutOfBoundsException: src.length=23 srcPos=-14 dst.length=23 dstPos=-13 length=36 04-23 05:23:58.484 2838 3037 E AndroidRuntime: at java.lang.System.arraycopy(Native Method) 04-23 05:23:58.484 2838 3037 E AndroidRuntime: at com.android.internal.util.GrowingArrayUtils.insert(GrowingArrayUtils.java:150) 04-23 05:23:58.484 2838 3037 E AndroidRuntime: at android.util.SparseArray.put(SparseArray.java:246) 04-23 05:23:58.484 2838 3037 E AndroidRuntime: at com.android.systemui.shared.recents.model.TaskKeyCache.put(TaskKeyCache.java:67) 04-23 05:23:58.484 2838 3037 E AndroidRuntime: at com.android.systemui.shared.recents.model.IconLoader.getIcon(IconLoader.java:77) 04-23 05:23:58.484 2838 3037 E AndroidRuntime: at com.android.systemui.shared.recents.model.BackgroundTaskLoader.processLoadQueueItem(BackgroundTaskLoader.java:140) 04-23 05:23:58.484 2838 3037 E AndroidRuntime: at com.android.systemui.shared.recents.model.BackgroundTaskLoader.run(BackgroundTaskLoader.java:109) 04-23 05:23:58.484 2838 3037 E AndroidRuntime: at android.os.Handler.handleCallback(Handler.java:873) 04-23 05:23:58.484 2838 3037 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:99) 04-23 05:23:58.484 2838 3037 E AndroidRuntime: at android.os.Looper.loop(Looper.java:210) 04-23 05:23:58.484 2838 3037 E AndroidRuntime: at android.os.HandlerThread.run(HandlerThread.java:65) 查看代码是SparseArray.java的put方法插入值的时候i取了小于0,但是看不懂是怎么负值的: public void put(int key, E value) { // 二分查找,key在mKeys列表中对应的index int i = ContainerHelpers.binarySearch(mKeys, mSize, key); // 如果找到,则直接赋值 if (i >= 0) { mValues[i] = value; } // 找不到 else { // binarySearch方法中,找不到时,i取了其非,这里再次取非,则非非则正 i = ~i; // 如果该位置的数据正好被删除,则赋值 if (i < mSize && mValues[i] == DELETED) { mKeys[i] = key; mValues[i] = value; return; } // 如果有数据被删除了,则gc if (mGarbage && mSize >= mKeys.length) { gc(); // Search again because indices may have changed. i = ~ContainerHelpers.binarySearch(mKeys, mSize, key); } // 插入数据,增长mKeys与mValues列表 mKeys = GrowingArrayUtils.insert(mKeys, mSize, i, key);//这里i取了-14导致异常,不知道怎么回事. mValues = GrowingArrayUtils.insert(mValues, mSize, i, value); mSize++; } } 看了下SparseArray是线程不安全的,怀疑是不是多线程调用的时候被其他线程插入了数据,但是不知道怎么去排查.
android.net.nsd 发现服务时随机重启报错 dequeueBuffer failed
小弟最近在做安卓的开发,用了android.net.nsd的服务注册与发现。在模拟器上调试的时候没有发现任何问题。但是将demo放到智能电视的时候出了问题。程序有时正常有时会重启。进过不断的调试发现是在启动NSD服务发现的时候报错了。 报错信息如下: 09-30 15:10:56.760: I/sg_life(11572): start discover…… 09-30 15:10:56.760: V/ActivityThread(11572): Resume ActivityRecord{41664cf8 token=android.os.BinderProxy@41664490 {com.example.testapk/com.example.testapk.ui.MDEActivity}} started activity: false, hideForNow: false, finished: false 09-30 15:10:56.768: V/ActivityThread(11572): Scheduling idle handler for ActivityRecord{41664cf8 token=android.os.BinderProxy@41664490 {com.example.testapk/com.example.testapk.ui.MDEActivity}} 09-30 15:10:56.856: E/SurfaceTextureClient(11572): dequeueBuffer failed (No such device) 09-30 15:10:56.864: E/ViewRootImpl(11572): Could not lock surface 09-30 15:10:56.864: E/ViewRootImpl(11572): java.lang.IllegalArgumentException 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.view.Surface.nativeLockCanvas(Native Method) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.view.Surface.lockCanvas(Surface.java:452) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.view.ViewRootImpl.drawSoftware(ViewRootImpl.java:2264) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.view.ViewRootImpl.draw(ViewRootImpl.java:2227) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2095) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1904) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1039) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:4417) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:749) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.view.Choreographer.doCallbacks(Choreographer.java:562) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.view.Choreographer.doFrame(Choreographer.java:532) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:735) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.os.Handler.handleCallback(Handler.java:725) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.os.Handler.dispatchMessage(Handler.java:92) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.os.Looper.loop(Looper.java:137) 09-30 15:10:56.864: E/ViewRootImpl(11572): at android.app.ActivityThread.main(ActivityThread.java:5061) 09-30 15:10:56.864: E/ViewRootImpl(11572): at java.lang.reflect.Method.invokeNative(Native Method) 09-30 15:10:56.864: E/ViewRootImpl(11572): at java.lang.reflect.Method.invoke(Method.java:511) 09-30 15:10:56.864: E/ViewRootImpl(11572): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:829) 09-30 15:10:56.864: E/ViewRootImpl(11572): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:596) 09-30 15:10:56.864: E/ViewRootImpl(11572): at dalvik.system.NativeStart.main(Native Method) 09-30 15:10:57.424: E/InputEventReceiver(11572): channel '41c547b0 com.example.testapk/com.example.testapk.ui.MainActivity (client)' ~ Publisher closed input channel or an error occurred. events=0x9 09-30 15:10:57.600: E/InputEventReceiver(11572): channel '41b6a120 com.example.testapk/com.example.testapk.ui.MDEActivity (client)' ~ Publisher closed input channel or an error occurred. events=0x9 代码如下: public void discoverServices() { Log.i("sg_life", "start discover……"); mNsdManager.discoverServices(SERVICE_TYPE, NsdManager.PROTOCOL_DNS_SD, mDiscoveryListener); } 日志中第一行是调用discoverServices之前的日志,在mDiscoveryListener的onDiscoveryStarted方法里也加了输出但是日志上没有打出来。 public void onDiscoveryStarted(String regType) { Log.e("sg_life", "Service discovery started……"); } 因此暂时判断是discoverServices方法中出错。API中discoverServices方法如下 public void discoverServices(String serviceType, int protocolType, DiscoveryListener listener) { if (listener == null) { throw new IllegalArgumentException("listener cannot be null"); } if (TextUtils.isEmpty(serviceType)) { throw new IllegalArgumentException("Service type cannot be empty"); } if (protocolType != PROTOCOL_DNS_SD) { throw new IllegalArgumentException("Unsupported protocol"); } NsdServiceInfo s = new NsdServiceInfo(); s.setServiceType(serviceType); mAsyncChannel.sendMessage(DISCOVER_SERVICES, 0, putListener(listener, s), s); } 再之后的代码小弟也没能力找到,根据报错日志也没有找到有用的信息。
CSocket类中OnReceive()函数被重写后,为什么还要调用CSocket::OnReceive.
1.CSocket类中OnReceive()函数被重写后,为什么还要调用CSocket::OnReceive. 2.被重写的Onreceive()函数什么时候会被调用,该函数中使用了Receive()方法。我没有使用定时器机制,会不会造成阻塞。 感谢您的耐心解答
MySql每天在同一个时间点报错:Timeout expired.
连接:局域网内连接; Mysql安装方式:以Windows服务的方式启动,mysqld install 服务名,配置文件只有一个my.ini文件; 数据库访问方式:调用程序集MySql.Data.dll,版本5.0.9.0; 程序:定时每分钟往局域网内的服务器插入数据,分实时数据和历史数据; 历史数据:每分钟统计好所有数据,一次性以“insert 表名 Value(),()....”的方式插入; 实时数据:每分钟等历史数据插完,以循环方式插入每条数据,循环中数据库连接每次都Open和Close; 出错:每天都在中午11:55分插入实时数据时报错“**imeout expired. The timeout period elapsed prior to completion of the operation or the server is not responding.**”而且每天报错时插入的数据都时同一条; 采取措施:已经在ini配置文件中加入配置interactive_timeout=604800;wait_timeout=604800。 但是问题一直得不到解决,希望有人能帮我分析下问题到底出现在哪里;
基于AXIS调用webservice报错:Connection refused: connect
我的调用方法: public static void main(String[] args) throws Exception { String client_id = "HeYiApp"; String orderNum = "2"; List numberList = new ArrayList(); numberList.add("120719"); numberList.add("120746"); numberList.add("113095"); String webUrl = "https://10.218.132.26/api/openapi/employee/getBatchEmpInfoList.json";// 服务端url地址 String webMethod = "getBatchEmpInfoList";// 调用方法名称 Service service = new Service(); // 建服务 Call call; try { call = (Call) service.createCall(); try { call.setTargetEndpointAddress(new URL(webUrl)); } catch (MalformedURLException e) { // TODO Auto-generated catch block e.printStackTrace(); }// 设置访问地址 call.setOperationName(webMethod);// 设置访问方法 call.addParameter("arg0", XMLType.XSD_STRING, javax.xml.rpc.ParameterMode.IN);// 定义参数 call.addParameter("arg1", XMLType.XSD_STRING, javax.xml.rpc.ParameterMode.IN);// 定义参数 call.addParameter("arg2", XMLType.XSD_STRING, javax.xml.rpc.ParameterMode.IN);// 定义参数 call.setReturnType(XMLType.XSD_STRING);// 定义返回值格式 //List<Map<String, Object>> workersInfo= (List<Map<String, Object>>) call.invoke(new Object[] { client_id, numberList, orderNum }); //for(Map m:workersInfo){ // System.out.println(m.get("name")); //} JSONArray jsonObject = (JSONArray) call.invoke(new Object[] { client_id, numberList, orderNum }); System.out.println(jsonObject.toString()); } catch (ServiceException e) { // TODO Auto-generated catch block e.printStackTrace(); } // 建对话 } 报错: Exception in thread "main" AxisFault faultCode: {http://schemas.xmlsoap.org/soap/envelope/}Server.userException faultSubcode: faultString: java.net.ConnectException: Connection refused: connect faultActor: faultNode: faultDetail: {http://xml.apache.org/axis/}stackTrace:java.net.ConnectException: Connection refused: connect at java.net.DualStackPlainSocketImpl.connect0(Native Method) at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:79) at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172) at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) at java.net.Socket.connect(Socket.java:589) at sun.security.ssl.SSLSocketImpl.connect(SSLSocketImpl.java:668) at sun.security.ssl.SSLSocketImpl.&lt;init&gt;(SSLSocketImpl.java:427) at sun.security.ssl.SSLSocketFactoryImpl.createSocket(SSLSocketFactoryImpl.java:88) at org.apache.axis.components.net.JSSESocketFactory.create(JSSESocketFactory.java:92) at org.apache.axis.transport.http.HTTPSender.getSocket(HTTPSender.java:191) at org.apache.axis.transport.http.HTTPSender.writeToSocket(HTTPSender.java:404) at org.apache.axis.transport.http.HTTPSender.invoke(HTTPSender.java:138) at org.apache.axis.strategies.InvocationStrategy.visit(InvocationStrategy.java:32) at org.apache.axis.SimpleChain.doVisiting(SimpleChain.java:118) at org.apache.axis.SimpleChain.invoke(SimpleChain.java:83) at org.apache.axis.client.AxisClient.invoke(AxisClient.java:165) at org.apache.axis.client.Call.invokeEngine(Call.java:2784) at org.apache.axis.client.Call.invoke(Call.java:2767) at org.apache.axis.client.Call.invoke(Call.java:2443) at org.apache.axis.client.Call.invoke(Call.java:2366) at org.apache.axis.client.Call.invoke(Call.java:1812) at webservice.Test.main(Test.java:52) {http://xml.apache.org/axis/}hostname:zhangxl java.net.ConnectException: Connection refused: connect at org.apache.axis.AxisFault.makeFault(AxisFault.java:101) at org.apache.axis.transport.http.HTTPSender.invoke(HTTPSender.java:154) at org.apache.axis.strategies.InvocationStrategy.visit(InvocationStrategy.java:32) at org.apache.axis.SimpleChain.doVisiting(SimpleChain.java:118) at org.apache.axis.SimpleChain.invoke(SimpleChain.java:83) at org.apache.axis.client.AxisClient.invoke(AxisClient.java:165) at org.apache.axis.client.Call.invokeEngine(Call.java:2784) at org.apache.axis.client.Call.invoke(Call.java:2767) at org.apache.axis.client.Call.invoke(Call.java:2443) at org.apache.axis.client.Call.invoke(Call.java:2366) at org.apache.axis.client.Call.invoke(Call.java:1812) at webservice.Test.main(Test.java:52) Caused by: java.net.ConnectException: Connection refused: connect at java.net.DualStackPlainSocketImpl.connect0(Native Method) at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:79) at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172) at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) at java.net.Socket.connect(Socket.java:589) at sun.security.ssl.SSLSocketImpl.connect(SSLSocketImpl.java:668) at sun.security.ssl.SSLSocketImpl.<init>(SSLSocketImpl.java:427) at sun.security.ssl.SSLSocketFactoryImpl.createSocket(SSLSocketFactoryImpl.java:88) at org.apache.axis.components.net.JSSESocketFactory.create(JSSESocketFactory.java:92) at org.apache.axis.transport.http.HTTPSender.getSocket(HTTPSender.java:191) at org.apache.axis.transport.http.HTTPSender.writeToSocket(HTTPSender.java:404) at org.apache.axis.transport.http.HTTPSender.invoke(HTTPSender.java:138) ... 10 more
安卓运行报错android.content.ActivityNotFoundException: Unable to find explicit activity class
以下是报错信息: ``` android.content.ActivityNotFoundException: Unable to find explicit activity class {com.example.helloworld/android.widget.TextView}; have you declared this activity in your AndroidManifest.xml? ``` 然后我搜索了一下得到的解决方案是没有将activity在mainfest.xml中注册,但是我已经注册过了,以下是xml中的代码 ``` <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.helloworld"> <application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/AppTheme"> <activity android:name=".TextViewActivity" android:label=""></activity>//注册第二个活动 <activity android:name=".MainActivity"> //前面的点是包名省略, <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest> ``` 以下是第二个活动的代码 ``` package com.example.helloworld; import androidx.appcompat.app.AppCompatActivity; import android.graphics.Paint; import android.os.Bundle; import android.widget.TextView; public class TextViewActivity extends AppCompatActivity { private TextView tv2; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_text_view); tv2 = findViewById(R.id.tv2); tv2.getPaint().setFlags(Paint.STRIKE_THRU_TEXT_FLAG);//加入划线 tv2.getPaint().setAntiAlias(true);//去除锯齿 } } ``` 以下是第二个活动的xml代码 ``` <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center_horizontal" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/tv_test1" android:textColor="#000000" android:textSize="30sp" />//在strings.xml中编辑好后,在这里调用 //最大行数为一,且显示不下时出现省略号 <TextView android:layout_width="100dp" android:layout_height="wrap_content" android:maxLines="1" android:ellipsize="end" android:id="@+id/t2" android:text="哎哟不错哦!" android:textColor="#000000" android:textSize="30sp"/> //有额外选项或者下拉框(大致这个意思) <TextView android:layout_width="match_parent" android:layout_height="50dp" android:drawableRight="@drawable/arrow3" android:text="for you and me" android:textColor="#000000" android:textSize="30sp" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="xxx" android:id="@+id/tv2" android:textColor="#000000" android:textSize="30sp" /> </LinearLayout> ``` 以下是mainactivity的代码(之后补充的) ``` public class MainActivity extends AppCompatActivity { private Button btntv; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main);//设置内容视图 btntv = findViewById(R.id.bt_tv1); btntv.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { //跳转到TextView演示界面 Intent intent = new Intent(MainActivity.this, TextView.class); startActivity(intent); } }); } } ```
Python->Pyecharts->Geo在地图中加入自定义的点报错:AttributeError: 'NoneType' object has no attribute 'add'。
Geo在地图中加入自定义的点报错: AttributeError: 'NoneType' object has no attribute 'add' 原码: ``` from example.commons import Faker from pyecharts import options as opts from pyecharts.charts import Geo from pyecharts.globals import ChartType, SymbolType import pandas as pd import json # 链式调用 c = ( Geo() .add_schema(maptype="world") # 加入自定义的点,格式为 .add_coordinate("测试点", 116.39770014211535, 39.90779994986951) # 为自定义的点添加属性 .add("geo", [("测试点", 51)]) .set_series_opts(label_opts=opts.LabelOpts(is_show=False)) .set_global_opts(title_opts=opts.TitleOpts(title="宇宙中心呼唤爱")) ) # 在 html(浏览器) 中渲染图表 c.render() # 在 Jupyter Notebook 中渲染图表 c.render_notebook() ``` 报错: .add_coordinate("测试点", 116.39770014211535, 39.90779994986951) AttributeError: 'NoneType' object has no attribute 'add'
请问下各位大佬们,我在用ksoap2-Android调用web service服务时出现了stream closed的报错
小弟仿照网上的一个例子想用web service服务写一个查询天气的安卓应用。 但是在该服务的第三个方法时出现了stream closed的错误,百度没有找到结果, 麻烦各位大神帮我看下,以下是我的代码,在根据城市获取城市具体天气情况这个 方法时报了错 提供服务的URL是http://ws.webxml.com.cn/WebServices/WeatherWS.asmx ``` public class WebServicerUtil { // 定义Web Service的命名空间 static final String SERVICE_NS = "http://WebXml.com.cn/"; // 定义Web Service提供服务的URL static final String SERVICE_URL = "http://ws.webxml.com.cn/WebServices/WeatherWS.asmx"; // 调用远程 Web Service获取省份列表 public static List<String> getProvinceList() { /** * 调用远程Web Service的getRegionProvince方法: 获得中国省份、直辖市、地区和与之对应的ID * <ArrayOfString xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns="http://WebXml.com.cn/"> <string>黑龙江,3113</string> <string>吉林,3114</string> <string>辽宁,3115</string> <string>内蒙古,3116</string> <string>河北,3117</string> <string>河南,3118</string> <string>山东,3119</string> <string>山西,31110</string> <string>江苏,31111</string> <string>安徽,31112</string> <string>陕西,31113</string> <string>宁夏,31114</string> <string>甘肃,31115</string> <string>青海,31116</string> <string>湖北,31117</string> <string>湖南,31118</string> <string>浙江,31119</string> <string>江西,31120</string> <string>福建,31121</string> <string>贵州,31122</string> <string>四川,31123</string> <string>广东,31124</string> <string>广西,31125</string> <string>云南,31126</string> <string>海南,31127</string> <string>新疆,31128</string> <string>西藏,31129</string> <string>台湾,31130</string> <string>北京,311101</string> <string>上海,311102</string> <string>天津,311103</string> <string>重庆,311104</string> <string>香港,311201</string> <string>澳门,311202</string> <string>钓鱼岛,311203</string> </ArrayOfString> */ String methodName = "getRegionProvince"; //获得中国省份、直辖市、地区和与之对应的ID // 创建HttpTransportSE传输对象,该对象用于调用Web Service操作 HttpTransportSE ht = new HttpTransportSE(SERVICE_URL); ht.debug = true; // 使用SOAP1.1协议创建Envelop对象 SoapSerializationEnvelope envelope = new SoapSerializationEnvelope( SoapEnvelope.VER11); // 实例化SoapObject对象,传入所要调用的Web Service的命名空间,Web Service方法名 SoapObject soapObject = new SoapObject(SERVICE_NS, methodName); //将 soapObject对象设置为SoapSerializationEnvelope对象的传出SOAP消息 envelope.bodyOut = soapObject; /** * 因为什么这个网站是通过.NET对外提供Web Service的, * 因此设置与.Net提供的Web Service保持较好的兼容性 */ envelope.dotNet = true; try { // 调用Web Service ht.call(SERVICE_NS + methodName, envelope); if (envelope.getResponse() != null) { // 获取服务器响应返回的SOAP消息 SoapObject result = (SoapObject) envelope.bodyIn; SoapObject detail = (SoapObject) result.getProperty(methodName + "Result"); // 解析服务器响应的SOAP消息。 return parseProvinceOrCity(detail); } } catch (IOException e) { e.printStackTrace(); } catch (XmlPullParserException e) { e.printStackTrace(); } return null; } // 根据省份获取城市列表 public static List<String> getCityListByProvince(String province) { /** * 调用的方法 * 获得支持的城市/地区名称和与之对应的ID 输入参数:theRegionCode = 省市、国家ID或名称,返回数据:一维字符串数组。 如:输入北京的theRegionCode:311101得到的返回结果为: <ArrayOfString xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns="http://WebXml.com.cn/"> <string>北京,792</string> <string>昌平,785</string> <string>大兴,826</string> <string>房山,827</string> <string>怀柔,752</string> <string>门头沟,788</string> <string>密云,751</string> <string>平谷,756</string> <string>顺义,741</string> <string>通州,3409</string> <string>延庆,746</string> <string>海淀,742</string> <string>朝阳,3408</string> <string>丰台,795</string> <string>石景山,794</string> </ArrayOfString> */ String methodName = "getSupportCityString"; // 创建HttpTransportSE传输对象 HttpTransportSE ht = new HttpTransportSE(SERVICE_URL); ht.debug = true; // 实例化SoapObject对象 SoapObject soapObject = new SoapObject(SERVICE_NS, methodName); // 添加一个请求参数 soapObject.addProperty("theRegionCode", province); // 使用SOAP1.1协议创建Envelop对象 SoapSerializationEnvelope envelope = new SoapSerializationEnvelope( SoapEnvelope.VER11); envelope.bodyOut = soapObject; // 设置与.Net提供的Web Service保持较好的兼容性 envelope.dotNet = true; try { // 调用Web Service ht.call(SERVICE_NS + methodName, envelope); if (envelope.getResponse() != null) { // 获取服务器响应返回的SOAP消息 SoapObject result = (SoapObject) envelope.bodyIn; SoapObject detail = (SoapObject) result.getProperty(methodName + "Result"); // 解析服务器响应的SOAP消息。 return parseProvinceOrCity(detail); } } catch (IOException e) { e.printStackTrace(); } catch (XmlPullParserException e) { e.printStackTrace(); } return null; } // 解析服务器响应的SOAP消息。 private static List<String> parseProvinceOrCity(SoapObject detail) { List<String> result = new ArrayList<String>(); for (int i = 0; i < detail.getPropertyCount(); i++) { // 解析出每个省份 result.add(detail.getProperty(i).toString().split(",")[0]); } return result; } // 根据城市获取城市具体天气情况 public static SoapObject getWeatherByCity(String cityName) { String methodName = "getWeather"; HttpTransportSE ht = new HttpTransportSE(SERVICE_URL); ht.debug = true; SoapSerializationEnvelope envelope = new SoapSerializationEnvelope( SoapEnvelope.VER11); SoapObject soapObject = new SoapObject(SERVICE_NS, methodName); soapObject.addProperty("theCityCode", cityName); envelope.bodyOut = soapObject; // 设置与.Net提供的Web Service保持较好的兼容性 envelope.dotNet = true; try { ht.call(SERVICE_NS + methodName, envelope); SoapObject result = (SoapObject) envelope.bodyIn; SoapObject detail = (SoapObject) result.getProperty(methodName + "Result"); return detail; } catch (Exception e) { e.printStackTrace(); } return null; } } ``` 下边是报错内容 ``` 2019-12-22 15:35:47.617 29228-29259/? W/System.err: java.io.IOException: Stream closed 2019-12-22 15:35:47.617 29228-29259/? W/System.err: at java.io.BufferedInputStream.getInIfOpen(BufferedInputStream.java:151) 2019-12-22 15:35:47.617 29228-29259/? W/System.err: at java.io.BufferedInputStream.fill(BufferedInputStream.java:235) 2019-12-22 15:35:47.617 29228-29259/? W/System.err: at java.io.BufferedInputStream.read1(BufferedInputStream.java:275) 2019-12-22 15:35:47.617 29228-29259/? W/System.err: at java.io.BufferedInputStream.read(BufferedInputStream.java:334) 2019-12-22 15:35:47.618 29228-29259/? W/System.err: at org.ksoap2.transport.HttpTransportSE.readDebug(HttpTransportSE.java:299) 2019-12-22 15:35:47.618 29228-29259/? W/System.err: at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:261) 2019-12-22 15:35:47.618 29228-29259/? W/System.err: at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:118) 2019-12-22 15:35:47.618 29228-29259/? W/System.err: at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:113) 2019-12-22 15:35:47.619 29228-29259/? W/System.err: at com.example.weather.WebServicerUtil.getWeatherByCity(WebServicerUtil.java:205) 2019-12-22 15:35:47.619 29228-29259/? W/System.err: at com.example.weather.MyWeather.showWeather(MyWeather.java:147) 2019-12-22 15:35:47.619 29228-29259/? W/System.err: at com.example.weather.MyWeather.access$200(MyWeather.java:21) 2019-12-22 15:35:47.619 29228-29259/? W/System.err: at com.example.weather.MyWeather$3$1.run(MyWeather.java:125) 2019-12-22 15:35:47.619 29228-29259/? W/System.err: at java.lang.Thread.run(Thread.java:761) 2019-12-22 15:35:47.619 29228-29259/? E/AndroidRuntime: FATAL EXCEPTION: Thread-4 Process: com.example.weather, PID: 29228 java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.Object org.ksoap2.serialization.SoapObject.getProperty(int)' on a null object reference at com.example.weather.MyWeather.showWeather(MyWeather.java:150) at com.example.weather.MyWeather.access$200(MyWeather.java:21) at com.example.weather.MyWeather$3$1.run(MyWeather.java:125) at java.lang.Thread.run(Thread.java:761) 2019-12-22 15:35:47.684 29228-29251/? D/EGL_emulation: eglMakeCurrent: 0xa26a6a60: ver 3 0 (tinfo 0xa461a8d0) ```
Eclipse 在工程A中调用B的文件出错
我工程A想调用工程B的文件,我是如下配置的:A工程右键->configure build path ->projects选择添加B工程。然后我直接在A中调用工程B的类(是在一个按钮中调用的)。项目没有报错,编译也可以过,可以当我APP安装后,点击这个调用了B类的按钮就会出错。错误如下 ``` Could not execute method of the activity 09-16 16:00:39.629: E/MyUncaughtHandler(16676): java.lang.IllegalStateException: Could not execute method of the activity 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at android.view.View$1.onClick(View.java:3725) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at android.view.View.performClick(View.java:4262) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at android.view.View$PerformClick.run(View.java:17351) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at android.os.Handler.handleCallback(Handler.java:615) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at android.os.Handler.dispatchMessage(Handler.java:92) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at android.os.Looper.loop(Looper.java:137) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at android.app.ActivityThread.main(ActivityThread.java:4935) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at java.lang.reflect.Method.invokeNative(Native Method) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at java.lang.reflect.Method.invoke(Method.java:511) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1038) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:805) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at dalvik.system.NativeStart.main(Native Method) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): Caused by: java.lang.reflect.InvocationTargetException 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at java.lang.reflect.Method.invokeNative(Native Method) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at java.lang.reflect.Method.invoke(Method.java:511) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at android.view.View$1.onClick(View.java:3720) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): ... 11 more 09-16 16:00:39.629: E/MyUncaughtHandler(16676): Caused by: java.lang.NoClassDefFoundError: org.videolan.vlc.audio.AudioServiceController 09-16 16:00:39.629: E/MyUncaughtHandler(16676): at ixz.fish_help_app.GrpDevListActivity.sys_vlc(GrpDevListActivity.java:1895) 09-16 16:00:39.629: E/MyUncaughtHandler(16676): ... 14 more ``` 其中找不到的文件是我工程B中的文件。
关于android 调用自己编译的su文件报错的问题
百度加google,自己弄了一个zlsu执行文件,放到system/bin/目录下后,调用它的时候,报错: java.io.IOException: write failed: EPIPE (Broken pipe)。
在调用百度地图Sdk时出现以下报错,改如何解决?
03-28 00:03:17.710: I/System.out(1125): so Failed to load. 03-28 00:03:17.770: W/dalvikvm(1125): No implementation found for native Lcom/baidu/platform/comjni/map/commonmemcache/JNICommonMemCache;.Create:()I 03-28 00:03:17.770: D/AndroidRuntime(1125): Shutting down VM 03-28 00:03:17.770: W/dalvikvm(1125): threadid=1: thread exiting with uncaught exception (group=0xb3a24b90) 03-28 00:03:17.780: E/AndroidRuntime(1125): FATAL EXCEPTION: main 03-28 00:03:17.780: E/AndroidRuntime(1125): Process: com.map.activity, PID: 1125 03-28 00:03:17.780: E/AndroidRuntime(1125): java.lang.UnsatisfiedLinkError: Native method not found: com.baidu.platform.comjni.map.commonmemcache.JNICommonMemCache.Create:()I 03-28 00:03:17.780: E/AndroidRuntime(1125): at com.baidu.platform.comjni.map.commonmemcache.JNICommonMemCache.Create(Native Method) 03-28 00:03:17.780: E/AndroidRuntime(1125): at com.baidu.platform.comjni.map.commonmemcache.a.a(Unknown Source) 03-28 00:03:17.780: E/AndroidRuntime(1125): at com.baidu.platform.comapi.c.c.b(Unknown Source) 03-28 00:03:17.780: E/AndroidRuntime(1125): at com.baidu.mapapi.a.c(Unknown Source) 03-28 00:03:17.780: E/AndroidRuntime(1125): at com.baidu.mapapi.SDKInitializer.initialize(Unknown Source) 03-28 00:03:17.780: E/AndroidRuntime(1125): at com.baidu.mapapi.SDKInitializer.initialize(Unknown Source) 03-28 00:03:17.780: E/AndroidRuntime(1125): at com.map.activity.MainActivity.onCreate(MainActivity.java:78) 03-28 00:03:17.780: E/AndroidRuntime(1125): at android.app.Activity.performCreate(Activity.java:5243) 03-28 00:03:17.780: E/AndroidRuntime(1125): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 03-28 00:03:17.780: E/AndroidRuntime(1125): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2140) 03-28 00:03:17.780: E/AndroidRuntime(1125): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2226) 03-28 00:03:17.780: E/AndroidRuntime(1125): at android.app.ActivityThread.access$700(ActivityThread.java:135) 03-28 00:03:17.780: E/AndroidRuntime(1125): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1397) 03-28 00:03:17.780: E/AndroidRuntime(1125): at android.os.Handler.dispatchMessage(Handler.java:102) 03-28 00:03:17.780: E/AndroidRuntime(1125): at android.os.Looper.loop(Looper.java:137) 03-28 00:03:17.780: E/AndroidRuntime(1125): at android.app.ActivityThread.main(ActivityThread.java:4998) 03-28 00:03:17.780: E/AndroidRuntime(1125): at java.lang.reflect.Method.invokeNative(Native Method) 03-28 00:03:17.780: E/AndroidRuntime(1125): at java.lang.reflect.Method.invoke(Method.java:515) 03-28 00:03:17.780: E/AndroidRuntime(1125): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777) 03-28 00:03:17.780: E/AndroidRuntime(1125): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593) 03-28 00:03:17.780: E/AndroidRuntime(1125): at dalvik.system.NativeStart.main(Native Method) 03-28 00:03:39.210: I/Process(1125): Sending signal. PID: 1125 SIG: 9
基于AXIS调用webservice报错:SOAP request failed ....
异常如图所示:![图片说明](https://img-ask.csdn.net/upload/201701/16/1484556304_982303.png) 我的客户端代码如图: ![图片说明](https://img-ask.csdn.net/upload/201701/16/1484556357_449165.png)
Android调用百度地图出现错误
12-08 11:25:41.251: E/NativeLoader(2438): java.lang.NullPointerException 12-08 11:25:41.251: E/NativeLoader(2438): at com.baidu.platform.comapi.NativeLoader.getCodePath(Unknown Source) 12-08 11:25:41.251: E/NativeLoader(2438): at com.baidu.platform.comapi.NativeLoader.copyNativeLibrary(Unknown Source) 12-08 11:25:41.251: E/NativeLoader(2438): at com.baidu.platform.comapi.NativeLoader.d(Unknown Source) 12-08 11:25:41.251: E/NativeLoader(2438): at com.baidu.platform.comapi.NativeLoader.loadCustomizeNativeLibrary(Unknown Source) 12-08 11:25:41.251: E/NativeLoader(2438): at com.baidu.platform.comapi.NativeLoader.loadLibrary(Unknown Source) 12-08 11:25:41.251: E/NativeLoader(2438): at com.baidu.platform.comapi.a.<clinit>(Unknown Source) 12-08 11:25:41.251: E/NativeLoader(2438): at com.baidu.mapapi.BMapManager.getContext(Unknown Source) 12-08 11:25:41.251: E/NativeLoader(2438): at com.baidu.platform.comapi.map.i.<clinit>(Unknown Source) 12-08 11:25:41.251: E/NativeLoader(2438): at com.baidu.mapapi.map.MapView.a(Unknown Source) 12-08 11:25:41.251: E/NativeLoader(2438): at com.baidu.mapapi.map.MapView.<init>(Unknown Source) 12-08 11:25:41.251: E/NativeLoader(2438): at java.lang.reflect.Constructor.constructNative(Native Method) 12-08 11:25:41.251: E/NativeLoader(2438): at java.lang.reflect.Constructor.newInstance(Constructor.java:417) 12-08 11:25:41.251: E/NativeLoader(2438): at android.view.LayoutInflater.createView(LayoutInflater.java:594) 12-08 11:25:41.251: E/NativeLoader(2438): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:696)
MediaRecorder录屏,Socket传输录屏内容报错java.lang.IllegalStateException
用模拟器调试可以运行,用真机测试在 mediaRecorder.prepare();抛异常 ``` package www.xjw.com.mymiracast2.screenrecordservice; import android.app.Notification; import android.app.Service; import android.content.Context; import android.content.Intent; import android.hardware.display.DisplayManager; import android.hardware.display.VirtualDisplay; import android.media.MediaRecorder; import android.media.projection.MediaProjection; import android.media.projection.MediaProjectionManager; import android.os.IBinder; import android.os.ParcelFileDescriptor; import java.net.Socket; /** * Created by dzjin on 2018/1/9. */ public class ScreenRecordService extends Service { private int resultCode; private Intent resultData=null; private MediaProjection mediaProjection=null; private MediaRecorder mediaRecorder=null; private VirtualDisplay virtualDisplay=null; private int mScreenWidth; private int mScreenHeight; private int mScreenDensity; private static String filePathName; private Socket receiver = null; private ParcelFileDescriptor pfd = null; private Context context=null; private String host = null; private int port = 8989; @Override public void onCreate() { super.onCreate(); //startForeground(2, new Notification()); } /** * 每次客户端通过调用startService(Intent)显式启动服务时,系统调用startService(Intent), *提供它提供的参数和表示启动请求的唯一整数标记。 * 不要直接调用这个方法。 * @param intent * @param flags * @param startId * @return */ @Override public int onStartCommand(Intent intent, int flags, int startId) { try{ resultCode=intent.getIntExtra("resultCode",-1); resultData=intent.getParcelableExtra("resultData"); mScreenWidth=intent.getIntExtra("mScreenWidth",0); mScreenHeight=intent.getIntExtra("mScreenHeight",0); mScreenDensity=intent.getIntExtra("mScreenDensity",0); filePathName=intent.getStringExtra("filePathName"); host=intent.getStringExtra("host"); port=intent.getIntExtra("port",8989); receiver = new Socket(host, port); pfd = ParcelFileDescriptor .fromSocket(receiver); mediaProjection=createMediaProjection(); mediaRecorder=createMediaRecorder(); virtualDisplay=createVirtualDisplay(); mediaRecorder.start(); }catch (Exception e) { e.printStackTrace(); } /** * START_NOT_STICKY: *从onStartCommand返回的常量(Intent, int, int):如果这个服务的进程是 *在启动时被杀死(从onStartCommand(Intent, int, int)返回后), *没有新的start意图交付给它,然后将服务从 *启动状态,在以后显式调用Context.startService(Intent)之前不要重新创建。 *服务将不会接收带有空意图的onStartCommand(Intent, int, int)调用 *因为如果没有等待交付的意图,它将不会重新启动。 */ return Service.START_NOT_STICKY; } public MediaProjection createMediaProjection(){ /** *使用getSystemService(类)检索MediaProjectionManager实例 *管理媒体放映会议。 */ return ((MediaProjectionManager)getSystemService(Context.MEDIA_PROJECTION_SERVICE)) .getMediaProjection(resultCode,resultData); /** *检索从成功的屏幕捕获请求中获得的MediaProjection。 *如果startActivityForResult()的结果不是RESULT_OK,则*将为null。 */ } private MediaRecorder createMediaRecorder(){ //用于录制音频和视频。录音控制是基于一个简单的状态机。 MediaRecorder mediaRecorder=new MediaRecorder(); //设置要录音的源。 //mediaRecorder.setAudioSource(MediaRecorder. AudioSource.CAMCORDER); //设置要录制的视频源。 mediaRecorder.setVideoSource(MediaRecorder.VideoSource.SURFACE); //设置录制过程中产生的输出的格式。 //3GPP媒体文件格式 mediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.MPEG_2_TS); //设置录音格式 //mediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB); //设置录像编码比特率。 //param:以比特/秒为单位的视频编码比特率 mediaRecorder.setVideoEncodingBitRate(5*mScreenWidth*mScreenHeight); //设置录像编码器用于录像。 mediaRecorder.setVideoEncoder(MediaRecorder.VideoEncoder.H264); //设置要拍摄的视频的宽度和高度。 mediaRecorder.setVideoSize(mScreenWidth,mScreenHeight); //设置要捕获视频的帧速率。 mediaRecorder.setVideoFrameRate(60); try{ mediaRecorder.setOutputFile(pfd.getFileDescriptor()); //mediaRecorder.setOutputFile(filePathName); **此次抛异常** //准备记录器开始捕捉和编码数据。 mediaRecorder.prepare(); }catch (Exception e){ e.printStackTrace(); } return mediaRecorder; } private VirtualDisplay createVirtualDisplay(){ /** *名称字符串:虚拟显示的名称,必须是非空的。这个值不能为空。 width int:虚拟显示的宽度,以像素为单位。必须大于0。 高度int:虚拟显示器的高度,以像素为单位。必须大于0。 dpi int: dpi中虚拟显示的密度。必须大于0。 标志int:虚拟显示标志的组合。有关标志的完整列表,请参见DisplayManager。 surface surface:虚拟显示内容应该呈现到的表面,如果一开始没有,则为null。 回调virtualdisplay。回调:当虚拟显示的状态改变时调用的回调,如果没有,则为空。 处理程序处理程序:应该在其上调用回调的处理程序,如果应该在调用线程的主循环程序上调用回调,则为null。 */ /** * DisplayManager.VIRTUAL_DISPLAY_FLAG_AUTO_MIRROR *虚拟显示标志:当没有显示内容时,允许在私有显示上镜像内容。 */ return mediaProjection.createVirtualDisplay("mediaProjection",mScreenWidth,mScreenHeight,mScreenDensity, DisplayManager.VIRTUAL_DISPLAY_FLAG_AUTO_MIRROR,mediaRecorder.getSurface(),null,null); } @Override public void onDestroy() { super.onDestroy(); if(virtualDisplay!=null){ virtualDisplay.release(); virtualDisplay=null; } if(mediaRecorder!=null){ mediaRecorder.stop(); mediaRecorder=null; } if(mediaProjection!=null){ mediaProjection.stop(); mediaProjection=null; } } @Override public IBinder onBind(Intent intent) { System.out.println("==============================="); return null; } } ``` I/MediaRecorder: enter in file frameworks/av/media/libmedia/mediarecorder.cpp, function prepare, line 461 I/IMediaRecorder: prepare (BpMediaRecorder client) in file frameworks/av/media/libmedia/IMediaRecorder.cpp, function prepare, line 249 W/com.mymiracast2: type=1400 audit(0.0:104572): avc: denied { read write } for path="socket:[8870267]" dev="sockfs" ino=8870267 scontext=u:r:mediaserver:s0 tcontext=u:r:untrusted_app:s0:c512,c768 tclass=tcp_socket permissive=0 E/MediaRecorder: prepare failed: -38 W/zygote64: Got a deoptimization request on un-deoptimizable method void android.media.MediaRecorder._prepare() W/System.err: java.lang.IllegalStateException W/System.err: at android.media.MediaRecorder._prepare(Native Method) W/System.err: at android.media.MediaRecorder.prepare(MediaRecorder.java:1017) W/System.err: at www.xjw.com.mymiracast2.screenrecordservice.ScreenRecordService.createMediaRecorder(ScreenRecordService.java:137) W/System.err: at www.xjw.com.mymiracast2.screenrecordservice.ScreenRecordService.onStartCommand(ScreenRecordService.java:79) W/System.err: at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:4151) W/System.err: at android.app.ActivityThread.-wrap21(Unknown Source:0) W/System.err: at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2119) W/System.err: at android.os.Handler.dispatchMessage(Handler.java:108) W/System.err: at android.os.Looper.loop(Looper.java:166) W/System.err: at android.app.ActivityThread.main(ActivityThread.java:7529) W/System.err: at java.lang.reflect.Method.invoke(Native Method) W/System.err: at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:245) W/System.err: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:921) E/MediaRecorder: SurfaceMediaSource could not be initialized! W/System.err: java.lang.IllegalStateException: failed to get surface at android.media.MediaRecorder.getSurface(Native Method) W/System.err: at www.xjw.com.mymiracast2.screenrecordservice.ScreenRecordService.createVirtualDisplay(ScreenRecordService.java:160) at www.xjw.com.mymiracast2.screenrecordservice.ScreenRecordService.onStartCommand(ScreenRecordService.java:80) W/System.err: at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:4151) at android.app.ActivityThread.-wrap21(Unknown Source:0) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2119) at android.os.Handler.dispatchMessage(Handler.java:108) W/System.err: at android.os.Looper.loop(Looper.java:166) at android.app.ActivityThread.main(ActivityThread.java:7529) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:245) W/System.err: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:921) D/StrictMode: StrictMode policy violation; ~duration=7334 ms: android.os.StrictMode$StrictModeNetworkViolation: policy=65543 violation=4 at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1466) at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:356) at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:201) at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:183) at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:356) at java.net.Socket.connect(Socket.java:616) at java.net.Socket.connect(Socket.java:565) at java.net.Socket.<init>(Socket.java:445) at java.net.Socket.<init>(Socket.java:217) at www.xjw.com.mymiracast2.screenrecordservice.ScreenRecordService.onStartCommand(ScreenRecordService.java:74) at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:4151) at android.app.ActivityThread.-wrap21(Unknown Source:0) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2119) at android.os.Handler.dispatchMessage(Handler.java:108) at android.os.Looper.loop(Looper.java:166) at android.app.ActivityThread.main(ActivityThread.java:7529) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:245) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:921) D/StrictMode: StrictMode policy violation; ~duration=7332 ms: android.os.StrictMode$StrictModeNetworkViolation: policy=65543 violation=4 ``` ```
Android 7.0以上调用相机报错
Android 7.0以上调用相机报错 android.os.FileUriExposedException: file:///storage/emulated/0/file_image.jpg exposed beyond app through ClipData.Item.getUri()错误 在Application 中加入以下代码为什么就好了 ... 查了以下大家都是这样回复 却不知道为什么 有没有大神知道原理呀 ``` StrictMode.VmPolicy.Builder builder = new StrictMode.VmPolicy.Builder(); StrictMode.setVmPolicy(builder.build()); builder.detectFileUriExposure(); ```
需要编写一个调用摄像头拍照并存储的Android项目,run,模拟器中出现停止运行程序。
![图片说明](https://img-ask.csdn.net/upload/201705/25/1495703326_203796.png) 这是logcat中的error,请大神帮忙看下,在线等。 05-25 16:47:42.071: E/memtrack(3531): Couldn't load memtrack module (No such file or directory) 05-25 16:47:42.071: E/android.os.Debug(3531): failed to load memtrack module: -2 05-25 16:47:42.731: E/memtrack(3543): Couldn't load memtrack module (No such file or directory) 05-25 16:47:42.731: E/android.os.Debug(3543): failed to load memtrack module: -2 05-25 16:47:42.871: E/AndroidRuntime(3555): FATAL EXCEPTION: main 05-25 16:47:42.871: E/AndroidRuntime(3555): Process: com.example.imageforensics, PID: 3555 05-25 16:47:42.871: E/AndroidRuntime(3555): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.imageforensics/com.example.imageforensics.MainActivity}: java.lang.NullPointerException 05-25 16:47:42.871: E/AndroidRuntime(3555): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2193) 05-25 16:47:42.871: E/AndroidRuntime(3555): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2243) 05-25 16:47:42.871: E/AndroidRuntime(3555): at android.app.ActivityThread.access$800(ActivityThread.java:135) 05-25 16:47:42.871: E/AndroidRuntime(3555): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 05-25 16:47:42.871: E/AndroidRuntime(3555): at android.os.Handler.dispatchMessage(Handler.java:102) 05-25 16:47:42.871: E/AndroidRuntime(3555): at android.os.Looper.loop(Looper.java:136) 05-25 16:47:42.871: E/AndroidRuntime(3555): at android.app.ActivityThread.main(ActivityThread.java:5019) 05-25 16:47:42.871: E/AndroidRuntime(3555): at java.lang.reflect.Method.invokeNative(Native Method) 05-25 16:47:42.871: E/AndroidRuntime(3555): at java.lang.reflect.Method.invoke(Method.java:515) 05-25 16:47:42.871: E/AndroidRuntime(3555): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 05-25 16:47:42.871: E/AndroidRuntime(3555): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 05-25 16:47:42.871: E/AndroidRuntime(3555): at dalvik.system.NativeStart.main(Native Method) 05-25 16:47:42.871: E/AndroidRuntime(3555): Caused by: java.lang.NullPointerException 05-25 16:47:42.871: E/AndroidRuntime(3555): at com.example.imageforensics.MainActivity.onCreate(MainActivity.java:41) 05-25 16:47:42.871: E/AndroidRuntime(3555): at android.app.Activity.performCreate(Activity.java:5231) 05-25 16:47:42.871: E/AndroidRuntime(3555): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1104) 05-25 16:47:42.871: E/AndroidRuntime(3555): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2157) 05-25 16:47:42.871: E/AndroidRuntime(3555): ... 11 more 05-25 16:47:52.801: E/WindowManager(579): Starting window AppWindowToken{4a928a80 token=Token{4aa4ef10 ActivityRecord{4aa54878 u0 com.example.imageforensics/.MainActivity t5}}} timed out 05-25 16:50:45.769: E/PlayCommon(1158): [49] com.google.android.play.a.g.a(1054): Failed to connect to server: java.net.SocketTimeoutException: failed to connect to play.googleapis.com/216.58.200.234 (port 443) after 10000ms 05-25 16:55:17.075: E/GCM(1083): Missing checkin config file 05-25 16:55:17.075: E/GCM(1083): Missing checkin config file 05-25 16:57:06.124: E/PlayCommon(1158): [49] com.google.android.play.a.g.a(1054): Failed to connect to server: java.net.SocketTimeoutException: failed to connect to play.googleapis.com/216.58.200.234 (port 443) after 10000ms 05-25 16:57:16.084: E/memtrack(3582): Couldn't load memtrack module (No such file or directory) 05-25 16:57:16.084: E/android.os.Debug(3582): failed to load memtrack module: -2 05-25 16:57:27.884: E/BandwidthController(170): Updating quota globalAlert failed (No such file or directory)
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私有的数
win10系统安装教程(U盘PE+UEFI安装)
一、准备工作 u盘,电脑一台,win10原版镜像(msdn官网) 二、下载wepe工具箱  极力推荐微pe(微pe官方下载) 下载64位的win10 pe,使用工具箱制作启动U盘打开软件,   选择安装到U盘(按照操作无需更改) 三、重启进入pe系统   1、关机后,将U盘插入电脑 2、按下电源后,按住F12进入启动项选择(技嘉主板是F12)     选择需要启
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
Nginx 软件层面加强Nginx性能优化的面试问答和解决方案
Nginx 软件层面加强Nginx性能优化的面试问答和解决方案 去年我去爱卡汽车面试PHP,一轮和二轮面的都不错,在三轮面到Nginx的时候很多问题当时不知道怎么回答,确实没有深入学习过,花了一段时间的学习,终于能解答Nginx高性能优化的问题了,10月24号为了获得程序员勋章,发布了半个优化笔记,浏览到了1000+,受到这个鼓舞,我抽时间在仔细整理下关于Nginx性能优化的问题,我们从软件说起。...
【管理系统课程设计】美少女手把手教你后台管理
【文章后台管理系统】URL设计与建模分析+项目源码+运行界面 栏目管理、文章列表、用户管理、角色管理、权限管理模块(文章最后附有源码) 1. 这是一个什么系统? 1.1 学习后台管理系统的原因 随着时代的变迁,现如今各大云服务平台横空出世,市面上有许多如学生信息系统、图书阅读系统、停车场管理系统等的管理系统,而本人家里就有人在用烟草销售系统,直接在网上完成挑选、购买与提交收货点,方便又快捷。 试想,若没有烟草销售系统,本人家人想要购买烟草,还要独自前往药...
11月19日科技资讯|华为明日发布鸿蒙整体战略;京东宣告全面向技术转型;Kotlin 1.3.60 发布
「极客头条」—— 技术人员的新闻圈! CSDN 的读者朋友们早上好哇,「极客头条」来啦,快来看今天都有哪些值得我们技术人关注的重要新闻吧。扫描上方二维码进入 CSDN App 可以收听御姐萌妹 Style 的人工版音频哟。 一分钟速览新闻点! 6G 专家组成员:速率是 5G 的 10 至 100 倍,预计 2030 年商用 雷军:很多人多次劝我放弃WPS,能坚持下来并不是纯粹的商业决定 ...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n
化繁为简 - 腾讯计费高一致TDXA的实践之路
导语:腾讯计费是孵化于支撑腾讯内部业务千亿级营收的互联网计费平台,在如此庞大的业务体量下,腾讯计费要支撑业务的快速增长,同时还要保证每笔交易不错账。采用最终一致性或离线补...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip install selenium -i https://pypi.tuna.tsinghua.edu.cn/simple/ 
Java学习笔记(七十二)—— Cookie
概述 会话技术: 会话:一次会话中包含多次请求和响应 一次会话:浏览器第一次给服务器发送资源请求,会话建立,直到有一方断开为止 功能:在一次会话的范围内的多次请求间,共享数据 方式: 客户端会话技术:Cookie,把数据存储到客户端 服务器端会话技术:Session,把数据存储到服务器端 Cookie 概念:客户端会话技术,将数据存储到客户端 快速入门: 使用步骤: 创建C
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆  每天早上8:30推送 作者| Mr.K   编辑| Emma 来源| 技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯
程序员该看的几部电影
##1、骇客帝国(1999) 概念:在线/离线,递归,循环,矩阵等 剧情简介: 不久的将来,网络黑客尼奥对这个看似正常的现实世界产生了怀疑。 他结识了黑客崔妮蒂,并见到了黑客组织的首领墨菲斯。 墨菲斯告诉他,现实世界其实是由一个名叫“母体”的计算机人工智能系统控制,人们就像他们饲养的动物,没有自由和思想,而尼奥就是能够拯救人类的救世主。 可是,救赎之路从来都不会一帆风顺,到底哪里才是真实的世界?
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东
@程序员,如何花式构建线程?
作者 |曾建责编 | 郭芮出品 | CSDN(ID:CSDNnews)在项目和业务的开发中,我们难免要经常使用线程来进行业务处理,使用线程可以保证我们的业务在相互处理之间可以保证原子性...
破14亿,Python分析我国存在哪些人口危机!
2020年1月17日,国家统计局发布了2019年国民经济报告,报告中指出我国人口突破14亿。 猪哥的朋友圈被14亿人口刷屏,但是很多人并没有看到我国复杂的人口问题:老龄化、男女比例失衡、生育率下降、人口红利下降等。 今天我们就来分析一下我们国家的人口数据吧! 一、背景 1.人口突破14亿 2020年1月17日,国家统计局发布了 2019年国民经济报告 ,报告中指出:年末中国大陆总人口(包括31个
强烈推荐10本程序员在家读的书
很遗憾,这个鼠年春节注定是刻骨铭心的,新型冠状病毒让每个人的神经都是紧绷的。那些处在武汉的白衣天使们,尤其值得我们的尊敬。而我们这些窝在家里的程序员,能不外出就不外出,就是对社会做出的最大的贡献。 有些读者私下问我,窝了几天,有点颓丧,能否推荐几本书在家里看看。我花了一天的时间,挑选了 10 本我最喜欢的书,你可以挑选感兴趣的来读一读。读书不仅可以平复恐惧的压力,还可以对未来充满希望,毕竟苦难终
Linux自学篇——linux命令英文全称及解释
man: Manual 意思是手册,可以用这个命令查询其他命令的用法。 pwd:Print working directory 显示当前目录 su:Swith user 切换用户,切换到root用户 cd:Change directory 切换目录 ls:List files 列出目录下的文件 ps:Process Status 进程状态 mk
Python实战:抓肺炎疫情实时数据,画2019-nCoV疫情地图
文章目录1. 前言2. 数据下载3. 数据处理4. 数据可视化 1. 前言 今天,群里白垩老师问如何用python画武汉肺炎疫情地图。白垩老师是研究海洋生态与地球生物的学者,国家重点实验室成员,于不惑之年学习python,实为我等学习楷模。先前我并没有关注武汉肺炎的具体数据,也没有画过类似的数据分布图。于是就拿了两个小时,专门研究了一下,遂成此文。 2月6日追记:本文发布后,腾讯的数据源多次变更u
智力题(程序员面试经典)
NO.1  有20瓶药丸,其中19瓶装有1克/粒的药丸,余下一瓶装有1.1克/粒的药丸。给你一台称重精准的天平,怎么找出比较重的那瓶药丸?天平只能用一次。 解法 有时候,严格的限制条件有可能反倒是解题的线索。在这个问题中,限制条件是天平只能用一次。 因为天平只能用一次,我们也得以知道一个有趣的事实:一次必须同时称很多药丸,其实更准确地说,是必须从19瓶拿出药丸进行称重。否则,如果跳过两瓶或更多瓶药
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ......
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!
2020年的1月,我辞掉了我的第一份工作
其实,这篇文章,我应该早点写的,毕竟现在已经2月份了。不过一些其它原因,或者是我的惰性、还有一些迷茫的念头,让自己迟迟没有试着写一点东西,记录下,或者说是总结下自己前3年的工作上的经历、学习的过程。 我自己知道的,在写自己的博客方面,我的文笔很一般,非技术类的文章不想去写;另外我又是一个还比较热衷于技术的人,而平常复杂一点的东西,如果想写文章写的清楚点,是需要足够...
别低估自己的直觉,也别高估自己的智商
所有群全部吵翻天,朋友圈全部沦陷,公众号疯狂转发。这两周没怎么发原创,只发新闻,可能有人注意到了。我不是懒,是文章写了却没发,因为大家的关注力始终在这次的疫情上面,发了也没人看。当然,我...
Java坑人面试题系列: 包装类(中级难度)
Java Magazine上面有一个专门坑人的面试题系列: https://blogs.oracle.com/javamagazine/quiz-2。 这些问题的设计宗旨,主要是测试面试者对Java语言的了解程度,而不是为了用弯弯绕绕的手段把面试者搞蒙。 如果你看过往期的问题,就会发现每一个都不简单。 这些试题模拟了认证考试中的一些难题。 而 “中级(intermediate)” 和 “高级(ad
Spring Boot 2.x基础教程:使用JdbcTemplate访问MySQL数据库
在第2章节中,我们介绍了如何通过Spring Boot来实现HTTP接口,以及围绕HTTP接口相关的单元测试、文档生成等实用技能。但是,这些内容还不足以帮助我们构建一个动态应用的服务端程序。不论我们是要做App、小程序、还是传统的Web站点,对于用户的信息、相关业务的内容,通常都需要对其进行存储,而不是像第2章节中那样,把用户信息存储在内存中(重启就丢了!)。 对于信息的存储,现在已经有非常非常多...
基于Python的人脸自动戴口罩系统
目录 1、项目背景 2、页面设计 3、器官识别 4、退出系统 1、项目背景 2019年新型冠状病毒感染的肺炎疫情发生以来,牵动人心,举国哀痛,口罩、酒精、消毒液奇货可居。 抢不到口罩,怎么办?作为技术人今天分享如何使用Python实现自动戴口罩系统,来安慰自己,系统效果如下所示: 本系统的实现原理是借助 Dlib模块的Landmark人脸68个关键点检测库轻松识别出人脸五官
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
节后首个工作日,企业们集体开晨会让钉钉挂了
By 超神经场景描述:昨天 2 月 3 日,是大部分城市号召远程工作的第一天,全国有接近 2 亿人在家开始远程办公,钉钉上也有超过 1000 万家企业活跃起来。关键词:十一出行 人脸...
相关热词 c#导入fbx c#中屏蔽键盘某个键 c#正态概率密度 c#和数据库登陆界面设计 c# 高斯消去法 c# codedom c#读取cad文件文本 c# 控制全局鼠标移动 c# temp 目录 bytes初始化 c#
立即提问